// ==UserScript== // @author Zaso // @name Free Sidebar // @category Controls // @version 0.0.5.20240307.074938 // @description Reduces use of sidebar. // @id free-sidebar@Zaso // @namespace https://github.com/IITC-CE/ingress-intel-total-conversion // @updateURL https://raw.githubusercontent.com/IITC-CE/Community-plugins/master/dist/Zaso/free-sidebar.meta.js // @downloadURL https://raw.githubusercontent.com/IITC-CE/Community-plugins/master/dist/Zaso/free-sidebar.user.js // @match https://intel.ingress.com/* // @match https://intel-x.ingress.com/* // @grant none // ==/UserScript== 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 = 'ZasoItems'; plugin_info.dateTimeVersion = '2024-03-07-074938'; plugin_info.pluginId = 'free-sidebar'; //END PLUGIN AUTHORS NOTE // PLUGIN START //////////////////////////////////////////////////////// // History // 0.0.5 add compatibility with IITC-CE V0.38+ // 0.0.4 Headers changed. Ready for IITC-CE // 0.0.3 Original sript window.plugin.freeSidebar = {}; window.plugin.freeSidebar.createControlToolbox = function(){ L.Control.FreeToolbox = L.Control.extend({ options: { collapsed: true, position: 'topright', autoZIndex: true }, initialize: function(options){ L.setOptions(this, options); this._lastZIndex = 0; this._handlingClick = false; }, onAdd: function(){ this._initLayout(); this._update(); return this._container; }, onRemove: function(){}, _initLayout: function(){ var className = 'leaflet-control-toolbox', container = this._container = L.DomUtil.create('div', className); //Makes this work on IE10 Touch devices by stopping it from firing a mouseout event when the touch is released container.setAttribute('aria-haspopup', true); if(!L.Browser.touch){ L.DomEvent .disableClickPropagation(container) .disableScrollPropagation(container); } else{ L.DomEvent.on(container, 'click', L.DomEvent.stopPropagation); } var divContainer = this._divContainer = L.DomUtil.create('div', className + '-list list-group'); if(this.options.collapsed){ if(!L.Browser.android){ L.DomEvent .on(container, 'mouseover', this._expand, this) .on(container, 'mouseout', this._collapse, this); } var link = this._layersLink = L.DomUtil.create('a', className + '-toggle', container); link.href = '#'; link.title = 'Toolbox'; if(L.Browser.touch){ L.DomEvent .on(link, 'click', L.DomEvent.stop) .on(link, 'click', this._expand, this); } else{ L.DomEvent.on(link, 'focus', this._expand, this); } //Work around for Firefox android issue https://github.com/Leaflet/Leaflet/issues/2033 L.DomEvent.on(divContainer, 'click', function(){ setTimeout(L.bind(this._onInputClick, this), 0); }, this); this._map.on('click', this._collapse, this); // TODO keyboard accessibility } else{ this._expand(); } container.appendChild(divContainer); }, _update: function(){}, _onInputClick: function(){ var input, inputs = this._divContainer.getElementsByTagName('input'), inputsLen = inputs.length; this._handlingClick = true; this._handlingClick = false; this._refocusOnMap(); }, _expand: function(){ L.DomUtil.addClass(this._container, 'leaflet-control-toolbox-expanded'); }, _collapse: function(){ this._container.className = this._container.className.replace(' leaflet-control-toolbox-expanded', ''); } }); L.control.freeToolbox = function(options){ return new L.Control.FreeToolbox(options); }; } window.plugin.freeSidebar.appendToolbox = function(){ var t = $('#'+window.plugin.freeSidebar.toolBoxId).detach(); t.appendTo('.leaflet-control-toolbox .leaflet-control-toolbox-list'); } window.plugin.freeSidebar.initToolbox = function(){ window.plugin.freeSidebar.createControlToolbox(); map.addControl(new L.control.freeToolbox()); window.plugin.freeSidebar.appendToolbox(); } window.plugin.freeSidebar.removeRedeemFromSidebar = function(){ $('#redeem').remove(); }; window.plugin.freeSidebar.appendRedeemToToolbox = function(){ $(window.plugin.freeSidebar.toolBoxId).append('Redeem'); } window.plugin.freeSidebar.openRedeemDialog = function(){ var html = ''; dialog({ html: html, dialogClass: 'ui-dialog-redeem-input', title: 'Redeem Passcode', }); window.setupRedeem(); } window.plugin.freeSidebar.initRedeem = function(){ window.plugin.freeSidebar.removeRedeemFromSidebar(); window.plugin.freeSidebar.appendRedeemToToolbox(); } window.plugin.freeSidebar.setupCSS = function(){ var baseIcon = ''; $('