Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@economist/component-ad-panel

Package Overview
Dependencies
Maintainers
1
Versions
25
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@economist/component-ad-panel - npm Package Compare versions

Comparing version 2.3.0 to 2.4.0

9

lib/index.js

@@ -63,6 +63,7 @@ 'use strict';

// Set targeting
pubAds.setTargeting('subs', targeting.subscriber);
if (targeting.etear) {
pubAds.setTargeting('etear', targeting.etear);
for (var targetingKey in targeting) {
if (targeting.hasOwnProperty(targetingKey)) {
pubAds.setTargeting(targetingKey, targeting[targetingKey]);
}
}

@@ -377,2 +378,2 @@

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/index.js"],"names":[],"mappings":";;;;;;;;AAEA;;;;AACA;;;;AACA;;;;;;;;;;;;;;AAEA,SAAS,QAAT,GAAoB;AAClB,MAAM,4BAA4B,IAAlC;AACA,MAAM,MAAM,EAAZ;AACA,SAAO,CAAC,KAAK,MAAL,KAAgB,yBAAjB,EAA4C,QAA5C,CAAqD,GAArD,CAAP;AACD;;AAED,IAAI,gBAAgB,EAApB;AACA,IAAM,SAAS,EAAf;AACA,SAAS,YAAT,CAAsB,SAAtB,EAAiC;AAC/B,MAAI,CAAC,OAAO,MAAZ,EAAoB;AAClB;AACD;AACD,YAAU,cAAV;AACA,SAAO,OAAP,CAAe,UAAC,GAAD,EAAS;AACtB,cAAU,OAAV,CAAkB,GAAlB;AACD,GAFD;;;AAKA,SAAO,MAAP,GAAgB,CAAhB;AACD;;IAEoB,O;;;UA+BZ,M,mBAAO,O,EAAS;AACrB,QAAM,YAAY,QAAQ,oBAAR,EAAlB;AACA,oBAAgB,OAAhB;;AAEA,cAAU,GAAV,CAAc,IAAd,CAAmB,YAAM;AACvB,UAAM,SAAS,UAAU,MAAV,EAAf;AACA,UAAM,YAAY,cAAc,SAAhC;;AAEA,aAAO,YAAP,CAAoB,MAApB,EAA4B,UAAU,UAAtC;;AAEA,UAAI,UAAU,KAAd,EAAqB;AACnB,eAAO,YAAP,CAAoB,OAApB,EAA6B,UAAU,KAAvC;AACD;;AAED,UAAI,cAAc,GAAlB,EAAuB;;AAErB,eAAO,mBAAP;AACD;;;AAGD,aAAO,iBAAP;AACD,KAjBD;AAkBD,G;;UAEM,U,yBAAa;AAClB,QAAM,YAAY,QAAQ,oBAAR,EAAlB;AACA,QAAI,OAAO,UAAU,OAAjB,KAA6B,UAAjC,EAA6C;AAC3C,mBAAa,SAAb;AACD,KAFD,MAEO;AACL,gBAAU,GAAV,CAAc,IAAd,CAAmB,YAAM;AACvB,qBAAa,SAAb;AACD,OAFD;AAGD;AACF,G;;UAEM,oB,mCAAuB;;AAE5B,QAAI,OAAO,MAAP,KAAkB,WAAlB,IAAiC,OAAO,OAAO,QAAd,KAA2B,WAAhE,EAA6E;AAC3E,aAAO,IAAP;AACD;AACD,QAAI,OAAO,SAAX,EAAsB;AACpB,aAAO,OAAO,SAAd;AACD;AACD,WAAO,SAAP,GAAmB,EAAE,KAAK,EAAP,EAAnB;AACA,QAAM,OAAO,SAAS,aAAT,CAAuB,QAAvB,CAAb;AACA,SAAK,KAAL,GAAa,IAAb;AACA,SAAK,IAAL,GAAY,iBAAZ;AACA,QAAM,SAAS,OAAO,QAAP,CAAgB,QAAhB,KAA6B,QAA5C;AACA,SAAK,GAAL,IAAe,SAAS,QAAT,GAAoB,OAAnC;AACA,WAAO,QAAP,CAAgB,IAAhB,CAAqB,WAArB,CAAiC,IAAjC;AACA,WAAO,OAAO,SAAd;AACD,G;;;;wBAjFyB;AACxB,aAAO;AACL,kBAAU,IADL;AAEL,kBAAU,IAFL;AAGL,wBAAgB,GAHX;AAIL,eAAO,CACL,EAAE,OAAO,EAAT,EAAa,QAAQ,EAArB,EADK,EAEL,EAAE,OAAO,EAAT,EAAa,QAAQ,EAArB,EAFK,EAGL,EAAE,OAAO,GAAT,EAAc,QAAQ,GAAtB,EAHK,EAIL,EAAE,OAAO,IAAT,EAAe,QAAQ,GAAvB,EAJK,CAJF;AAUL,qBAAa,CACX,CACE,EAAE,OAAO,GAAT,EAAc,QAAQ,GAAtB,EADF,EAEE,CACE,EAAE,OAAO,IAAT,EAAe,QAAQ,GAAvB,EADF,CAFF,CADW,EAOX,CACE,EAAE,OAAO,CAAT,EAAY,QAAQ,CAApB,EADF,EAEE,CACE,EAAE,OAAO,GAAT,EAAc,QAAQ,GAAtB,EADF,CAFF,CAPW,CAVR;AAwBL,mBAAW,EAxBN;AAyBL,gBAAQ;AAzBH,OAAP;AA2BD;;;AAuDD,qBAAqB;AAAA;;AAAA,sCAAN,IAAM;AAAN,UAAM;AAAA;;AAAA,iDACnB,4DAAS,IAAT,EADmB;;AAEnB,UAAK,qBAAL,GAA6B,MAAK,qBAAL,CAA2B,IAA3B,OAA7B;AACA,UAAK,uBAAL,GAA+B;AAAA,aAAM,IAAN;AAAA,KAA/B;AAHmB;AAIpB;;oBAED,kB,iCAAqB;AACnB,SAAK,QAAL,CAAc;AACZ,2BAAoB,UADR;AAEZ,mBAAa,KAFD;AAGZ,gBAAU;AAHE,KAAd;AAKD,G;;oBAED,iB,gCAAoB;AAClB,QAAI,KAAK,KAAL,IAAc,KAAK,KAAL,CAAW,KAA7B,EAAoC;AAClC,cAAQ,oBAAR;AACD;AACD,QAAI,CAAC,KAAK,KAAL,CAAW,QAAZ,IAAwB,KAAK,KAA7B,IAAsC,KAAK,KAAL,CAAW,KAAjD,IAA0D,CAAC,KAAK,KAAL,CAAW,WAA1E,EAAuF;AACrF,WAAK,UAAL;AACD;AACD,QAAI,KAAK,KAAL,CAAW,QAAf,EAAyB;AACvB,aAAO,gBAAP,CAAwB,QAAxB,EAAkC,KAAK,qBAAvC;AACA,aAAO,gBAAP,CAAwB,QAAxB,EAAkC,KAAK,qBAAvC;AACA,WAAK,qBAAL;AACD;AACF,G;;oBAED,oB,mCAAuB;AACrB,SAAK,qBAAL;AACD,G;;oBAED,mB,gCAAoB,G,EAAiB;AAAA,QAAZ,MAAY,yDAAH,CAAG;;AACnC,QAAM,mBAAmB,KAAK,sBAAL,EAAzB;AACA,QAAI,CAAC,gBAAD,IAAqB,OAAO,iBAAiB,qBAAxB,KAAkD,UAA3E,EAAuF;AACrF,aAAO,KAAP;AACD;AACD,QAAM,OAAO,KAAK,sBAAL,GAA8B,qBAA9B,EAAb;AACA,WAAO,KAAK,MAAL,GAAc,CAAC,MAAf,IACL,KAAK,KAAL,GAAa,CAAC,MADT,IAEL,KAAK,IAAL,GAAY,CAAC,OAAO,UAAP,IAAqB,SAAS,eAAT,CAAyB,WAA/C,IAA8D,MAFrE,IAGL,KAAK,GAAL,GAAW,CAAC,OAAO,WAAP,IAAsB,SAAS,eAAT,CAAyB,YAAhD,IAAgE,MAH7E;AAID,G;;oBAED,sB,qCAAyB;AACvB,WAAO,mBAAS,WAAT,CAAqB,KAAK,IAAL,CAAU,SAA/B,CAAP;AACD,G;;oBAED,qB,oCAAwB;AACtB,QAAM,mBAAmB,KAAK,IAAL,CAAU,SAAnC;AACA,QAAI,CAAC,KAAK,KAAL,CAAW,WAAZ,IACA,KAAK,mBAAL,CAAyB,gBAAzB,EAA2C,KAAK,KAAL,CAAW,cAAtD,CADJ,EAC2E;AACzE,WAAK,UAAL;AACD;AACD,QAAI,KAAK,mBAAL,CAAyB,gBAAzB,MAA+C,IAAnD,EAAyD;AACvD,UAAM,yBAAyB,KAAK,sBAAL,EAA/B;AACA,6BAAuB,SAAvB,IAAoC,oBAApC;AACA,WAAK,qBAAL;AACD;AACF,G;;oBAED,qB,oCAAwB;AACtB,WAAO,mBAAP,CAA2B,QAA3B,EAAqC,KAAK,qBAA1C;AACA,WAAO,mBAAP,CAA2B,QAA3B,EAAqC,KAAK,qBAA1C;AACA,SAAK,uBAAL;AACD,G;;oBAED,uB,0CAAuC;AAAA;;AAAA,QAAb,SAAa,QAAb,SAAa;;AACrC,QAAI,CAAC,UAAU,MAAf,EAAuB;AACrB,YAAM,IAAI,KAAJ,CAAU,sFAAV,CAAN;AACD;AACD,QAAI,CAAC,KAAK,MAAV,EAAkB;AAChB,YAAM,IAAI,KAAJ,CAAU,sEAAV,CAAN;AACD;;AAED,QAAM,OAAO,KAAK,MAAlB;;AAEA,QAAI,gBAAgB,KAApB;AACA,cAAU,MAAV,GAAmB,gBAAnB,CAAoC,iBAApC,EAAuD,UAAC,oBAAD,EAA0B;AAC/E,UAAI,iBAAiB,qBAAqB,IAArB,KAA8B,IAAnD,EAAyD;AACvD;AACD;AACD,UAAI,OAAK,KAAL,CAAW,iBAAf,EAAkC;AAChC,eAAK,KAAL,CAAW,iBAAX,CAA6B,oBAA7B;AACD;AACD,UAAI,qBAAqB,OAAzB,EAAkC;AAChC,eAAK,QAAL,CAAc,EAAE,UAAU,IAAZ,EAAd;AACA,eAAK,qBAAL;AACA,YAAI,OAAK,KAAL,CAAW,SAAf,EAA0B;AACxB,iBAAK,KAAL,CAAW,SAAX;AACD;AACD;AACD;AACD,aAAK,uBAAL;AACD,KAhBD;AAiBA,SAAK,uBAAL,GAA+B,YAAM;AACnC,sBAAgB,IAAhB;AACA,aAAO,IAAP;AACD,KAHD;AAID,G;;oBAED,gB,+BAAmB;AACjB,QAAM,UAAU,KAAK,KAAL,CAAW,WAAX,IAA0B,EAA1C;AACA,QAAM,YAAY,QAAQ,oBAAR,EAAlB;AACA,QAAI,CAAC,UAAU,WAAf,EAA4B;AAC1B,YAAM,IAAI,KAAJ,CAAU,+EAAV,CAAN;AACD;AACD,QAAM,qBAAqB,UAAU,WAAV,EAA3B;AACA,WAAO,QAAQ,MAAR,CAAe,UAAC,OAAD;AAAA,UAAY,YAAZ;AAAA,UAA0B,OAA1B;AAAA,aACpB,QAAQ,OAAR,CAAgB,sBAAO,YAAP,CAAhB,EAAsC,QAAQ,GAAR,kBAAtC,CADoB;AAAA,KAAf,EAEJ,kBAFI,EAEgB,KAFhB,EAAP;AAGD,G;;oBAED,U,yBAAa;AAAA;;AACX,QAAM,YAAY,QAAQ,oBAAR,EAAlB;AACA,QAAI,OAAO,KAAK,KAAL,CAAW,KAAlB,KAA4B,WAAhC,EAA6C;AAC3C;AACD;AACD,cAAU,GAAV,CAAc,IAAd,CAAmB,YAAM;AACvB,UAAM,cAAc,OAAK,gBAAL,EAApB;AADuB,mBAEE,OAAK,KAFP;AAAA,UAEf,KAFe,UAEf,KAFe;AAAA,UAER,KAFQ,UAER,KAFQ;AAAA,UAGf,KAHe,GAGL,OAAK,KAHA,CAGf,KAHe;;AAIvB,aAAK,MAAL,GAAc,UAAU,UAAV,CAAqB,KAArB,EAA4B,CAAC,SAAS,EAAV,EAAc,GAAd,kBAA5B,EAAuD,KAAvD,EACX,UADW,CACA,UAAU,MAAV,EADA,EAEX,iBAFW,CAEO,WAFP,CAAd;AAGA,2BAA6B,OAAK,KAAL,CAAW,SAAxC,kHAAmD;AAAA;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;AAAA;AAAA,YAAtC,GAAsC;AAAA,YAAjC,KAAiC;;AACjD,eAAK,MAAL,CAAY,YAAZ,CAAyB,GAAzB,EAA8B,KAA9B;AACD;AACD,UAAM,SAAS,UAAU,MAAV,EAAf;AACA,UAAI,cAAc,GAAlB,EAAuB;AACrB,eAAO,IAAP,CAAY,KAAZ;AACA,YAAI,OAAO,OAAK,KAAL,CAAW,aAAlB,KAAoC,UAAxC,EAAoD;AAClD,iBAAK,KAAL,CAAW,aAAX,CAAyB,KAAzB;AACD;AACF,OALD,MAKO;AACL,kBAAU,cAAV;AACA,kBAAU,OAAV,CAAkB,KAAlB;AACD;;AAED,aAAK,uBAAL,CAA6B,EAAE,oBAAF,EAA7B;AACA,UAAI,OAAK,KAAL,CAAW,oBAAf,EAAqC;AACnC,eAAO,gBAAP,CAAwB,oBAAxB,EAA8C,OAAK,KAAL,CAAW,oBAAzD;AACD;AACD,UAAI,OAAK,KAAL,CAAW,uBAAf,EAAwC;AACtC,eAAO,gBAAP,CAAwB,uBAAxB,EAAiD,OAAK,KAAL,CAAW,uBAA5D;AACD;AACF,KA5BD;AA6BA,SAAK,QAAL,CAAc,EAAE,aAAa,IAAf,EAAd;AACD,G;;oBAED,M,qBAAS;AACP,QAAI,KAAK,KAAL,IAAc,KAAK,KAAL,CAAW,QAA7B,EAAuC;AACrC,aAAQ,0CAAR;AACD;AACD,QAAI,MAAM,EAAV;AACA,QAAI,KAAK,KAAL,IAAc,KAAK,KAAL,CAAW,KAA7B,EAAoC;AAClC,UAAI,UAAU,EAAd;AACA,UAAI,KAAK,KAAL,CAAW,aAAf,EAA8B;AAC5B,kBAAU,EAAE,WAAW,KAAK,KAAL,CAAW,aAAxB,EAAV;AACD;AACD,YACE;AACE,mBAAU,oBADZ;AAEE,YAAI,KAAK,KAAL,CAAW,KAFjB;AAGE,eAAO,OAHT;AAIE,eAAM;AAJR,QADF;AAQD;AACD,QAAI,iBAAiB,CAAE,qBAAF,CAArB;AACA,QAAI,KAAK,KAAL,CAAW,MAAf,EAAuB;AACrB,uBAAiB,eAAe,MAAf,CAAsB,CAAE,6BAAF,CAAtB,CAAjB;AACD;AACD,QAAI,KAAK,KAAL,CAAW,KAAf,EAAsB;AACpB,uBAAiB,eAAe,MAAf,CAAsB,CAAE,4BAAF,CAAtB,CAAjB;AACD;AACD,QAAI,KAAK,KAAL,CAAW,QAAf,EAAyB;AACvB,uBAAiB,eAAe,MAAf,CAAsB,CAAE,oBAAF,CAAtB,CAAjB;AACD;AACD,QAAI,KAAK,KAAL,CAAW,SAAf,EAA0B;AACxB,uBAAiB,eAAe,MAAf,CAAsB,CAAE,KAAK,KAAL,CAAW,SAAb,CAAtB,CAAjB;AACD;AACD,QAAM,OAAO;AACX,YAAM,eADK;AAEX,iBAAW;AAFA,KAAb;AAIA,WACE;AAAA;MAAA,WAAK,KAAI,WAAT,EAAqB,WAAW,eAAe,IAAf,CAAoB,GAApB,CAAhC,IAA8D,IAA9D;MACG;AADH,KADF;AAKD,G;;;EAnRkC,gBAAM,S;;kBAAtB,O;;;AAsRrB,IAAI,QAAQ,GAAR,CAAY,QAAZ,KAAyB,YAA7B,EAA2C;AACzC,MAAM,aAAa,gBAAM,SAAN,CAAgB,KAAhB,CACjB,gBAAM,SAAN,CAAgB,OAAhB,CAAwB,gBAAM,SAAN,CAAgB,MAAxC,CADiB,EAEjB,gBAAM,SAAN,CAAgB,KAAhB,CAAsB;AACpB,WAAO,gBAAM,SAAN,CAAgB,MADH;AAEpB,YAAQ,gBAAM,SAAN,CAAgB;AAFJ,GAAtB,CAFiB,CAAnB;AAOA,UAAQ,SAAR,GAAoB;AAClB,cAAU,gBAAM,SAAN,CAAgB,IADR;AAElB,WAAO,gBAAM,SAAN,CAAgB,MAAhB,CAAuB,UAFZ;AAGlB,eAAW,gBAAM,SAAN,CAAgB,MAHT;AAIlB,cAAU,gBAAM,SAAN,CAAgB,IAJR;AAKlB,oBAAgB,gBAAM,SAAN,CAAgB,MALd;AAMlB,WAAO,gBAAM,SAAN,CAAgB,OAAhB,CAAwB,UAAxB,CANW;AAOlB,iBAAa,gBAAM,SAAN,CAAgB,OAAhB,CACX,gBAAM,SAAN,CAAgB,OAAhB,CACE,UADF,CADW,CAPK;AAYlB,eAAW,gBAAM,SAAN,CAAgB,IAZT;AAalB,mBAAe,gBAAM,SAAN,CAAgB,IAbb;AAclB,eAAW,gBAAM,SAAN,CAAgB,OAAhB,CAAwB,gBAAM,SAAN,CAAgB,OAAhB,CAAwB,UAAxB,CAAxB,CAdO;AAelB,mBAAe,gBAAM,SAAN,CAAgB,MAfb;AAgBlB,YAAQ,gBAAM,SAAN,CAAgB,IAhBN;AAiBlB,WAAO,gBAAM,SAAN,CAAgB,IAjBL;AAkBlB,uBAAmB,gBAAM,SAAN,CAAgB,IAlBjB;AAmBlB,6BAAyB,gBAAM,SAAN,CAAgB,IAnBvB;AAoBlB,0BAAsB,gBAAM,SAAN,CAAgB;AApBpB,GAApB;AAsBD","file":"index.js","sourcesContent":["/* global window: false */\n/* global document: false */\nimport React from 'react';\nimport ReactDom from 'react-dom';\nimport values from 'lodash.values';\n\nfunction uniqueId() {\n  const mathRandomToIntMultiplier = 1e17;\n  const hex = 16;\n  return (Math.random() * mathRandomToIntMultiplier).toString(hex);\n}\n\nlet adPanelConfig = {};\nconst adDivs = [];\nfunction displayAdsFn(googleTag) {\n  if (!adDivs.length) {\n    return;\n  }\n  googleTag.enableServices();\n  adDivs.forEach((div) => {\n    googleTag.display(div);\n  });\n\n  // Clean up\n  adDivs.length = 0;\n}\n\nexport default class AdPanel extends React.Component {\n  static get defaultProps() {\n    return {\n      animated: true,\n      lazyLoad: true,\n      lazyLoadMargin: 600,\n      sizes: [\n        { width: 60, height: 60 },\n        { width: 70, height: 70 },\n        { width: 300, height: 250 },\n        { width: 1024, height: 768 },\n      ],\n      sizeMapping: [\n        [\n          { width: 980, height: 200 },\n          [\n            { width: 1024, height: 768 },\n          ],\n        ],\n        [\n          { width: 0, height: 0 },\n          [\n            { width: 300, height: 250 },\n          ],\n        ],\n      ],\n      targeting: [],\n      styled: true,\n    };\n  }\n\n  static config(options) {\n    const googleTag = AdPanel.getOrCreateGoogleTag();\n    adPanelConfig = options;\n\n    googleTag.cmd.push(() => {\n      const pubAds = googleTag.pubads();\n      const targeting = adPanelConfig.targeting;\n      // Set targeting\n      pubAds.setTargeting('subs', targeting.subscriber);\n\n      if (targeting.etear) {\n        pubAds.setTargeting('etear', targeting.etear);\n      }\n\n      if (adPanelConfig.sra) {\n        // enables Single Request Architecture (SRA)\n        pubAds.enableSingleRequest();\n      }\n\n      // Collapses empty div elements on a page when there is no ad content to display.\n      pubAds.collapseEmptyDivs();\n    });\n  }\n\n  static displayAds() {\n    const googleTag = AdPanel.getOrCreateGoogleTag();\n    if (typeof googleTag.display === 'function') {\n      displayAdsFn(googleTag);\n    } else {\n      googleTag.cmd.push(() => {\n        displayAdsFn(googleTag);\n      });\n    }\n  }\n\n  static getOrCreateGoogleTag() {\n    /* global window: false */\n    if (typeof window === 'undefined' || typeof window.document === 'undefined') {\n      return null;\n    }\n    if (window.googletag) {\n      return window.googletag;\n    }\n    window.googletag = { cmd: [] };\n    const gads = document.createElement('script');\n    gads.async = true;\n    gads.type = 'text/javascript';\n    const useSsl = window.location.protocol === 'https:';\n    gads.src = `${ useSsl ? 'https:' : 'http:' }//www.googletagservices.com/tag/js/gpt.js`;\n    window.document.head.appendChild(gads);\n    return window.googletag;\n  }\n\n  constructor(...args) {\n    super(...args);\n    this.loadElementWhenInView = this.loadElementWhenInView.bind(this);\n    this.unlistenSlotRenderEnded = () => null;\n  }\n\n  componentWillMount() {\n    this.setState({\n      tagId: `googlead-${ uniqueId() }`,\n      adGenerated: false,\n      adFailed: false,\n    });\n  }\n\n  componentDidMount() {\n    if (this.state && this.state.tagId) {\n      AdPanel.getOrCreateGoogleTag();\n    }\n    if (!this.props.lazyLoad && this.state && this.state.tagId && !this.state.adGenerated) {\n      this.generateAd();\n    }\n    if (this.props.lazyLoad) {\n      window.addEventListener('scroll', this.loadElementWhenInView);\n      window.addEventListener('resize', this.loadElementWhenInView);\n      this.loadElementWhenInView();\n    }\n  }\n\n  componentWillUnmount() {\n    this.cleanupEventListeners();\n  }\n\n  isElementInViewport(elm, margin = 0) {\n    const containerElement = this.getContainerDomElement();\n    if (!containerElement || typeof containerElement.getBoundingClientRect !== 'function') {\n      return false;\n    }\n    const rect = this.getContainerDomElement().getBoundingClientRect();\n    return rect.bottom > -margin &&\n      rect.right > -margin &&\n      rect.left < (window.innerWidth || document.documentElement.clientWidth) + margin &&\n      rect.top < (window.innerHeight || document.documentElement.clientHeight) + margin;\n  }\n\n  getContainerDomElement() {\n    return ReactDom.findDOMNode(this.refs.container);\n  }\n\n  loadElementWhenInView() {\n    const containerElement = this.refs.container;\n    if (!this.state.adGenerated &&\n        this.isElementInViewport(containerElement, this.props.lazyLoadMargin)) {\n      this.generateAd();\n    }\n    if (this.isElementInViewport(containerElement) === true) {\n      const targetContainerElement = this.getContainerDomElement();\n      targetContainerElement.className += ' ad-panel--visible';\n      this.cleanupEventListeners();\n    }\n  }\n\n  cleanupEventListeners() {\n    window.removeEventListener('scroll', this.loadElementWhenInView);\n    window.removeEventListener('resize', this.loadElementWhenInView);\n    this.unlistenSlotRenderEnded();\n  }\n\n  listenToSlotRenderEnded({ googleTag }) {\n    if (!googleTag.pubads) {\n      throw new Error('listenToSlotRenderEnded() must be called inside a googletag.cmd.push()\\'ed function!');\n    }\n    if (!this.adSlot) {\n      throw new Error('listenToSlotRenderEnded() must be called with this.adSlot available!');\n    }\n\n    const slot = this.adSlot;\n    // the GPT API doesn't have a removeEventListener function\n    let stopListening = false;\n    googleTag.pubads().addEventListener('slotRenderEnded', (slotRenderEndedEvent) => {\n      if (stopListening || slotRenderEndedEvent.slot !== slot) {\n        return;\n      }\n      if (this.props.onSlotRenderEnded) {\n        this.props.onSlotRenderEnded(slotRenderEndedEvent);\n      }\n      if (slotRenderEndedEvent.isEmpty) {\n        this.setState({ adFailed: true });\n        this.cleanupEventListeners();\n        if (this.props.onFailure) {\n          this.props.onFailure();\n        }\n        return;\n      }\n      this.unlistenSlotRenderEnded();\n    });\n    this.unlistenSlotRenderEnded = () => {\n      stopListening = true;\n      return null;\n    };\n  }\n\n  buildSizeMapping() {\n    const mapping = this.props.sizeMapping || [];\n    const googleTag = AdPanel.getOrCreateGoogleTag();\n    if (!googleTag.sizeMapping) {\n      throw new Error('buildSizeMapping() must be called inside a googletag.cmd.push()\\'ed function!');\n    }\n    const sizeMappingBuilder = googleTag.sizeMapping();\n    return mapping.reduce((builder, [ viewportSize, adSizes ]) => (\n      builder.addSize(values(viewportSize), adSizes.map(values))\n    ), sizeMappingBuilder).build();\n  }\n\n  generateAd() {\n    const googleTag = AdPanel.getOrCreateGoogleTag();\n    if (typeof this.props.adTag === 'undefined') {\n      return;\n    }\n    googleTag.cmd.push(() => {\n      const sizeMapping = this.buildSizeMapping();\n      const { adTag, sizes } = this.props;\n      const { tagId } = this.state;\n      this.adSlot = googleTag.defineSlot(adTag, (sizes || []).map(values), tagId)\n        .addService(googleTag.pubads())\n        .defineSizeMapping(sizeMapping);\n      for (const [ key, value ] of this.props.targeting) {\n        this.adSlot.setTargeting(key, value);\n      }\n      const pubAds = googleTag.pubads();\n      if (adPanelConfig.sra) {\n        adDivs.push(tagId);\n        if (typeof this.props.onSlotDefined === 'function') {\n          this.props.onSlotDefined(tagId);\n        }\n      } else {\n        googleTag.enableServices();\n        googleTag.display(tagId);\n      }\n\n      this.listenToSlotRenderEnded({ googleTag });\n      if (this.props.onImpressionViewable) {\n        pubAds.addEventListener('impressionViewable', this.props.onImpressionViewable);\n      }\n      if (this.props.onSlotVisibilityChanged) {\n        pubAds.addEventListener('slotVisibilityChanged', this.props.onSlotVisibilityChanged);\n      }\n    });\n    this.setState({ adGenerated: true });\n  }\n\n  render() {\n    if (this.state && this.state.adFailed) {\n      return (<div />);\n    }\n    let tag = [];\n    if (this.state && this.state.tagId) {\n      let adStyle = {};\n      if (this.props.reserveHeight) {\n        adStyle = { minHeight: this.props.reserveHeight };\n      }\n      tag = (\n        <div\n          className=\"ad-panel__googlead\"\n          id={this.state.tagId}\n          style={adStyle}\n          title=\"Advertisement\"\n        ></div>\n      );\n    }\n    let rootClassNames = [ 'ad-panel__container' ];\n    if (this.props.styled) {\n      rootClassNames = rootClassNames.concat([ 'ad-panel__container--styled' ]);\n    }\n    if (this.props.block) {\n      rootClassNames = rootClassNames.concat([ 'ad-panel__container--block' ]);\n    }\n    if (this.props.animated) {\n      rootClassNames = rootClassNames.concat([ 'ad-panel__animated' ]);\n    }\n    if (this.props.className) {\n      rootClassNames = rootClassNames.concat([ this.props.className ]);\n    }\n    const aria = {\n      role: 'complementary',\n      itemScope: 'https://schema.org/WPAdBlock',\n    };\n    return (\n      <div ref=\"container\" className={rootClassNames.join(' ')} {...aria}>\n        {tag}\n      </div>\n    );\n  }\n}\n\nif (process.env.NODE_ENV !== 'production') {\n  const sizeObject = React.PropTypes.oneOf(\n    React.PropTypes.arrayOf(React.PropTypes.number),\n    React.PropTypes.shape({\n      width: React.PropTypes.number,\n      height: React.PropTypes.number,\n    })\n  );\n  AdPanel.propTypes = {\n    animated: React.PropTypes.bool,\n    adTag: React.PropTypes.string.isRequired,\n    className: React.PropTypes.string,\n    lazyLoad: React.PropTypes.bool,\n    lazyLoadMargin: React.PropTypes.number,\n    sizes: React.PropTypes.arrayOf(sizeObject),\n    sizeMapping: React.PropTypes.arrayOf(\n      React.PropTypes.arrayOf(\n        sizeObject\n      )\n    ),\n    onFailure: React.PropTypes.func,\n    onSlotDefined: React.PropTypes.func,\n    targeting: React.PropTypes.arrayOf(React.PropTypes.arrayOf(sizeObject)),\n    reserveHeight: React.PropTypes.number,\n    styled: React.PropTypes.bool,\n    block: React.PropTypes.bool,\n    onSlotRenderEnded: React.PropTypes.func,\n    onSlotVisibilityChanged: React.PropTypes.func,\n    onImpressionViewable: React.PropTypes.func,\n  };\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/index.js"],"names":[],"mappings":"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","file":"index.js","sourcesContent":["/* global window: false */\n/* global document: false */\nimport React from 'react';\nimport ReactDom from 'react-dom';\nimport values from 'lodash.values';\n\nfunction uniqueId() {\n  const mathRandomToIntMultiplier = 1e17;\n  const hex = 16;\n  return (Math.random() * mathRandomToIntMultiplier).toString(hex);\n}\n\nlet adPanelConfig = {};\nconst adDivs = [];\nfunction displayAdsFn(googleTag) {\n  if (!adDivs.length) {\n    return;\n  }\n  googleTag.enableServices();\n  adDivs.forEach((div) => {\n    googleTag.display(div);\n  });\n\n  // Clean up\n  adDivs.length = 0;\n}\n\nexport default class AdPanel extends React.Component {\n  static get defaultProps() {\n    return {\n      animated: true,\n      lazyLoad: true,\n      lazyLoadMargin: 600,\n      sizes: [\n        { width: 60, height: 60 },\n        { width: 70, height: 70 },\n        { width: 300, height: 250 },\n        { width: 1024, height: 768 },\n      ],\n      sizeMapping: [\n        [\n          { width: 980, height: 200 },\n          [\n            { width: 1024, height: 768 },\n          ],\n        ],\n        [\n          { width: 0, height: 0 },\n          [\n            { width: 300, height: 250 },\n          ],\n        ],\n      ],\n      targeting: [],\n      styled: true,\n    };\n  }\n\n  static config(options) {\n    const googleTag = AdPanel.getOrCreateGoogleTag();\n    adPanelConfig = options;\n\n    googleTag.cmd.push(() => {\n      const pubAds = googleTag.pubads();\n      const targeting = adPanelConfig.targeting;\n      // Set targeting\n\n      for (const targetingKey in targeting) {\n        if (targeting.hasOwnProperty(targetingKey)) {\n          pubAds.setTargeting(targetingKey, targeting[targetingKey]);\n        }\n      }\n\n      if (adPanelConfig.sra) {\n        // enables Single Request Architecture (SRA)\n        pubAds.enableSingleRequest();\n      }\n\n      // Collapses empty div elements on a page when there is no ad content to display.\n      pubAds.collapseEmptyDivs();\n    });\n  }\n\n  static displayAds() {\n    const googleTag = AdPanel.getOrCreateGoogleTag();\n    if (typeof googleTag.display === 'function') {\n      displayAdsFn(googleTag);\n    } else {\n      googleTag.cmd.push(() => {\n        displayAdsFn(googleTag);\n      });\n    }\n  }\n\n  static getOrCreateGoogleTag() {\n    /* global window: false */\n    if (typeof window === 'undefined' || typeof window.document === 'undefined') {\n      return null;\n    }\n    if (window.googletag) {\n      return window.googletag;\n    }\n    window.googletag = { cmd: [] };\n    const gads = document.createElement('script');\n    gads.async = true;\n    gads.type = 'text/javascript';\n    const useSsl = window.location.protocol === 'https:';\n    gads.src = `${ useSsl ? 'https:' : 'http:' }//www.googletagservices.com/tag/js/gpt.js`;\n    window.document.head.appendChild(gads);\n    return window.googletag;\n  }\n\n  constructor(...args) {\n    super(...args);\n    this.loadElementWhenInView = this.loadElementWhenInView.bind(this);\n    this.unlistenSlotRenderEnded = () => null;\n  }\n\n  componentWillMount() {\n    this.setState({\n      tagId: `googlead-${ uniqueId() }`,\n      adGenerated: false,\n      adFailed: false,\n    });\n  }\n\n  componentDidMount() {\n    if (this.state && this.state.tagId) {\n      AdPanel.getOrCreateGoogleTag();\n    }\n    if (!this.props.lazyLoad && this.state && this.state.tagId && !this.state.adGenerated) {\n      this.generateAd();\n    }\n    if (this.props.lazyLoad) {\n      window.addEventListener('scroll', this.loadElementWhenInView);\n      window.addEventListener('resize', this.loadElementWhenInView);\n      this.loadElementWhenInView();\n    }\n  }\n\n  componentWillUnmount() {\n    this.cleanupEventListeners();\n  }\n\n  isElementInViewport(elm, margin = 0) {\n    const containerElement = this.getContainerDomElement();\n    if (!containerElement || typeof containerElement.getBoundingClientRect !== 'function') {\n      return false;\n    }\n    const rect = this.getContainerDomElement().getBoundingClientRect();\n    return rect.bottom > -margin &&\n      rect.right > -margin &&\n      rect.left < (window.innerWidth || document.documentElement.clientWidth) + margin &&\n      rect.top < (window.innerHeight || document.documentElement.clientHeight) + margin;\n  }\n\n  getContainerDomElement() {\n    return ReactDom.findDOMNode(this.refs.container);\n  }\n\n  loadElementWhenInView() {\n    const containerElement = this.refs.container;\n    if (!this.state.adGenerated &&\n        this.isElementInViewport(containerElement, this.props.lazyLoadMargin)) {\n      this.generateAd();\n    }\n    if (this.isElementInViewport(containerElement) === true) {\n      const targetContainerElement = this.getContainerDomElement();\n      targetContainerElement.className += ' ad-panel--visible';\n      this.cleanupEventListeners();\n    }\n  }\n\n  cleanupEventListeners() {\n    window.removeEventListener('scroll', this.loadElementWhenInView);\n    window.removeEventListener('resize', this.loadElementWhenInView);\n    this.unlistenSlotRenderEnded();\n  }\n\n  listenToSlotRenderEnded({ googleTag }) {\n    if (!googleTag.pubads) {\n      throw new Error('listenToSlotRenderEnded() must be called inside a googletag.cmd.push()\\'ed function!');\n    }\n    if (!this.adSlot) {\n      throw new Error('listenToSlotRenderEnded() must be called with this.adSlot available!');\n    }\n\n    const slot = this.adSlot;\n    // the GPT API doesn't have a removeEventListener function\n    let stopListening = false;\n    googleTag.pubads().addEventListener('slotRenderEnded', (slotRenderEndedEvent) => {\n      if (stopListening || slotRenderEndedEvent.slot !== slot) {\n        return;\n      }\n      if (this.props.onSlotRenderEnded) {\n        this.props.onSlotRenderEnded(slotRenderEndedEvent);\n      }\n      if (slotRenderEndedEvent.isEmpty) {\n        this.setState({ adFailed: true });\n        this.cleanupEventListeners();\n        if (this.props.onFailure) {\n          this.props.onFailure();\n        }\n        return;\n      }\n      this.unlistenSlotRenderEnded();\n    });\n    this.unlistenSlotRenderEnded = () => {\n      stopListening = true;\n      return null;\n    };\n  }\n\n  buildSizeMapping() {\n    const mapping = this.props.sizeMapping || [];\n    const googleTag = AdPanel.getOrCreateGoogleTag();\n    if (!googleTag.sizeMapping) {\n      throw new Error('buildSizeMapping() must be called inside a googletag.cmd.push()\\'ed function!');\n    }\n    const sizeMappingBuilder = googleTag.sizeMapping();\n    return mapping.reduce((builder, [ viewportSize, adSizes ]) => (\n      builder.addSize(values(viewportSize), adSizes.map(values))\n    ), sizeMappingBuilder).build();\n  }\n\n  generateAd() {\n    const googleTag = AdPanel.getOrCreateGoogleTag();\n    if (typeof this.props.adTag === 'undefined') {\n      return;\n    }\n    googleTag.cmd.push(() => {\n      const sizeMapping = this.buildSizeMapping();\n      const { adTag, sizes } = this.props;\n      const { tagId } = this.state;\n      this.adSlot = googleTag.defineSlot(adTag, (sizes || []).map(values), tagId)\n        .addService(googleTag.pubads())\n        .defineSizeMapping(sizeMapping);\n      for (const [ key, value ] of this.props.targeting) {\n        this.adSlot.setTargeting(key, value);\n      }\n      const pubAds = googleTag.pubads();\n      if (adPanelConfig.sra) {\n        adDivs.push(tagId);\n        if (typeof this.props.onSlotDefined === 'function') {\n          this.props.onSlotDefined(tagId);\n        }\n      } else {\n        googleTag.enableServices();\n        googleTag.display(tagId);\n      }\n\n      this.listenToSlotRenderEnded({ googleTag });\n      if (this.props.onImpressionViewable) {\n        pubAds.addEventListener('impressionViewable', this.props.onImpressionViewable);\n      }\n      if (this.props.onSlotVisibilityChanged) {\n        pubAds.addEventListener('slotVisibilityChanged', this.props.onSlotVisibilityChanged);\n      }\n    });\n    this.setState({ adGenerated: true });\n  }\n\n  render() {\n    if (this.state && this.state.adFailed) {\n      return (<div />);\n    }\n    let tag = [];\n    if (this.state && this.state.tagId) {\n      let adStyle = {};\n      if (this.props.reserveHeight) {\n        adStyle = { minHeight: this.props.reserveHeight };\n      }\n      tag = (\n        <div\n          className=\"ad-panel__googlead\"\n          id={this.state.tagId}\n          style={adStyle}\n          title=\"Advertisement\"\n        ></div>\n      );\n    }\n    let rootClassNames = [ 'ad-panel__container' ];\n    if (this.props.styled) {\n      rootClassNames = rootClassNames.concat([ 'ad-panel__container--styled' ]);\n    }\n    if (this.props.block) {\n      rootClassNames = rootClassNames.concat([ 'ad-panel__container--block' ]);\n    }\n    if (this.props.animated) {\n      rootClassNames = rootClassNames.concat([ 'ad-panel__animated' ]);\n    }\n    if (this.props.className) {\n      rootClassNames = rootClassNames.concat([ this.props.className ]);\n    }\n    const aria = {\n      role: 'complementary',\n      itemScope: 'https://schema.org/WPAdBlock',\n    };\n    return (\n      <div ref=\"container\" className={rootClassNames.join(' ')} {...aria}>\n        {tag}\n      </div>\n    );\n  }\n}\n\nif (process.env.NODE_ENV !== 'production') {\n  const sizeObject = React.PropTypes.oneOf(\n    React.PropTypes.arrayOf(React.PropTypes.number),\n    React.PropTypes.shape({\n      width: React.PropTypes.number,\n      height: React.PropTypes.number,\n    })\n  );\n  AdPanel.propTypes = {\n    animated: React.PropTypes.bool,\n    adTag: React.PropTypes.string.isRequired,\n    className: React.PropTypes.string,\n    lazyLoad: React.PropTypes.bool,\n    lazyLoadMargin: React.PropTypes.number,\n    sizes: React.PropTypes.arrayOf(sizeObject),\n    sizeMapping: React.PropTypes.arrayOf(\n      React.PropTypes.arrayOf(\n        sizeObject\n      )\n    ),\n    onFailure: React.PropTypes.func,\n    onSlotDefined: React.PropTypes.func,\n    targeting: React.PropTypes.arrayOf(React.PropTypes.arrayOf(sizeObject)),\n    reserveHeight: React.PropTypes.number,\n    styled: React.PropTypes.bool,\n    block: React.PropTypes.bool,\n    onSlotRenderEnded: React.PropTypes.func,\n    onSlotVisibilityChanged: React.PropTypes.func,\n    onImpressionViewable: React.PropTypes.func,\n  };\n}\n"]}
{
"name": "@economist/component-ad-panel",
"version": "2.3.0",
"version": "2.4.0",
"description": "An advert panel using GPT tags",

@@ -5,0 +5,0 @@ "homepage": "https://github.com/economist-components/component-ad-panel",

SocketSocket SOC 2 Logo

Product

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

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc