// ==UserScript==
// @id             iitc-plugin-scaling@jamokoo
// @name           IITC plugin: scaling
// @category       Controls
// @version        0.2
// @namespace      https://github.com/jonatkins/ingress-intel-total-conversion
// @author         jamokoo
// @downloadURL    https://jaumon.000webhostapp.com/iitc/scaling.user.js
// @updateURL      https://jaumon.000webhostapp.com/iitc/scaling.user.js
// @description    [iitc-0.2] adds scaling to iitc. view can be scaled smaller than default. Restart of iitc recommended after changing scale.
// @include        https://*.ingress.com/intel*
// @include        http://*.ingress.com/intel*
// @match          https://*.ingress.com/intel*
// @match          http://*.ingress.com/intel*
// @grant          none
// @require        file://g:\projects\git\iitc\scaling.user.js
// ==/UserScript==

/*
ChangeLog:
0.2   Added scaling button to left of map.
      Added big buttons to settings dialog to use if scaled too small.
0.1   Initial Version.
 */

function wrapper(plugin_info) {
// ensure plugin framework is there, even if iitc is not yet loaded
  if(typeof window.plugin !== 'function') window.plugin = function() {};

//PLUGIN AUTHORS: writing a plugin outside of the IITC build environment? if so, delete these lines!!
//(leaving them in place might break the 'About IITC' page or break update checks)
  plugin_info.buildName = 'release';
  plugin_info.dateTimeVersion = '2020-05-26-1';
  plugin_info.pluginId = 'scaleMod';
//END PLUGIN AUTHORS NOTE

  // use own namespace for plugin
  window.plugin.scaling = function() {};
  let thisPlugin = window.plugin.scaling;

  var setup = function() {
    thisPlugin.addScalingButton();

    const toolbox = document.getElementById('toolbox');

    const scalingOptions = document.createElement('a');
    scalingOptions.textContent = 'Scaling';
    scalingOptions.title = 'Scaling Options';
    scalingOptions.addEventListener('click', thisPlugin.showSettings);
    toolbox.appendChild(scalingOptions);

    if(localStorage.getItem('plugin-scaling') !== null) {
      let newValue = localStorage.getItem('plugin-scaling');

      let floatValue = parseFloat(newValue);
      if(floatValue < 0.4 || floatValue > 1) {
        //Do not allow invalid values
        newValue = '1.0';
        localStorage.setItem('plugin-scaling', newValue);
      }

      let newContent = "width=device-width, initial-scale=" + newValue + ", user-scalable=no";

      if($('meta').length == 0) {
        let meta = document.createElement('meta');
        meta.name = "viewport";
        meta.content = newContent;
        $('head').append(meta);
      } else {
        $('meta').attr("content", newContent);
      }
    }

  };

  thisPlugin.addScalingButton = function() {
    thisPlugin.locateButton = L.control({position: 'topleft'});
    thisPlugin.locateButton.onAdd = function (map) {
      var container = L.DomUtil.create('div', 'leaflet-scaling-button');
      $(container).append('<div class="leaflet-bar"><a href="javascript: void(0);" class="viewer-button"></a></div>');
      L.DomEvent.disableClickPropagation(container);
      $(container).on('click', function() {
        thisPlugin.showSettings();

      });

      return container;
    };

    thisPlugin.locateButton.addTo(map);

    cssData =
      ".leaflet-scaling-button a.viewer-button {\
        background-image: url(''); \
      };";
    $('<style>') .prop('type', 'text/css') .html(cssData).appendTo('head');
  };

  thisPlugin.showSettings = function () {
    let div = document.createElement('div');
    div.style.textAlign = "center";
    div.style.lineHeight = '200%';

    let sliderValue = document.createElement('div');
    sliderValue.id = 'sliderValue';
    sliderValue.style.fontSize = '20px';

    let currentSliderValue = '1.0';

    if(localStorage.getItem('plugin-scaling') !== null) {
      currentSliderValue = localStorage.getItem('plugin-scaling');
      console.log("read value " + currentSliderValue);
    }

    let decreaseButton = document.createElement('button');
    decreaseButton.innerHTML = "-";
    decreaseButton.style.padding = "15px 32px";
    decreaseButton.style.margin = "0px 8px";
    decreaseButton.style.fontSize = "40px";
    decreaseButton.onclick = function() {
      let slider = document.getElementById('scalingSlider');
      slider.stepDown();
      $('#sliderValue').text(parseFloat(slider.value).toFixed(1));
    };

    let increaseButton = document.createElement('button');
    increaseButton.innerHTML = "+";
    increaseButton.style.padding = "15px 32px";
    increaseButton.style.margin = "0px 8px";
    increaseButton.style.fontSize = "40px";
    increaseButton.onclick = function() {
      let slider = document.getElementById('scalingSlider');
      slider.stepUp();
      $('#sliderValue').text(parseFloat(slider.value).toFixed(1));
    };

    let input = document.createElement('input');
    input.type = 'range';
    input.min = '0.4';
    input.max = '1.0';
    input.step = '0.1';
    input.value = currentSliderValue;
    input.class = 'scalingSlider';
    input.id = 'scalingSlider';

    input.oninput = function() {
      $('#sliderValue').text(parseFloat(this.value).toFixed(1));
    };

    sliderValue.innerText = parseFloat(input.value).toFixed(1);

    let table = document.createElement('table');
    table.style.width = '100%';

    let firstRow = document.createElement('tr');
    let cell = document.createElement('td');
    cell.style.width = '25px';

    let scalingText = document.createElement('div');
    scalingText.innerText = "Scaling";
    scalingText.style.fontSize = '20px';

    cell.appendChild(scalingText);
    firstRow.appendChild(cell);

    cell = document.createElement('td');
    cell.style.width = '50px';

    cell.appendChild(input);

    firstRow.appendChild(cell);

    cell = document.createElement('td');
    cell.style.width = '20px';

    cell.appendChild(sliderValue);

    firstRow.appendChild(cell);

    table.appendChild(firstRow);

    let secondRow = document.createElement('tr');

    cell = document.createElement('td');
    cell.colSpan = 3;

    cell.appendChild(decreaseButton);
    cell.appendChild(increaseButton);

    secondRow.appendChild(cell);
    table.appendChild(secondRow);


    div.appendChild(table);

    dialog({
      id: 'plugin-scaling',
      html: div,
      buttons: [
        {
          text: 'Cancel',
          click: function () {
            $(this).dialog("close");
          },
          style: "margin-right:5px; padding: 16px 16px; font-size: 32px"
        },
        {
          text: 'OK',
          id: 'okok',
          click: function () {
            let readValue = $('#scalingSlider').val();
            console.log("Read value for saving " + readValue);
            localStorage.setItem('plugin-scaling', readValue);
            let newValue = "width=device-width, initial-scale=" + readValue + ", user-scalable=no";

            if($('meta').length == 0) {
              let meta = document.createElement('meta');
              meta.name = "viewport";
              meta.content = newValue;
              $('head').append(meta);
            } else {
              $('meta').attr("content", newValue);
            }

            $(this).dialog("close");
          },
          style: "margin-left:5px; padding: 16px 16px; font-size: 32px"
        }
        ,
        {
          text: 'OK',
          id: 'okid',
          click: function () {
            $(this).dialog("close");
          }
        }
      ],
      title: 'Scaling Settings',
    });

    $("#okid").hide();
    $(".ui-dialog-titlebar").hide();
  };

  setup.info = plugin_info; //add the script info data to the function as a property
  setup.priority = 'low';
  if(!window.bootPlugins) window.bootPlugins = [];
  window.bootPlugins.push(setup);
// if IITC has already booted, immediately run the 'setup' function
  if(window.iitcLoaded && typeof setup === 'function') setup();
} // wrapper end
// inject code into site context
var script = document.createElement('script');
var info = {};
if (typeof GM_info !== 'undefined' && GM_info && GM_info.script) info.script = { version: GM_info.script.version, name: GM_info.script.name, description: GM_info.script.description };
script.appendChild(document.createTextNode('('+ wrapper +')('+JSON.stringify(info)+');'));
(document.body || document.head || document.documentElement).appendChild(script);

