(function () {
  //Inject code v5.2

  var highcharts = document.createElement('script');
  var injectVersion = 5;
  var cdn = 'https://code.highcharts.com/';
  var loaded = 0;  
  var encodedUrl = encodeURI('https://https://app.everviz.com//show/6bn5rTBlo');
  var chartCreated = false;
  var chart = false;
  var delayGen = 0;
  var scripts = [
    "highcharts.js",
    "modules/stock.js",
    "highcharts-more.js",
    "highcharts-3d.js",
    "modules/data.js",
    "modules/exporting.js",
    "modules/funnel.js",
    "modules/solid-gauge.js",
    "modules/export-data.js",
    "modules/accessibility.js"
  ];

  const inEmbedCode = window.location.pathname.indexOf('/embed/') > -1;
  const inEverviz = window.location.origin === 'https://app.everviz.com';
  const loadHighchartsModules = inEverviz && !inEmbedCode;

  var legacyElementClassName = 'highcharts-6bn5rTBlo';
  var elementClassName = 'everviz-6bn5rTBlo';
  var externalCSS = [
    "https://app.everviz.com/fonts/uWUXwFsgf/font.css",
    "https://app.everviz.com/fonts/PrbXiHAt4/font.css",
    "https://app.everviz.com/fonts/GmilNayOv/font.css",
    "https://app.everviz.com/resources/css/highcharts-small-screen-annotations.css",
    "https://app.everviz.com/static/fonts/gordita/style.css",
    "https://app.everviz.com/resources/css/highcharts-data-table.css"
  ];

  var extraScripts = [
  "https://code.highcharts.com/modules/annotations.js",
  "https://code.highcharts.com/modules/annotations-advanced.js",
  "https://app.everviz.com/resources/js/highcharts-small-screen-annotations.js",
  "https://app.everviz.com/resources/js/everviz-tooltip-helper.js",
  "https://app.everviz.com/resources/js/highcharts-scroll-animation.js",
  "https://app.everviz.com/resources/js/everviz-utils.js",
  "https://app.everviz.com/resources/js/highcharts-overrides.js",
  ];

  var options = {"chart":{"type":"line","polar":false,"plotBackgroundColor":"#ffffff","parallelAxes":{"labels":{"useHTML":true},"stackLabels":{"useHTML":true},"title":{"useHTML":true}},"style":{"fontFamily":"proximanova-medium","color":"#333","fontSize":"12px","fontWeight":"normal","fontStyle":"normal"}},"title":{"align":"center","x":10,"style":{"fontFamily":"proximanova-medium","color":"#2b2b2b","fontSize":"16px","fontWeight":"bold","fontStyle":"normal","fill":"#333333","width":"1208px"},"useHTML":true,"text":"\n"},"subtitle":{"align":"center","x":10,"style":{"fontFamily":"proximanova_regular-webfont","color":"#2b2b2b","fontSize":"14px","fontWeight":"bold","fontStyle":"normal","fill":"#666666"},"useHTML":true,"text":""},"plotOptions":{"series":{"allowPointSelect":true,"states":{"select":{"color":"#EFFFEF","borderColor":"black","dashStyle":"dot"}},"label":{"enabled":false},"marker":{"enabled":false},"lineWidth":3,"dataLabels":{"style":{"fontFamily":"proximanova_bold-webfont"},"useHTML":true}},"spline":{"dataLabels":{"useHTML":true}}},"credits":{"href":"","enabled":false,"text":"everviz.com"},"lang":{"shortMonths":["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],"weekdays":["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],"months":["January","February","March","April","May","June","July","August","September","October","November","December"],"numericSymbols":["k","M","G","T","P","E"]},"colors":["#15571d","#028526","#b4821d","#d73034","#00b589","#e83237","#d5d5d5","#757575","#2b2b2b"],"legend":{"align":"center","verticalAlign":"top","itemMarginBottom":10,"x":0,"symbolRadius":0,"layout":"horizontal","useHTML":true,"symbolHeight":12,"itemStyle":{"fontFamily":"proximanova_regular-webfont","color":"#757575","fontSize":"16px","fontWeight":"normal","fontStyle":"normal","cursor":"pointer","textOverflow":"ellipsis"},"title":{"style":{"fontWeight":"bold","fontFamily":"\"Proxima Nova\", proximanova-medium","fontSize":"16px"}},"itemCheckboxStyle":{"width":"13px","height":"13px","position":"absolute","fontFamily":"\"Lucida Grande\", \"Lucida Sans Unicode\", Verdana, Arial, Helvetica, sans-serif","fontSize":"16px"},"squareSymbol":true,"symbolPadding":5},"series":[{"turboThreshold":0,"type":"line","marker":{"symbol":"circle"},"name":"Column 2","tooltip":{"useHTML":true},"data":[],"_colorIndex":0,"_symbolIndex":0,"color":"#15571d"},{"turboThreshold":0,"type":"line","name":"Column 3","data":[],"_colorIndex":1,"_symbolIndex":0},{"turboThreshold":0,"type":"line","name":"Column 4","data":[],"_colorIndex":2,"_symbolIndex":0},{"turboThreshold":0,"type":"line","name":"Column 5","data":[],"_colorIndex":3,"_symbolIndex":0}],"tooltip":{"shared":false,"useHTML":true,"style":{"fontFamily":"proximanova_regular-webfont"},"borderColor":"#NaNNaNNaN00","dateTimeLabelFormats":{"day":"%B %e %Y"},"headerFormat":"<div><span style=\"font-size: 10px;\">{point.key}</span></div>","pointFormat":"<div>● {series.name}: <strong>{point.y}%</strong></div>","footerFormat":""},"exporting":{"enabled":false,"url":"https://api.everviz.com/export"},"stockTools":{"gui":{"enabled":false}},"navigation":{"events":{},"bindingsClassName":"tools-container","annotationsOptions":{"labelOptions":{"useHTML":true}}},"labels":{"items":[]},"navigator":{"xAxis":{"labels":{"useHTML":true},"title":{"useHTML":true}}},"pane":{"background":[]},"responsive":{"rules":[{"condition":{"maxWidth":500},"chartOptions":{"legend":{"itemStyle":{"fontSize":"14px"}},"xAxis":{"labels":{"style":{"fontSize":"14px"}}},"yAxis":{"labels":{"style":{"fontSize":"14px"}}}},"_id":"highcharts-o9cbjhn-88"}]},"xAxis":{"labels":{"useHTML":true,"style":{"fontFamily":"proximanova_regular-webfont","fontSize":"14px","color":"#2b2b2b"},"format":"{value:%b ’%y}"},"title":{"style":{"fontFamily":"proximanova_regular-webfont"}},"lineColor":"#e6e6e6","type":"datetime","tickWidth":"0"},"yAxis":{"labels":{"useHTML":true,"style":{"fontFamily":"proximanova_regular-webfont","fontSize":"14px","color":"#2b2b2b"},"format":"{value}%"},"title":{"style":{"fontFamily":"proximanova_regular-webfont","fontSize":"14px"},"useHTML":true,"text":""},"max":100,"min":0,"tickAmount":6,"tickInterval":20},"annotations":[],"everviz":{"tooltip":{"useEvervizHelper":true}},"data":{"csv":"\"period_end\";\"Vaccinated\";\"Plans to get vaccinated\";\"Uncertain\";\"Unwilling\"\n\"2021-03-15\";26;36;18;21\n\"2021-03-22\";29;33;18;20\n\"2021-03-29\";35;29;17;19\n\"2021-04-05\";38;27;16;19\n\"2021-04-12\";43;24;15;19\n\"2021-04-19\";47;19;14;20\n\"2021-04-26\";49;17;14;20\n\"2021-05-03\";52;15;14;20\n\"2021-05-10\";54;13;14;19\n\"2021-05-17\";55;13;13;19\n\"2021-05-24\";57;12;12;19\n\"2021-05-31\";58;11;12;19\n\"2021-06-07\";58;10;12;20\n\"2021-06-14\";59;10;11;20\n\"2021-06-21\";60;10;11;19\n\"2021-06-28\";60;10;12;19\n\"2021-07-05\";60;10;11;19\n\"2021-07-12\";61;9;11;19\n\"2021-07-19\";61;9;11;19\n\"2021-07-26\";62;8;11;19\n\"2021-08-02\";63;8;11;19\n\"2021-08-09\";63;8;10;19\n\"2021-08-16\";64;8;10;17\n\"2021-08-23\";64;8;10;18\n\"2021-08-30\";65;8;10;17\n\"2021-09-06\";65;8;10;17\n\"2021-09-13\";65;7;10;18\n\"2021-09-20\";66;7;10;17\n\"2021-09-27\";66;7;10;18\n\"2021-10-04\";66;7;10;18\n\"2021-10-11\";66;7;9;18\n\"2021-10-18\";66;7;9;18\n\"2021-10-25\";67;6;9;18\n\"2021-11-01\";67;6;9;19\n\"2021-11-08\";67;6;9;18\n\"2021-11-15\";67;6;9;19\n\"2021-11-22\";68;6;8;18\n\"2021-11-29\";67;6;9;19\n\"2021-12-06\";67;6;9;19\n\"2021-12-13\";66;6;9;19\n\"2021-12-20\";67;6;9;19\n\"2022-01-03\";67;5;9;19\n\"2022-01-10\";66;6;8;20\n\"2022-01-18\";66;5;8;21\n\"2022-01-24\";66;5;8;20\n\"2022-01-31\";67;5;8;20\n\"2022-02-07\";68;5;8;20\n\"2022-02-14\";66;5;8;21\n\"2022-02-21\";67;4;8;21\n\"2022-02-28\";68;4;7;20\n\"2022-03-07\";68;4;7;21\n\"2022-03-14\";69;4;7;21\n\"2022-03-21\";70;4;6;20\n\"2022-03-28\";69;4;7;21\n\"2022-04-04\";71;4;6;19\n\"2022-04-11\";72;3;6;19\n\"2022-04-18\";71;3;7;19\n\"2022-04-25\";72;3;6;19\n\"2022-05-02\";71;3;6;19\n\"2022-05-09\";71;3;6;19\n\"2022-05-16\";71;3;6;19\n\"2022-05-23\";71;4;6;20\n\"2022-05-30\";71;3;7;19\n\"2022-06-06\";71;3;6;20\n\"2022-06-13\";70;3;6;20\n\"2022-06-20\";71;3;6;20\n\"2022-06-27\";71;3;6;20\n\"2022-07-04\";71;3;6;20\n\"2022-07-11\";71;3;6;20\n\"2022-07-18\";71;3;6;20\n\"2022-07-25\";71;3;6;20\n\"2022-08-01\";70;3;6;20\n\"2022-08-08\";71;3;6;21\n\"2022-08-15\";71;3;6;21\n\"2022-08-22\";71;3;6;21\n\"2022-08-29\";70;3;6;21\n\"2022-09-05\";71;3;6;20\n\"2022-09-12\";70;3;6;21\n\"2022-09-19\";70;3;6;21\n\"2022-09-26\";70;3;6;21\n\"2022-10-03\";71;3;6;21\n\"2022-10-10\";71;3;5;21\n\"2022-10-17\";69;3;6;22\n\"2022-10-24\";70;3;6;22\n\"2022-10-31\";70;3;6;22\n\"2022-11-07\";71;2;5;21\n\"2022-11-14\";71;3;5;21\n\"2022-11-21\";70;3;6;22\n\"2022-11-28\";70;3;6;22\n\"2022-12-05\";70;3;6;22\n\"2022-12-12\";70;3;6;22\n\"2022-12-19\";70;3;6;22\n\"2022-12-26\";70;3;6;22\n\"2023-01-02\";70;3;5;22\n\"2023-01-09\";70;3;5;22\n\"2023-01-16\";70;3;5;23\n\"2023-01-23\";70;3;5;23\n\"2023-01-30\";70;3;5;22\n\"2023-02-06\";70;3;5;22\n\"2023-02-13\";71;2;5;22\n\"2023-02-20\";71;2;5;22\n\"2023-02-27\";72;2;5;21\n\"2023-03-06\";71;2;5;22\n\"2023-03-13\";71;3;5;21","seriesMapping":[{"x":0,"y":1},{"x":0,"y":2},{"x":0,"y":3},{"x":0,"y":4}]}};
  var optionsStub;
  
  var templateDataSettings = {};

  var pluginCode = {};;

  function isScriptAlreadyIncluded(src){

    var scripts = document.getElementsByTagName("script");
    for (var i = 0; i < scripts.length; i++) {
      if (scripts[i].hasAttribute('src')) {
        const scriptTag = scripts[i].getAttribute('src') || '';
        if ((scriptTag.indexOf(src) >= 0) || 
            (scriptTag.indexOf('highcharts.src.js') > -1 && src === 'highcharts.js') ||
            ((scriptTag.indexOf('stock/highstock.js') > -1) && src === 'modules/highstock.js') ||
             (loadHighchartsModules && src === 'highcharts.js')) {
          return true;
        }
      }
    }
    return false;
  }

  function loadCSS() {
    var cssLength = externalCSS.length;
    for(var i=0; i < cssLength; i++) {
      var css = document.createElement('link');
      css.rel  = 'stylesheet';
      css.type = "text/css";
      css.href = externalCSS[i];
      document.body.appendChild(css);
    }
  }

  function allScriptsIncluded(){
    var allScripts = scripts.concat(extraScripts);
    var haveAllScriptsBeenIncluded = true;
    var scriptsToUse = document.getElementsByTagName("script");
    for(var n=0;n<allScripts.length;n++) {
      if (!isScriptAlreadyIncluded(allScripts[n], scriptsToUse)) {
        haveAllScriptsBeenIncluded = false;
        break;
      }
    }
    return haveAllScriptsBeenIncluded;
  }

  function modifyOptions(){
    if (options.data && !options.data.complete) {
      options.data.complete = function(chartOptions) {
        const keys = Object.keys(templateDataSettings || {});
        keys.forEach(function(key) {
          const serie = chartOptions.series[key];
          (serie.data || []).forEach(function(d, i) {
            if (templateDataSettings[key].data && templateDataSettings[key].data[i]) {
              window["everviz"].merge(d, templateDataSettings[key].data[i]);
            }
          })
        })

        if (options && options.chart && options.chart.type === 'packedbubble') {
          chartOptions.series.forEach((series) => {
            series.data = series.data.filter((point) => point.value);
          });
        }

        return chartOptions;
      }
    }
    
    optionsStub = window["everviz"].createStub(options);
    window["everviz"].merge(options, pluginCode);
    if ('Chart' === 'Map') window["everviz"].modifyMapType(options);
  }

  function createChart() {
    if(chartCreated) return;

    var hasProj4 = extraScripts.indexOf('https://cdnjs.cloudflare.com/ajax/libs/proj4js/2.3.6/proj4.js') > -1;

    if (!allScriptsIncluded() || 
      (hasProj4 && !window.proj4) || 
      !window["everviz"].merge ||
      !window["everviz"].createStub) {
      setTimeout(createChart, 200);
      return;
    }  

    modifyOptions();

    if (hasProj4) delayGen = 100;

    if (typeof window['Highcharts'] !== 'undefined') {
      
    if (window['everviz'] && window['everviz'].tooltipFormatter && 
        options.everviz && options.everviz.tooltip){
      if (!options.tooltip) options.tooltip = {};
      options.tooltip.formatter = window['everviz'].tooltipFormatter;
    }


    if (options.yAxis && options.yAxis.length === 1) options.yAxis = options.yAxis[0];
    if (options.xAxis && options.xAxis.length === 1) options.xAxis = options.xAxis[0];
    if (options.zAxis && options.zAxis.length === 1) options.zAxis = options.zAxis[0];

    Highcharts.merge(true, options, {
    responsive: {
        rules: [{
            condition: {
                maxWidth: 500
            },
            // Make the labels less space demanding on mobile
            chartOptions: {
                legend: {
                  itemStyle: {
                    fontSize: '14px'
                  }
                },
              	xAxis: {
        			labels: {
            			style: {
               				fontSize: '14px'
            			}
        			}
    			},
              	yAxis: {
        			labels: {
            			style: {
               				fontSize: '14px'
            			}
        			}
    			}
            }
        }]
    }
});


      if (options && (options.lang || options.global)) {
        Highcharts.setOptions({
          global: options.global || {},
          lang: options.lang || {}
        });
      }

      if (Highcharts.Annotation) {
        Highcharts.Annotation.ControlPoint.prototype.redraw = function (animation) {
          this.graphic[animation ? 'animate' : 'attr'](
              this.options.positioner ? this.options.positioner.call(this, this.target) : null
          );
        };
      }

      chartCreated = true;
      window.HighchartsCloud.hasLoaded = true; 
      setTimeout(function(){
          if (window["everviz"] && window["everviz"].pendingAnim) {
            //TODO: change to using classes instead.
            //Bit of work to do there due to backward compatibility
            const elements = document.querySelectorAll(
              '#' + elementClassName + 
              ', #' + legacyElementClassName
            );
            const elementsArray = Array.prototype.slice.call(elements);
            elementsArray.forEach(function(element, elementIndex) {

              window["everviz"].updateRenderTo(optionsStub, element);
              chart = new Highcharts.Chart(optionsStub);
              

              window["everviz"].pendingAnim({
                id: element.id + '-' + elementIndex, 
                loaded: false,
                options: options,
                appear:function(){
                  window["everviz"].updateRenderTo(options, element);
                  chart = new Highcharts.Chart(options); 

                },
                element: element
              });
            });

          } else {
            const element = document.querySelector('#' + legacyElementClassName);

            if (element) chart = new Highcharts.Chart(legacyElementClassName, options);  
            else chart = new Highcharts.Chart(elementClassName, options);  

            
          }
      }, delayGen);
    }
  }

  function check(scripts, cb) {
    if (loaded === scripts.length) {
      if (cb) {
        cb();
      } else {


        //Create first project
        if (!window.HighchartsCloud.versions ||
           (window.HighchartsCloud.versions && window.HighchartsCloud.versions.length !== window.HighchartsCloud.ondone.length)) {
             
          for (var i = 0; i < window.HighchartsCloud.ondone.length; i++) {
            try {
              window.HighchartsCloud.ondone[i]();
            } catch(e) {
              console.error(e);
            }
          }
        } else {
          if (window.HighchartsCloud.stack.length) {
            window.HighchartsCloud.stack[0]();
            window.HighchartsCloud.stack.shift();
            const shouldRenderNextChart = window.HighchartsCloud.stack.length > 0;
            if (shouldRenderNextChart) {
              window.HighchartsCloud.stack[0](true);
            }
          }
        }
        
      }
    }
  }

  function loadScript(s, scripts, cb) {
    if (!s) next();
    
    function next() {
      ++loaded;
      if (loaded < scripts.length) {
        loadScript(scripts[loaded], scripts, cb);
      }
      check(scripts, cb);
    }

    if (isScriptAlreadyIncluded(s)) {
      return next();
    }

    var n = document.createElement('script');

    n.onload = function () {
      next();
    };

    if (s.indexOf('http') >= 0) {
      n.src = s;
    } else {
      n.src = cdn + s;
    }
    document.body.appendChild(n);
  }

  function loadExtraScripts(){
    if (extraScripts.length > 0) {
      loaded = 0;
      loadScript(extraScripts[0], extraScripts);
    } else {
      check(scripts);
    }
  }

  function loadExtraScriptsAndMakeChart(isUsingStack){
    loaded = 0;
    loadCSS();
    if (extraScripts.length > 0) {
      if (isUsingStack) {
        window.HighchartsCloud.stack[0] = createChart;
        loadScript(extraScripts[0], extraScripts);
      }
      else loadScript(extraScripts[0], extraScripts, createChart);
    } else {
      check(extraScripts);
    }
  }

  function getAllScripts(){
    var evervizScripts = [];
    var allScripts = scripts.map(function(script) {
      return 'highcharts/'+ script.replace('highcharts/highcharts.js', 'highcharts.js').replace('.js', '');
    }).concat(
      extraScripts.map(function(script) {
        if (script.indexOf('https://code.highcharts.com/') > -1) {
          return 'highcharts/'+ script.replace('https://code.highcharts.com/', '').replace('.js', '');
        } else if (script.indexOf('https://app.everviz.com/') > -1) {
          evervizScripts.push(script);
          return null;
        } else return script;
      }).filter(function(s) {
        return s !== null;
      })
    );

    allScripts.forEach(function(script) {
      if (window.HighchartsCloud.allScripts)
        window.HighchartsCloud.allScripts[script] = 1
    });

    return {
      allHighchartsScripts: allScripts,
      evervizScripts: evervizScripts
    }
  }

  function loadRequireJSScript(){
    require.config({
      packages: [{
        name: 'highcharts',
        main: 'highcharts'
      }],
      paths: {
        'highcharts': 'https://code.highcharts.com'
      }
    });

    const allScripts = getAllScripts();

    require(
      allScripts.allHighchartsScripts,
      function (Highcharts) {
        //Attach highcharts to the window for use in the everviz scripts
        window.Highcharts = Highcharts;
        if (allScripts && allScripts.evervizScripts.length) {
          require(allScripts.evervizScripts, function(){
            createChart();
            loadCSS();
          })
        } else {
          createChart();
          loadCSS();
        }
      }
    );
  }

  function loadInitialScript(){
    if (window['require'] && typeof require === "function" && typeof require.specified === "function") {
      loadRequireJSScript();
    } else {
      getAllScripts()
      loadScript(scripts[0], scripts, loadExtraScripts);
      loadCSS();
    }
  }

  if (typeof window['HighchartsCloud'] === 'undefined') {
    window.HighchartsCloud = {
      ondone: [createChart],
      stack: [createChart],
      hasWrapped: false,
      hasLoaded: false,
      externalCSS: externalCSS,
      versions: [injectVersion],
      types: ['chart'],
      allScripts: {},
      projectUUIDs: {'6bn5rTBlo': 1},
    };

    loadInitialScript();

  } else {
    if (window.HighchartsCloud.externalCSS) window.HighchartsCloud.externalCSS.push(externalCSS);
    if (!window.HighchartsCloud.hasLoaded) {
      if (!window.HighchartsCloud.projectUUIDs) window.HighchartsCloud.projectUUIDs = {};

      if (!window.HighchartsCloud.projectUUIDs['6bn5rTBlo']) {

        window.HighchartsCloud.projectUUIDs['6bn5rTBlo'] = 1;
        window.HighchartsCloud.ondone.push(loadExtraScriptsAndMakeChart);
        if (window.HighchartsCloud.stack) {
          window.HighchartsCloud.stack.push(loadExtraScriptsAndMakeChart);
          window.HighchartsCloud.versions.push(injectVersion);
          window.HighchartsCloud.types.push('chart');
        }

      }
      if (window['require'] && typeof require === "function" && typeof require.specified === "function") {
        getAllScripts()
        loadRequireJSScript();
      }
    }
    else {
      if (window['require'] && typeof require === "function" && typeof require.specified === "function") {
        loadRequireJSScript();
      } else {
        getAllScripts()
        loadExtraScriptsAndMakeChart();
      }
    }
  }

}());
