(function () {
  //Inject code v4.0

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

  var cdn = 'https://code.highcharts.com/';
  var loaded = 0;  
  var encodedUrl = encodeURI('https://https://app.everviz.com//show/ctLUOlSK5');
  var chartCreated = 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"
  ];

  var externalCSS = [
    "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/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":"column","inverted":true,"polar":false,"height":941},"plotOptions":{"series":{"stacking":"normal","animation":false}},"title":{"text":"Preventable-injury-related death rates by state of residence, 2019"},"series":[{"data":[],"turboThreshold":0,"_colorIndex":0,"_symbolIndex":0},{"data":[],"turboThreshold":0,"_colorIndex":1,"_symbolIndex":0,"type":"column"},{"data":[],"turboThreshold":0,"_colorIndex":2,"_symbolIndex":0,"type":"column"},{"data":[],"turboThreshold":0,"_colorIndex":3,"_symbolIndex":0,"type":"column"},{"data":[],"turboThreshold":0,"_colorIndex":4,"_symbolIndex":0,"type":"column"}],"legend":{"reversed":true},"pane":{"background":[]},"responsive":{"rules":[]},"subtitle":{"text":""},"credits":{"text":"© 2021 National Safety Council - All Rights Reserved.","href":""},"lang":{"thousandsSep":","},"annotations":[],"yAxis":{"title":{"text":"Deaths per 100,000 population"}},"data":{"csv":"null;All other;Choking;MV;Falls;Poisoning\nNew York;5.9;1;5.8;9;17.3\nCalifornia;5.6;0.8;10.2;7.3;15.2\nTexas;8.1;1.3;13.3;7.5;10.4\nMaryland;7.3;1.6;9.2;12.7;10.9\nUtah;6.7;1.2;7.7;10.8;15.4\nGeorgia;8.4;1.7;14.5;7.6;12.5\nNebraska;10.5;2.1;13.6;12.6;7.3\nHawaii;10.4;3;8.5;11.8;15.3\nNevada;7.9;0.8;9.9;10.7;18.2\nVirginia;7.7;1.9;10.5;11.3;17.3\nWashington;8.8;1.8;8.3;14.5;15.3\nIllinois;8;1.7;9.1;9.8;21.2\nIowa;10.6;2.1;11.6;16.4;10.1\nNorth Dakota;13.8;2.6;13.4;10.5;11\nArkansas;12.6;1.9;18.4;7.6;12\nMinnesota;8.1;1.3;8;21.7;12.9\nKansas;10.8;2.1;13.9;14.7;12.9\nNew Jersey;7.6;1.8;6.7;6.8;31.3\nOregon;8.5;1.5;12.7;18.4;12.9\nTotal United States;8.8;1.6;11.9;12;20\nIdaho;10;2.2;14.3;15.1;13.6\nColorado;9.9;1.4;11.1;15.4;17.2\nMichigan;9.6;1.6;10.7;13.1;20.9\nAlabama;14.5;1.9;20.6;6;15.1\nIndiana;12.5;2;13;8;24.1\nSouth Dakota;10.4;;15.1;23.2;9.7\nMassachusetts;7.5;2.5;5.7;14.5;31.1\nNorth Carolina;8.8;1.6;15.3;14.3;20.6\nAlaska;17.5;;12.7;8.7;20.4\nMontana;13.8;2.9;18.1;18.2;11.4\nConnecticut;8.5;3.3;7.5;12.4;33.2\nOklahoma;10.9;1;17.4;17.9;15.4\nDistrict of Columbia;6.2;;6.2;7.1;42.4\nFlorida;7.8;1.5;15.4;15.7;23.2\nArizona;9;1.1;13.4;15.3;24.9\nLouisiana;14.2;2.4;16.4;7;25.1\nRhode Island;9.2;2.8;7;18.5;28.5\nNew Hampshire;8.5;1.5;7.9;18.5;28.6\nMississippi;14.2;2.8;25.2;11;13.2\nMissouri;11.7;2;15.7;12.8;24.2\nSouth Carolina;12;2.3;19.7;11.9;21.2\nVermont;9.9;;9.1;26.3;19.6\nWyoming;15.6;;19.4;17.3;14\nPennsylvania;9.2;2.4;8.8;15.8;33.3\nKentucky;13.4;1.8;17.1;9.4;30\nWisconsin;8.7;1.5;10.6;31.3;19.6\nOhio;9.9;1.7;11;14.6;35.4\nTennessee;12;2;17.3;12.2;29.6\nDelaware;8.1;;13.7;9.9;43.1\nMaine;9.1;;12.7;27.5;27.1\nNew Mexico;11.2;1.7;19.1;19.1;31.1\nWest Virginia;12.7;2.6;18.4;25.2;47.4","seriesMapping":[{"x":0,"y":1},{"x":0,"y":2},{"x":0,"y":3},{"x":0,"y":4},{"x":0,"y":5}]},"stockTools":{"gui":{"enabled":false}}};
  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')) {
          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 = function(options) {
        const keys = Object.keys(templateDataSettings || {});
        keys.forEach(function(key) {
          const serie = options.series[key];
          (serie.data || []).forEach(function(d, i) {
            if (templateDataSettings[key].data && templateDataSettings[key].data[i]) {
              window["everviz"].merge(d, templateDataSettings[key].data[i]);
            }
          })
        })  
        return options;
      }
    }
    
    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 (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];

    /*
// Sample of extending options:
Highcharts.merge(true, options, {
    chart: {
        backgroundColor: "#bada55"
    },
    plotOptions: {
        series: {
            cursor: "pointer",
            events: {
                click: function(event) {
                    alert(this.name + " clicked\n" +
                          "Alt: " + event.altKey + "\n" +
                          "Control: " + event.ctrlKey + "\n" +
                          "Shift: " + event.shiftKey + "\n");
                }
            }
        }
    }
});
*/


      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) {

          var chart = new Highcharts.Chart('highcharts-ctLUOlSK5', optionsStub); 
          window["everviz"].pendingAnim({
            id: 'highcharts-ctLUOlSK5', 
            loaded: false,
            options: options,
            appear:function(){
              chart.destroy();
              chart = new Highcharts.Chart('highcharts-ctLUOlSK5', options); 
            },
            element: document.querySelector('#highcharts-ctLUOlSK5')
          });
        } else {
          new Highcharts.Chart('highcharts-ctLUOlSK5', 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);
            }
          }
        }


/*
        for (var i = 0; i < window.HighchartsCloud.ondone.length; i++) {
          try {
            window.HighchartsCloud.ondone[i]();
          } catch(e) {
            console.error(e);
          }
        }*/



      }
    }
  }

  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('https') >= 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 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 return script;
      })
    );

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

    return allScripts;
  }

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

    const allScripts = getAllScripts();

    require(
      allScripts,
      function (Highcharts) {
        //Attach highcharts to the window for use in the everviz scripts
        window.Highcharts = Highcharts;
        createChart();
    });
  }

  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: [4],
      types: ['chart'],
      allScripts: {}
    };

    loadInitialScript();

  } else {
    if (window.HighchartsCloud.externalCSS) window.HighchartsCloud.externalCSS.push(externalCSS);
    if (!window.HighchartsCloud.hasLoaded) {
      window.HighchartsCloud.ondone.push(loadExtraScriptsAndMakeChart);
      if (window.HighchartsCloud.stack) {
        window.HighchartsCloud.stack.push(loadExtraScriptsAndMakeChart);
        window.HighchartsCloud.versions.push(4);
        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();
      }
    }
  }

}());
