MediaWiki:Script/Filter.js : Différence entre versions

 
Ligne 2 : Ligne 2 :
 
   element.classList.add("tabber-noactive");
 
   element.classList.add("tabber-noactive");
 
}
 
}
 
  
 
function showElement(element) {
 
function showElement(element) {
 
   element.classList.remove("tabber-noactive");
 
   element.classList.remove("tabber-noactive");
 
}
 
}
 
  
 
function removeAccent(str) {
 
function removeAccent(str) {
   return str.normalize("NFD").replace(/[\u0300-\u036f]/g, "").toLowerCase()
+
   return str
 +
    .normalize("NFD")
 +
    .replace(/[\u0300-\u036f]/g, "")
 +
    .toLowerCase();
 
}
 
}
 
  
 
function toNormalForm(str) {
 
function toNormalForm(str) {
    return removeAccent(str).replace(/[^a-zA-Z0-9 ]/g, "");;
+
  return removeAccent(str).replace(/[^a-zA-Z0-9 ]/g, "");
 
}
 
}
 
  
 
function addValueToObject(object, key, value) {
 
function addValueToObject(object, key, value) {
         
 
 
   if (object[key]) {
 
   if (object[key]) {
 
     object[key].push(value);
 
     object[key].push(value);
Ligne 27 : Ligne 25 :
 
   }
 
   }
 
}
 
}
 
  
 
function loading() {
 
function loading() {
 
 
 
   var mainContainer = document.getElementById("hide-all");
 
   var mainContainer = document.getElementById("hide-all");
 
   var loadingAnimation = document.getElementById("loading-animation");
 
   var loadingAnimation = document.getElementById("loading-animation");
Ligne 37 : Ligne 33 :
 
   loadingAnimation.classList.add("tabber-noactive");
 
   loadingAnimation.classList.add("tabber-noactive");
 
}
 
}
 
  
 
function handleDropdowns(filterInformation) {
 
function handleDropdowns(filterInformation) {
 
 
 
   var form = filterInformation.form;
 
   var form = filterInformation.form;
 
   var activeButton = null;
 
   var activeButton = null;
Ligne 57 : Ligne 51 :
 
   }
 
   }
  
 
 
 
   function closeDropdowns() {
 
   function closeDropdowns() {
 
     if (activeButton) {
 
     if (activeButton) {
Ligne 65 : Ligne 58 :
 
   }
 
   }
  
   form.addEventListener("click", function(event) {
+
   form.addEventListener("click", function (event) {
 +
    var target = event.target;
 +
    var button = target.closest("button");
  
    var target = event.target;
 
    var button = target.closest('button');
 
   
 
 
     if (button) {
 
     if (button) {
     
 
 
       var dropdownMenu = button.nextElementSibling;
 
       var dropdownMenu = button.nextElementSibling;
     
+
 
 
       toggleDropdown(button, dropdownMenu);
 
       toggleDropdown(button, dropdownMenu);
     
+
     } else if (!target.closest(".dropdown-menu")) {
     } else if (!target.closest('.dropdown-menu')) {
 
 
       closeDropdowns();
 
       closeDropdowns();
 
     }
 
     }
 
   });
 
   });
  
   document.addEventListener("mousedown", function(event) {
+
   document.addEventListener("mousedown", function (event) {
 
     if (!form.contains(event.target)) {
 
     if (!form.contains(event.target)) {
 
       closeDropdowns();
 
       closeDropdowns();
Ligne 87 : Ligne 77 :
 
   });
 
   });
 
}
 
}
 
  
 
function incrementCounter(counterElement, counterValue) {
 
function incrementCounter(counterElement, counterValue) {
 
 
   if (counterValue === 0) {
 
   if (counterValue === 0) {
 
     showElement(counterElement);
 
     showElement(counterElement);
Ligne 97 : Ligne 85 :
 
   counterElement.textContent = counterValue + 1;
 
   counterElement.textContent = counterValue + 1;
 
}
 
}
 
  
 
function decrementCounter(counterElement, counterValue) {
 
function decrementCounter(counterElement, counterValue) {
 
 
   if (counterValue === 1) {
 
   if (counterValue === 1) {
 
     hideElement(counterElement);
 
     hideElement(counterElement);
Ligne 107 : Ligne 93 :
 
   counterElement.textContent = counterValue - 1;
 
   counterElement.textContent = counterValue - 1;
 
}
 
}
 
  
 
function filterItems(filterInformation, cardInformation) {
 
function filterItems(filterInformation, cardInformation) {
 
 
 
 
 
   function showCounter() {
 
   function showCounter() {
     var checkbox = filterInformation.checkbox
+
     var checkbox = filterInformation.checkbox;
   
+
 
 
     for (var filterName in checkbox) {
 
     for (var filterName in checkbox) {
       var values = checkbox[filterName].values
+
       var values = checkbox[filterName].values;
     
+
 
 
       for (var filterValue in values) {
 
       for (var filterValue in values) {
 
         var span = values[filterValue].span;
 
         var span = values[filterValue].span;
       
+
 
 
         span.textContent = " (" + values[filterValue].value + ")";
 
         span.textContent = " (" + values[filterValue].value + ")";
 
         values[filterValue].value = 0;
 
         values[filterValue].value = 0;
Ligne 126 : Ligne 109 :
 
     }
 
     }
 
   }
 
   }
 
+
 
 
 
 
   function addCount(cardParameters, checkboxNames, parameter) {
 
   function addCount(cardParameters, checkboxNames, parameter) {
     cardParameters[parameter].split(' ').forEach(function(cardValue) {
+
     cardParameters[parameter].split(" ").forEach(function (cardValue) {
 
       checkboxNames[parameter].values[cardValue].value += 1;
 
       checkboxNames[parameter].values[cardValue].value += 1;
 
     });
 
     });
 
   }
 
   }
+
 
 
 
 
   function isObjectValuesInRangeFilter(parameters, rangeFilter) {
 
   function isObjectValuesInRangeFilter(parameters, rangeFilter) {
     return Object.keys(rangeFilter).every(function(property) {
+
     return Object.keys(rangeFilter).every(function (property) {
 
       var propertyValue = parameters[property];
 
       var propertyValue = parameters[property];
       return rangeFilter[property].min <= propertyValue && rangeFilter[property].max >= propertyValue;
+
       return (
 +
        rangeFilter[property].min <= propertyValue &&
 +
        rangeFilter[property].max >= propertyValue
 +
      );
 
     });
 
     });
 
   }
 
   }
 
+
 
 
 
 
   function filterByName(parameters, filterName) {
 
   function filterByName(parameters, filterName) {
 
     if (filterName) {
 
     if (filterName) {
Ligne 149 : Ligne 132 :
 
     return true;
 
     return true;
 
   }
 
   }
 
+
 
 
 
 
   function isObjectValuesInFilter(parameters, filter) {
 
   function isObjectValuesInFilter(parameters, filter) {
     return Object.keys(filter).every(function(property) {
+
     return Object.keys(filter).every(function (property) {
       return parameters[property].split(' ').some(function(value) {
+
       return parameters[property].split(" ").some(function (value) {
 
         return filter[property].indexOf(value) !== -1;
 
         return filter[property].indexOf(value) !== -1;
 
       });
 
       });
 
     });
 
     });
 
   }
 
   }
 
+
 
 
+
   function isObjectValuesInFilters(
   function isObjectValuesInFilters(parameters, filter, rangeFilter, filterName) {
+
    parameters,
     return isObjectValuesInFilter(parameters, filter) && filterByName(parameters, filterName) && isObjectValuesInRangeFilter(parameters, rangeFilter);
+
    filter,
 +
    rangeFilter,
 +
    filterName
 +
  ) {
 +
     return (
 +
      isObjectValuesInFilter(parameters, filter) &&
 +
      filterByName(parameters, filterName) &&
 +
      isObjectValuesInRangeFilter(parameters, rangeFilter)
 +
    );
 
   }
 
   }
 
+
 
 
   var filter = filterInformation.filters.filter;
 
   var filter = filterInformation.filters.filter;
 
   var rangeFilter = filterInformation.filters.rangeFilter;
 
   var rangeFilter = filterInformation.filters.rangeFilter;
Ligne 170 : Ligne 160 :
 
   var listToFilter = cardInformation.listToFilter.children;
 
   var listToFilter = cardInformation.listToFilter.children;
 
   var cardData = cardInformation.data;
 
   var cardData = cardInformation.data;
 
+
 
 
   if (filterInformation.reverse) {
 
   if (filterInformation.reverse) {
 
     var parent = cardInformation.listToFilter;
 
     var parent = cardInformation.listToFilter;
     for (var reverseIndex = 1; reverseIndex < listToFilter.length; reverseIndex++) {
+
     for (
 +
      var reverseIndex = 1;
 +
      reverseIndex < listToFilter.length;
 +
      reverseIndex++
 +
    ) {
 
       parent.insertBefore(listToFilter[reverseIndex], parent.firstChild);
 
       parent.insertBefore(listToFilter[reverseIndex], parent.firstChild);
 
     }
 
     }
Ligne 179 : Ligne 173 :
 
     filterInformation.reverse = false;
 
     filterInformation.reverse = false;
 
   }
 
   }
 
+
 
 
   for (var cardIndex = 0; cardIndex < listToFilter.length; cardIndex++) {
 
   for (var cardIndex = 0; cardIndex < listToFilter.length; cardIndex++) {
 
     var card = listToFilter[cardIndex];
 
     var card = listToFilter[cardIndex];
 
     var cardParameters = cardData[cardIndex];
 
     var cardParameters = cardData[cardIndex];
     if (isObjectValuesInFilters(cardParameters, filter, rangeFilter, filterName)) {
+
     if (
 +
      isObjectValuesInFilters(cardParameters, filter, rangeFilter, filterName)
 +
    ) {
 
       showElement(card);
 
       showElement(card);
 
       for (var parameter in checkboxNames) {
 
       for (var parameter in checkboxNames) {
Ligne 194 : Ligne 190 :
 
   showCounter();
 
   showCounter();
 
}
 
}
 
  
 
function updateFilterObject(filterInformation, cardInformation) {
 
function updateFilterObject(filterInformation, cardInformation) {
 
 
 
 
 
   function updateFilter(event, filterByName = false) {
 
   function updateFilter(event, filterByName = false) {
 
   
 
 
     function handleNumberType(target) {
 
     function handleNumberType(target) {
     
 
 
       var [filterName, extremum] = target.id.split("-");
 
       var [filterName, extremum] = target.id.split("-");
 
       var currentValue = Number(target.value);
 
       var currentValue = Number(target.value);
Ligne 210 : Ligne 200 :
 
       var initialRange = filterInformation.range[filterName].init;
 
       var initialRange = filterInformation.range[filterName].init;
 
       var rangeFilter = filterInformation.filters.rangeFilter;
 
       var rangeFilter = filterInformation.filters.rangeFilter;
     
+
 
 
       if (rangeFilter[filterName]) {
 
       if (rangeFilter[filterName]) {
 
         rangeFilter[filterName][extremum] = currentValue;
 
         rangeFilter[filterName][extremum] = currentValue;
 
       } else {
 
       } else {
 
         incrementCounter(counterElement, counterValue);
 
         incrementCounter(counterElement, counterValue);
         rangeFilter[filterName] = {min: initialRange.min, max: initialRange.max};
+
         rangeFilter[filterName] = {
 +
          min: initialRange.min,
 +
          max: initialRange.max,
 +
        };
 
         rangeFilter[filterName][extremum] = currentValue;
 
         rangeFilter[filterName][extremum] = currentValue;
 
       }
 
       }
       if ((rangeFilter[filterName].max === initialRange.max) && (rangeFilter[filterName].min === initialRange.min)) {
+
       if (
 +
        rangeFilter[filterName].max === initialRange.max &&
 +
        rangeFilter[filterName].min === initialRange.min
 +
      ) {
 
         decrementCounter(counterElement, counterValue);
 
         decrementCounter(counterElement, counterValue);
 
         delete rangeFilter[filterName];
 
         delete rangeFilter[filterName];
 
       }
 
       }
 
     }
 
     }
   
+
 
   
 
 
     function handleCheckbox(target) {
 
     function handleCheckbox(target) {
     
 
 
       var filterName = target.id.split("-")[0];
 
       var filterName = target.id.split("-")[0];
 
       var filter = filterInformation.filters.filter;
 
       var filter = filterInformation.filters.filter;
Ligne 232 : Ligne 226 :
 
       var counterElement = filterInformation.checkbox[filterName].counter;
 
       var counterElement = filterInformation.checkbox[filterName].counter;
 
       var counterValue = Number(counterElement.textContent);
 
       var counterValue = Number(counterElement.textContent);
     
+
 
 
       if (target.checked) {
 
       if (target.checked) {
 
         incrementCounter(counterElement, counterValue);
 
         incrementCounter(counterElement, counterValue);
 
         addValueToObject(filter, filterName, filterValue);
 
         addValueToObject(filter, filterName, filterValue);
       
 
 
       } else {
 
       } else {
 
         decrementCounter(counterElement, counterValue);
 
         decrementCounter(counterElement, counterValue);
Ligne 249 : Ligne 242 :
 
       }
 
       }
 
     }
 
     }
   
+
 
 
     var target = event.target;
 
     var target = event.target;
   
+
 
 
     if (filterByName) {
 
     if (filterByName) {
 
       filterInformation.filters.filterName = toNormalForm(target.value);
 
       filterInformation.filters.filterName = toNormalForm(target.value);
 
     } else {
 
     } else {
 
       var type = target.type;
 
       var type = target.type;
     
+
 
 
       if (type === "number") {
 
       if (type === "number") {
 
         handleNumberType(target);
 
         handleNumberType(target);
Ligne 269 : Ligne 262 :
 
     filterItems(filterInformation, cardInformation);
 
     filterItems(filterInformation, cardInformation);
 
   }
 
   }
 
+
 
 
   var form = filterInformation.form;
 
   var form = filterInformation.form;
 
   var debounceTimer;
 
   var debounceTimer;
 
+
 
   form.addEventListener("submit", function(event) {
+
   form.addEventListener("submit", function (event) {
 
     event.preventDefault();
 
     event.preventDefault();
 
   });
 
   });
 
+
 
   form.addEventListener("change", function(event) {
+
   form.addEventListener("change", function (event) {
 
     updateFilter(event);
 
     updateFilter(event);
 
   });
 
   });
 
+
 
   form.addEventListener("input", function(event) {
+
   form.addEventListener("input", function (event) {
 
     if (event.target.id === "filter-name") {
 
     if (event.target.id === "filter-name") {
 
       clearTimeout(debounceTimer);
 
       clearTimeout(debounceTimer);
       debounceTimer = setTimeout(function() {
+
       debounceTimer = setTimeout(function () {
 
         updateFilter(event, true);
 
         updateFilter(event, true);
 
       }, 500);
 
       }, 500);
Ligne 290 : Ligne 283 :
 
   });
 
   });
 
}
 
}
 
  
 
function filterInitialization() {
 
function filterInitialization() {
 
 
 
   function createSpan() {
 
   function createSpan() {
 
     var span = document.createElement("span");
 
     var span = document.createElement("span");
     span.style.color = '#9F9F9F';
+
     span.style.color = "#9F9F9F";
     span.style.fontSize = '12px';
+
     span.style.fontSize = "12px";
 
     return span;
 
     return span;
 
   }
 
   }
 
+
 
 
 
 
   function handlefilterParameters(filterParameters, param, filterName) {
 
   function handlefilterParameters(filterParameters, param, filterName) {
   
 
 
     if (param === "levels") {
 
     if (param === "levels") {
       addValueToObject(filterParameters, "levels", filterName)
+
       addValueToObject(filterParameters, "levels", filterName);
     
 
 
     } else if (param.startsWith("replace_")) {
 
     } else if (param.startsWith("replace_")) {
     
 
 
       var replace = param.split("replace_")[1].replace("_", " ");
 
       var replace = param.split("replace_")[1].replace("_", " ");
     
+
 
 
       if (!filterParameters["replace"]) {
 
       if (!filterParameters["replace"]) {
 
         filterParameters["replace"] = {};
 
         filterParameters["replace"] = {};
 
       }
 
       }
       filterParameters["replace"][filterName] = {"value": replace};
+
       filterParameters["replace"][filterName] = { value: replace };
     
 
 
     } else if (param === "elem") {
 
     } else if (param === "elem") {
 
       filterParameters["elem"] = filterName;
 
       filterParameters["elem"] = filterName;
 
     }
 
     }
 
   }
 
   }
 
+
 
 
   var form = document.getElementById("filter-form");
 
   var form = document.getElementById("filter-form");
 
   var filters = { filterName: "", filter: {}, rangeFilter: {} };
 
   var filters = { filterName: "", filter: {}, rangeFilter: {} };
   var filterInformation = { form: form, filters: filters, range: {}, checkbox: {}, reverse: false };
+
   var filterInformation = {
 +
    form: form,
 +
    filters: filters,
 +
    range: {},
 +
    checkbox: {},
 +
    reverse: false,
 +
  };
 
   var allButton = form.querySelectorAll("button");
 
   var allButton = form.querySelectorAll("button");
 
   var filterParameters = {};
 
   var filterParameters = {};
  
   allButton.forEach(function(button) {
+
   allButton.forEach(function (button) {
   
 
 
     var buttonSibling = button.nextElementSibling;
 
     var buttonSibling = button.nextElementSibling;
   
+
 
 
     if (!buttonSibling) return;
 
     if (!buttonSibling) return;
   
+
 
 
     var filterName = buttonSibling.id;
 
     var filterName = buttonSibling.id;
 
     var counter = buttonSibling.nextElementSibling;
 
     var counter = buttonSibling.nextElementSibling;
 
     var param = buttonSibling.dataset.param;
 
     var param = buttonSibling.dataset.param;
   
+
 
 
     if (!filterName || !counter || !param) return;
 
     if (!filterName || !counter || !param) return;
  
 
     var infoType = filterName.endsWith("-range") ? "range" : "checkbox";
 
     var infoType = filterName.endsWith("-range") ? "range" : "checkbox";
     var filterName = filterName.replace("-range", "")
+
     var filterName = filterName.replace("-range", "");
     var filterObj = filterInformation[infoType][filterName] = { counter: counter };
+
     var filterObj = (filterInformation[infoType][filterName] = {
   
+
      counter: counter,
 +
    });
 +
 
 
     handlefilterParameters(filterParameters, param, filterName);
 
     handlefilterParameters(filterParameters, param, filterName);
   
+
 
 
     if (infoType === "checkbox") {
 
     if (infoType === "checkbox") {
 
       filterObj.values = {};
 
       filterObj.values = {};
 
       var allInput = buttonSibling.querySelectorAll("input");
 
       var allInput = buttonSibling.querySelectorAll("input");
       allInput.forEach(function(input) {
+
       allInput.forEach(function (input) {
 
         var filterValue = input.dataset.filter;
 
         var filterValue = input.dataset.filter;
       
+
 
 
         if (!filterValue) return;
 
         if (!filterValue) return;
  
 
         var span = createSpan();
 
         var span = createSpan();
 
         input.parentElement.appendChild(span);
 
         input.parentElement.appendChild(span);
         filterObj.values[filterValue] = { value: 0, span: span};
+
         filterObj.values[filterValue] = { value: 0, span: span };
 
       });
 
       });
 
     } else if (infoType === "range") {
 
     } else if (infoType === "range") {
       filterObj.init = {}
+
       filterObj.init = {};
 
       filterObj.init.min = Number(buttonSibling.children[0].firstChild.min);
 
       filterObj.init.min = Number(buttonSibling.children[0].firstChild.min);
 
       filterObj.init.max = Number(buttonSibling.children[0].firstChild.max);
 
       filterObj.init.max = Number(buttonSibling.children[0].firstChild.max);
Ligne 366 : Ligne 359 :
 
   return [filterInformation, filterParameters];
 
   return [filterInformation, filterParameters];
 
}
 
}
 
  
 
function getCardInformation(filterParameters) {
 
function getCardInformation(filterParameters) {
 
 
 
   function createDataSelector(name) {
 
   function createDataSelector(name) {
     return "[data-" + name + "]"
+
     return "[data-" + name + "]";
 
   }
 
   }
 
+
 
 
   var listToFilter = document.getElementById("list-to-filter");
 
   var listToFilter = document.getElementById("list-to-filter");
 
   var listToFilterChildren = listToFilter.children;
 
   var listToFilterChildren = listToFilter.children;
Ligne 380 : Ligne 371 :
 
   var filterWithReplace = filterParameters["replace"];
 
   var filterWithReplace = filterParameters["replace"];
 
   var filterElementName = filterParameters["elem"];
 
   var filterElementName = filterParameters["elem"];
 
+
 
 
   if (filterLevelsNames) {
 
   if (filterLevelsNames) {
 
     var [level0, level1] = filterLevelsNames;
 
     var [level0, level1] = filterLevelsNames;
 
     var levelsSelector = createDataSelector(level0);
 
     var levelsSelector = createDataSelector(level0);
 
   }
 
   }
 
+
 
 
   if (filterWithReplace) {
 
   if (filterWithReplace) {
 
     for (var replaceName in filterWithReplace) {
 
     for (var replaceName in filterWithReplace) {
Ligne 391 : Ligne 382 :
 
     }
 
     }
 
   }
 
   }
 
+
 
 
   if (filterElementName) {
 
   if (filterElementName) {
 
     var elementSelector = createDataSelector(filterElementName);
 
     var elementSelector = createDataSelector(filterElementName);
 
   }
 
   }
  
   for (var cardIndex = 0; cardIndex < listToFilterChildren.length; cardIndex++) {
+
   for (
   
+
    var cardIndex = 0;
 +
    cardIndex < listToFilterChildren.length;
 +
    cardIndex++
 +
  ) {
 
     var card = listToFilterChildren[cardIndex];
 
     var card = listToFilterChildren[cardIndex];
 
     var cardInformation = {};
 
     var cardInformation = {};
     var cardName = card.querySelector("[data-name]").textContent;
+
     var cardNameElement = card.querySelector("[data-name]");
     cardInformation.name = toNormalForm(cardName);
+
     cardInformation.name = toNormalForm(cardNameElement.textContent);
      
+
     cardInformation.trueName = cardNameElement.firstChild.title;
 +
 
 
     if (filterLevelsNames) {
 
     if (filterLevelsNames) {
 
       var levelsElement = card.querySelector(levelsSelector);
 
       var levelsElement = card.querySelector(levelsSelector);
       var [levelValue0, levelValue1] = levelsElement.textContent.slice(1, -1).split(", ");
+
       var [levelValue0, levelValue1] = levelsElement.textContent
 +
        .slice(1, -1)
 +
        .split(", ");
 
       cardInformation[level0] = Number(levelValue0);
 
       cardInformation[level0] = Number(levelValue0);
 
       cardInformation[level1] = removeAccent(levelValue1);
 
       cardInformation[level1] = removeAccent(levelValue1);
 
     }
 
     }
   
+
 
 
     if (filterElementName) {
 
     if (filterElementName) {
 
       var elementChild = card.querySelector(elementSelector).children;
 
       var elementChild = card.querySelector(elementSelector).children;
 
       var elementValue = "";
 
       var elementValue = "";
 
       if (elementChild.length) {
 
       if (elementChild.length) {
         for (var elementIndex = 0; elementIndex < elementChild.length; elementIndex++) {
+
         for (
 +
          var elementIndex = 0;
 +
          elementIndex < elementChild.length;
 +
          elementIndex++
 +
        ) {
 
           elementValue += elementChild[elementIndex].title + " ";
 
           elementValue += elementChild[elementIndex].title + " ";
 
         }
 
         }
Ligne 421 : Ligne 422 :
 
       cardInformation[filterElementName] = removeAccent(elementValue);
 
       cardInformation[filterElementName] = removeAccent(elementValue);
 
     }
 
     }
     
+
 
 
     if (filterWithReplace) {
 
     if (filterWithReplace) {
 
       for (var replaceName in filterWithReplace) {
 
       for (var replaceName in filterWithReplace) {
 
         var replaceInformation = filterWithReplace[replaceName];
 
         var replaceInformation = filterWithReplace[replaceName];
         var replaceValue = card.querySelector(replaceInformation.selector).textContent.replace(replaceInformation.value, '');
+
         var replaceValue = card
         cardInformation[replaceName] = removeAccent(replaceValue)
+
          .querySelector(replaceInformation.selector)
 +
          .textContent.replace(replaceInformation.value, "");
 +
         cardInformation[replaceName] = removeAccent(replaceValue);
 
       }
 
       }
 
     }
 
     }
     
+
 
 
     allCardInformation.push(cardInformation);
 
     allCardInformation.push(cardInformation);
 
   }
 
   }
 
   allCardInformation = { listToFilter: listToFilter, data: allCardInformation };
 
   allCardInformation = { listToFilter: listToFilter, data: allCardInformation };
 
+
 
 
   return allCardInformation;
 
   return allCardInformation;
 
}
 
}
  
 +
function editCardInformation(cardInformation) {
 +
  var listToFilterChildren = cardInformation.listToFilter.children;
 +
 +
  for (
 +
    var cardIndex = 0;
 +
    cardIndex < listToFilterChildren.length;
 +
    cardIndex++
 +
  ) {
 +
    var card = listToFilterChildren[cardIndex];
 +
    var cardName = card.querySelector("[data-name]").textContent;
 +
    cardInformation.data[cardIndex].name = toNormalForm(cardName);
 +
  }
 +
}
 +
 +
function observeLanguageChange(cardInformation) {
 +
  var filterName = document.getElementById("filter-name");
 +
 +
  if (!filterName) {
 +
    return;
 +
  }
 +
 +
  var observer = new MutationObserver(function (mutation) {
 +
    editCardInformation(cardInformation);
 +
  });
 +
 +
  observer.observe(filterName, { attributes: true });
 +
}
 +
 +
function getSavedMonsters() {
 +
  var savedMonsters = localStorage.getItem("savedMonstersCalculator");
 +
 +
  if (savedMonsters) {
 +
    return JSON.parse(savedMonsters);
 +
  }
 +
  return [];
 +
}
 +
 +
function writeMonster(monsterVnum) {
 +
  localStorage.setItem("newMonsterCalculator", monsterVnum);
 +
}
  
function filterWithUrl(filterInformation) {
+
function handleDamageSimulator(cardInformation) {
 
+
  var addMonster = document.getElementById("add-monster");
 +
  var cardToEdit = cardInformation.listToFilter.children;
 +
  var cardData = cardInformation.data;
 +
  var savedMonsters = getSavedMonsters();
 +
 
 +
  addMonster.removeAttribute("id");
 +
  addMonster = addMonster.parentElement;
 +
  addMonster.classList.remove("tabber-noactive");
 +
 
 +
  var nameToVnum = {};
 +
  var monsterParametersLength = monsterData[101].length;
 +
 
 +
  for (monsterVnum in monsterData) {
 +
    nameToVnum[monsterData[monsterVnum][monsterParametersLength - 1]] =
 +
      monsterVnum;
 +
  }
 +
 
 +
  for (var cardIndex = 0; cardIndex < cardToEdit.length; cardIndex++) {
 +
    var card = cardToEdit[cardIndex];
 +
    var cardName = cardData[cardIndex].trueName;
 +
 
 +
    if (!nameToVnum.hasOwnProperty(cardName)) {
 +
      continue;
 +
    }
 +
 
 +
    var addMonsterClone = addMonster.cloneNode(true);
 +
    var monsterVnum = nameToVnum[cardName];
 +
 
 +
    addMonsterClone.dataset.monsterId = monsterVnum;
 +
    card.lastElementChild.appendChild(addMonsterClone);
 +
 
 +
    if (savedMonsters.indexOf(monsterVnum) !== -1) {
 +
        addMonsterClone.firstChild.classList.add("svg-delete-monster");
 +
    }
 +
  }
 +
 
 +
  addMonster.remove();
 +
  var addMonsterText = "Ajouter ce monstre au simulateur de dégâts";
 +
  var deleteMonsterText = "Supprimer ce monstre du simulateur de dégâts";
 +
 
 +
  document.addEventListener("click", function (event) {
 +
    var target = event.target.closest(".add-monster");
 +
 
 +
    if (target) {
 +
      var savedMonsters = getSavedMonsters();
 +
      var monsterVnum = target.dataset.monsterId;
 +
      target = target.firstChild;
 +
 
 +
      if (target.classList.contains("svg-delete-monster")) {
 +
        // delete monster
 +
        target.firstChild.textContent = addMonsterText;
 +
 
 +
        var monsterIndex = savedMonsters.indexOf(monsterVnum);
 +
 
 +
        if (monsterIndex !== -1) {
 +
          writeMonster("-" + monsterVnum);
 +
        } else {
 +
          writeMonster(0);
 +
        }
 +
      } else {
 +
        // add monster
 +
        target.firstChild.textContent = deleteMonsterText;
 +
 
 +
        if (savedMonsters.indexOf(monsterVnum) === -1) {
 +
          writeMonster(monsterVnum);
 +
        } else {
 +
          writeMonster(0);
 +
        }
 +
      }
 +
 
 +
      target.classList.toggle("svg-delete-monster");
 +
    }
 +
  });
 +
}
 +
 
 +
function filterWithUrl(filterInformation, cardInformation) {
 
   function processParameter(key, value, filters) {
 
   function processParameter(key, value, filters) {
 
 
     if (key === "name") {
 
     if (key === "name") {
 
       var filterName = document.getElementById("filter-name");
 
       var filterName = document.getElementById("filter-name");
Ligne 462 : Ligne 579 :
 
         }
 
         }
 
       }
 
       }
 +
    } else if (key === "simulator" && value === "1") {
 +
      var javascriptSource =
 +
        "/index.php?title=Utilisateur:Ankhseram/Calculator.js&action=raw&ctype=text/javascript";
 +
      var cssSource =
 +
        "/index.php?title=Utilisateur:Ankhseram/Style.css&action=raw&ctype=text/css";
 +
      loadStyle(cssSource);
 +
      loadScript(javascriptSource, function () {
 +
        handleDamageSimulator(cardInformation);
 +
      });
 
     } else {
 
     } else {
 
       var splitKey = key.split("-")[0];
 
       var splitKey = key.split("-")[0];
Ligne 475 : Ligne 601 :
 
           rangeFilter[splitKey][extremum] = value;
 
           rangeFilter[splitKey][extremum] = value;
 
         } else {
 
         } else {
           rangeFilter[splitKey] = { min: rangeInformation.init.min, max: rangeInformation.init.max };
+
           rangeFilter[splitKey] = {
 +
            min: rangeInformation.init.min,
 +
            max: rangeInformation.init.max,
 +
          };
 
           rangeFilter[splitKey][extremum] = value;
 
           rangeFilter[splitKey][extremum] = value;
 
         }
 
         }
Ligne 481 : Ligne 610 :
 
     }
 
     }
 
   }
 
   }
 
+
 
 
   var url = new URL(window.location.href);
 
   var url = new URL(window.location.href);
 
   var urlHash = url.hash;
 
   var urlHash = url.hash;
Ligne 488 : Ligne 617 :
  
 
   if (urlHash) {
 
   if (urlHash) {
   
 
 
     var start = ".3F";
 
     var start = ".3F";
     var equal = '.3D';
+
     var equal = ".3D";
     var and = '.26';
+
     var and = ".26";
 
     var startParametersIndex = urlHash.indexOf(start);
 
     var startParametersIndex = urlHash.indexOf(start);
  
 
     if (startParametersIndex !== -1) {
 
     if (startParametersIndex !== -1) {
     
 
 
       useParams = false;
 
       useParams = false;
 
       var parameters = urlHash.slice(startParametersIndex + start.length);
 
       var parameters = urlHash.slice(startParametersIndex + start.length);
  
       parameters.split(and).forEach(function(keyValue) {
+
       parameters.split(and).forEach(function (keyValue) {
 
         var [key, value] = keyValue.split(equal);
 
         var [key, value] = keyValue.split(equal);
 
         processParameter(key, value, filters);
 
         processParameter(key, value, filters);
Ligne 505 : Ligne 632 :
 
     }
 
     }
 
   }
 
   }
 
+
 
 
   if (useParams) {
 
   if (useParams) {
 
     var URLparams = new URLSearchParams(url.search);
 
     var URLparams = new URLSearchParams(url.search);
Ligne 515 : Ligne 642 :
 
}
 
}
  
      
+
function loadScript(src, callback) {
(function(){
+
  var script = document.createElement("script");
    
+
  script.src = src;
 +
 
 +
  function onComplete() {
 +
     if (script.parentNode) {
 +
      script.parentNode.removeChild(script);
 +
    }
 +
    callback();
 +
  }
 +
 
 +
  document.head.appendChild(script);
 +
 
 +
  script.onload = onComplete;
 +
  script.onerror = onComplete;
 +
}
 +
 
 +
function loadStyle(src) {
 +
   var link = document.createElement("link");
 +
  link.href = src;
 +
  link.rel = "stylesheet";
 +
 
 +
  document.head.appendChild(link);
 +
}
 +
 
 +
(function () {
 
   var [filterInformation, filterParameters] = filterInitialization();
 
   var [filterInformation, filterParameters] = filterInitialization();
 
   var cardInformation = getCardInformation(filterParameters);
 
   var cardInformation = getCardInformation(filterParameters);
  
 +
  observeLanguageChange(cardInformation);
 
   handleDropdowns(filterInformation);
 
   handleDropdowns(filterInformation);
   filterWithUrl(filterInformation);
+
   filterWithUrl(filterInformation, cardInformation);
 
   filterItems(filterInformation, cardInformation);
 
   filterItems(filterInformation, cardInformation);
 
   updateFilterObject(filterInformation, cardInformation);
 
   updateFilterObject(filterInformation, cardInformation);
 
   loading();
 
   loading();
 
})();
 
})();

Version actuelle datée du 11 mai 2024 à 18:42

function hideElement(element) {
  element.classList.add("tabber-noactive");
}

function showElement(element) {
  element.classList.remove("tabber-noactive");
}

function removeAccent(str) {
  return str
    .normalize("NFD")
    .replace(/[\u0300-\u036f]/g, "")
    .toLowerCase();
}

function toNormalForm(str) {
  return removeAccent(str).replace(/[^a-zA-Z0-9 ]/g, "");
}

function addValueToObject(object, key, value) {
  if (object[key]) {
    object[key].push(value);
  } else {
    object[key] = [value];
  }
}

function loading() {
  var mainContainer = document.getElementById("hide-all");
  var loadingAnimation = document.getElementById("loading-animation");

  mainContainer.classList.remove("tabber-noactive");
  loadingAnimation.classList.add("tabber-noactive");
}

function handleDropdowns(filterInformation) {
  var form = filterInformation.form;
  var activeButton = null;

  function toggleDropdown(button, dropdownMenu) {
    if (button === activeButton) {
      hideElement(dropdownMenu);
      activeButton = null;
    } else {
      if (activeButton) {
        hideElement(activeButton.nextElementSibling);
      }
      showElement(dropdownMenu);
      activeButton = button;
    }
  }

  function closeDropdowns() {
    if (activeButton) {
      hideElement(activeButton.nextElementSibling);
      activeButton = null;
    }
  }

  form.addEventListener("click", function (event) {
    var target = event.target;
    var button = target.closest("button");

    if (button) {
      var dropdownMenu = button.nextElementSibling;

      toggleDropdown(button, dropdownMenu);
    } else if (!target.closest(".dropdown-menu")) {
      closeDropdowns();
    }
  });

  document.addEventListener("mousedown", function (event) {
    if (!form.contains(event.target)) {
      closeDropdowns();
    }
  });
}

function incrementCounter(counterElement, counterValue) {
  if (counterValue === 0) {
    showElement(counterElement);
  }

  counterElement.textContent = counterValue + 1;
}

function decrementCounter(counterElement, counterValue) {
  if (counterValue === 1) {
    hideElement(counterElement);
  }

  counterElement.textContent = counterValue - 1;
}

function filterItems(filterInformation, cardInformation) {
  function showCounter() {
    var checkbox = filterInformation.checkbox;

    for (var filterName in checkbox) {
      var values = checkbox[filterName].values;

      for (var filterValue in values) {
        var span = values[filterValue].span;

        span.textContent = " (" + values[filterValue].value + ")";
        values[filterValue].value = 0;
      }
    }
  }

  function addCount(cardParameters, checkboxNames, parameter) {
    cardParameters[parameter].split(" ").forEach(function (cardValue) {
      checkboxNames[parameter].values[cardValue].value += 1;
    });
  }

  function isObjectValuesInRangeFilter(parameters, rangeFilter) {
    return Object.keys(rangeFilter).every(function (property) {
      var propertyValue = parameters[property];
      return (
        rangeFilter[property].min <= propertyValue &&
        rangeFilter[property].max >= propertyValue
      );
    });
  }

  function filterByName(parameters, filterName) {
    if (filterName) {
      return parameters.name.indexOf(filterName) !== -1;
    }
    return true;
  }

  function isObjectValuesInFilter(parameters, filter) {
    return Object.keys(filter).every(function (property) {
      return parameters[property].split(" ").some(function (value) {
        return filter[property].indexOf(value) !== -1;
      });
    });
  }

  function isObjectValuesInFilters(
    parameters,
    filter,
    rangeFilter,
    filterName
  ) {
    return (
      isObjectValuesInFilter(parameters, filter) &&
      filterByName(parameters, filterName) &&
      isObjectValuesInRangeFilter(parameters, rangeFilter)
    );
  }

  var filter = filterInformation.filters.filter;
  var rangeFilter = filterInformation.filters.rangeFilter;
  var filterName = filterInformation.filters.filterName;
  var checkboxNames = filterInformation.checkbox;
  var listToFilter = cardInformation.listToFilter.children;
  var cardData = cardInformation.data;

  if (filterInformation.reverse) {
    var parent = cardInformation.listToFilter;
    for (
      var reverseIndex = 1;
      reverseIndex < listToFilter.length;
      reverseIndex++
    ) {
      parent.insertBefore(listToFilter[reverseIndex], parent.firstChild);
    }
    cardInformation.data.reverse();
    filterInformation.reverse = false;
  }

  for (var cardIndex = 0; cardIndex < listToFilter.length; cardIndex++) {
    var card = listToFilter[cardIndex];
    var cardParameters = cardData[cardIndex];
    if (
      isObjectValuesInFilters(cardParameters, filter, rangeFilter, filterName)
    ) {
      showElement(card);
      for (var parameter in checkboxNames) {
        addCount(cardParameters, checkboxNames, parameter);
      }
    } else {
      hideElement(card);
    }
  }
  showCounter();
}

function updateFilterObject(filterInformation, cardInformation) {
  function updateFilter(event, filterByName = false) {
    function handleNumberType(target) {
      var [filterName, extremum] = target.id.split("-");
      var currentValue = Number(target.value);
      var counterElement = filterInformation.range[filterName].counter;
      var counterValue = Number(counterElement.textContent);
      var initialRange = filterInformation.range[filterName].init;
      var rangeFilter = filterInformation.filters.rangeFilter;

      if (rangeFilter[filterName]) {
        rangeFilter[filterName][extremum] = currentValue;
      } else {
        incrementCounter(counterElement, counterValue);
        rangeFilter[filterName] = {
          min: initialRange.min,
          max: initialRange.max,
        };
        rangeFilter[filterName][extremum] = currentValue;
      }
      if (
        rangeFilter[filterName].max === initialRange.max &&
        rangeFilter[filterName].min === initialRange.min
      ) {
        decrementCounter(counterElement, counterValue);
        delete rangeFilter[filterName];
      }
    }

    function handleCheckbox(target) {
      var filterName = target.id.split("-")[0];
      var filter = filterInformation.filters.filter;
      var filterValue = target.dataset.filter;
      var counterElement = filterInformation.checkbox[filterName].counter;
      var counterValue = Number(counterElement.textContent);

      if (target.checked) {
        incrementCounter(counterElement, counterValue);
        addValueToObject(filter, filterName, filterValue);
      } else {
        decrementCounter(counterElement, counterValue);
        var index = filter[filterName].indexOf(filterValue);
        if (index !== -1) {
          if (filter[filterName].length === 1) {
            delete filter[filterName];
          } else {
            filter[filterName].splice(index, 1);
          }
        }
      }
    }

    var target = event.target;

    if (filterByName) {
      filterInformation.filters.filterName = toNormalForm(target.value);
    } else {
      var type = target.type;

      if (type === "number") {
        handleNumberType(target);
      } else if (type === "checkbox") {
        if (target.id === "filter-reverse") {
          filterInformation.reverse = true;
        } else {
          handleCheckbox(target);
        }
      }
    }
    filterItems(filterInformation, cardInformation);
  }

  var form = filterInformation.form;
  var debounceTimer;

  form.addEventListener("submit", function (event) {
    event.preventDefault();
  });

  form.addEventListener("change", function (event) {
    updateFilter(event);
  });

  form.addEventListener("input", function (event) {
    if (event.target.id === "filter-name") {
      clearTimeout(debounceTimer);
      debounceTimer = setTimeout(function () {
        updateFilter(event, true);
      }, 500);
    }
  });
}

function filterInitialization() {
  function createSpan() {
    var span = document.createElement("span");
    span.style.color = "#9F9F9F";
    span.style.fontSize = "12px";
    return span;
  }

  function handlefilterParameters(filterParameters, param, filterName) {
    if (param === "levels") {
      addValueToObject(filterParameters, "levels", filterName);
    } else if (param.startsWith("replace_")) {
      var replace = param.split("replace_")[1].replace("_", " ");

      if (!filterParameters["replace"]) {
        filterParameters["replace"] = {};
      }
      filterParameters["replace"][filterName] = { value: replace };
    } else if (param === "elem") {
      filterParameters["elem"] = filterName;
    }
  }

  var form = document.getElementById("filter-form");
  var filters = { filterName: "", filter: {}, rangeFilter: {} };
  var filterInformation = {
    form: form,
    filters: filters,
    range: {},
    checkbox: {},
    reverse: false,
  };
  var allButton = form.querySelectorAll("button");
  var filterParameters = {};

  allButton.forEach(function (button) {
    var buttonSibling = button.nextElementSibling;

    if (!buttonSibling) return;

    var filterName = buttonSibling.id;
    var counter = buttonSibling.nextElementSibling;
    var param = buttonSibling.dataset.param;

    if (!filterName || !counter || !param) return;

    var infoType = filterName.endsWith("-range") ? "range" : "checkbox";
    var filterName = filterName.replace("-range", "");
    var filterObj = (filterInformation[infoType][filterName] = {
      counter: counter,
    });

    handlefilterParameters(filterParameters, param, filterName);

    if (infoType === "checkbox") {
      filterObj.values = {};
      var allInput = buttonSibling.querySelectorAll("input");
      allInput.forEach(function (input) {
        var filterValue = input.dataset.filter;

        if (!filterValue) return;

        var span = createSpan();
        input.parentElement.appendChild(span);
        filterObj.values[filterValue] = { value: 0, span: span };
      });
    } else if (infoType === "range") {
      filterObj.init = {};
      filterObj.init.min = Number(buttonSibling.children[0].firstChild.min);
      filterObj.init.max = Number(buttonSibling.children[0].firstChild.max);
    }
  });

  return [filterInformation, filterParameters];
}

function getCardInformation(filterParameters) {
  function createDataSelector(name) {
    return "[data-" + name + "]";
  }

  var listToFilter = document.getElementById("list-to-filter");
  var listToFilterChildren = listToFilter.children;
  var allCardInformation = [];
  var filterLevelsNames = filterParameters["levels"];
  var filterWithReplace = filterParameters["replace"];
  var filterElementName = filterParameters["elem"];

  if (filterLevelsNames) {
    var [level0, level1] = filterLevelsNames;
    var levelsSelector = createDataSelector(level0);
  }

  if (filterWithReplace) {
    for (var replaceName in filterWithReplace) {
      filterWithReplace[replaceName].selector = createDataSelector(replaceName);
    }
  }

  if (filterElementName) {
    var elementSelector = createDataSelector(filterElementName);
  }

  for (
    var cardIndex = 0;
    cardIndex < listToFilterChildren.length;
    cardIndex++
  ) {
    var card = listToFilterChildren[cardIndex];
    var cardInformation = {};
    var cardNameElement = card.querySelector("[data-name]");
    cardInformation.name = toNormalForm(cardNameElement.textContent);
    cardInformation.trueName = cardNameElement.firstChild.title;

    if (filterLevelsNames) {
      var levelsElement = card.querySelector(levelsSelector);
      var [levelValue0, levelValue1] = levelsElement.textContent
        .slice(1, -1)
        .split(", ");
      cardInformation[level0] = Number(levelValue0);
      cardInformation[level1] = removeAccent(levelValue1);
    }

    if (filterElementName) {
      var elementChild = card.querySelector(elementSelector).children;
      var elementValue = "";
      if (elementChild.length) {
        for (
          var elementIndex = 0;
          elementIndex < elementChild.length;
          elementIndex++
        ) {
          elementValue += elementChild[elementIndex].title + " ";
        }
      }
      elementValue = elementValue.trim() || "Aucun";
      cardInformation[filterElementName] = removeAccent(elementValue);
    }

    if (filterWithReplace) {
      for (var replaceName in filterWithReplace) {
        var replaceInformation = filterWithReplace[replaceName];
        var replaceValue = card
          .querySelector(replaceInformation.selector)
          .textContent.replace(replaceInformation.value, "");
        cardInformation[replaceName] = removeAccent(replaceValue);
      }
    }

    allCardInformation.push(cardInformation);
  }
  allCardInformation = { listToFilter: listToFilter, data: allCardInformation };

  return allCardInformation;
}

function editCardInformation(cardInformation) {
  var listToFilterChildren = cardInformation.listToFilter.children;

  for (
    var cardIndex = 0;
    cardIndex < listToFilterChildren.length;
    cardIndex++
  ) {
    var card = listToFilterChildren[cardIndex];
    var cardName = card.querySelector("[data-name]").textContent;
    cardInformation.data[cardIndex].name = toNormalForm(cardName);
  }
}

function observeLanguageChange(cardInformation) {
  var filterName = document.getElementById("filter-name");

  if (!filterName) {
    return;
  }

  var observer = new MutationObserver(function (mutation) {
    editCardInformation(cardInformation);
  });

  observer.observe(filterName, { attributes: true });
}

function getSavedMonsters() {
  var savedMonsters = localStorage.getItem("savedMonstersCalculator");

  if (savedMonsters) {
    return JSON.parse(savedMonsters);
  }
  return [];
}

function writeMonster(monsterVnum) {
  localStorage.setItem("newMonsterCalculator", monsterVnum);
}

function handleDamageSimulator(cardInformation) {
  var addMonster = document.getElementById("add-monster");
  var cardToEdit = cardInformation.listToFilter.children;
  var cardData = cardInformation.data;
  var savedMonsters = getSavedMonsters();

  addMonster.removeAttribute("id");
  addMonster = addMonster.parentElement;
  addMonster.classList.remove("tabber-noactive");

  var nameToVnum = {};
  var monsterParametersLength = monsterData[101].length;

  for (monsterVnum in monsterData) {
    nameToVnum[monsterData[monsterVnum][monsterParametersLength - 1]] =
      monsterVnum;
  }

  for (var cardIndex = 0; cardIndex < cardToEdit.length; cardIndex++) {
    var card = cardToEdit[cardIndex];
    var cardName = cardData[cardIndex].trueName;

    if (!nameToVnum.hasOwnProperty(cardName)) {
      continue;
    }

    var addMonsterClone = addMonster.cloneNode(true);
    var monsterVnum = nameToVnum[cardName];

    addMonsterClone.dataset.monsterId = monsterVnum;
    card.lastElementChild.appendChild(addMonsterClone);

    if (savedMonsters.indexOf(monsterVnum) !== -1) {
        addMonsterClone.firstChild.classList.add("svg-delete-monster");
    }
  }

  addMonster.remove();
  var addMonsterText = "Ajouter ce monstre au simulateur de dégâts";
  var deleteMonsterText = "Supprimer ce monstre du simulateur de dégâts";

  document.addEventListener("click", function (event) {
    var target = event.target.closest(".add-monster");

    if (target) {
      var savedMonsters = getSavedMonsters();
      var monsterVnum = target.dataset.monsterId;
      target = target.firstChild;

      if (target.classList.contains("svg-delete-monster")) {
        // delete monster
        target.firstChild.textContent = addMonsterText;

        var monsterIndex = savedMonsters.indexOf(monsterVnum);

        if (monsterIndex !== -1) {
          writeMonster("-" + monsterVnum);
        } else {
          writeMonster(0);
        }
      } else {
        // add monster
        target.firstChild.textContent = deleteMonsterText;

        if (savedMonsters.indexOf(monsterVnum) === -1) {
          writeMonster(monsterVnum);
        } else {
          writeMonster(0);
        }
      }

      target.classList.toggle("svg-delete-monster");
    }
  });
}

function filterWithUrl(filterInformation, cardInformation) {
  function processParameter(key, value, filters) {
    if (key === "name") {
      var filterName = document.getElementById("filter-name");
      filterName.value = toNormalForm(value);
      filters.filterName = value;
    } else if (Object.keys(filterInformation.checkbox).indexOf(key) !== -1) {
      var checkboxElement = document.getElementById(key + "-" + value);
      if (!checkboxElement) return;
      var counterElement = filterInformation.checkbox[key].counter;
      var counterValue = Number(counterElement.textContent);
      incrementCounter(counterElement, counterValue);
      checkboxElement.checked = true;
      addValueToObject(filters.filter, key, value);
    } else if (key === "reverse") {
      if (value === "1") {
        filterInformation.reverse = true;
        var reverseElement = document.getElementById("filter-reverse");
        if (reverseElement) {
          reverseElement.checked = true;
        }
      }
    } else if (key === "simulator" && value === "1") {
      var javascriptSource =
        "/index.php?title=Utilisateur:Ankhseram/Calculator.js&action=raw&ctype=text/javascript";
      var cssSource =
        "/index.php?title=Utilisateur:Ankhseram/Style.css&action=raw&ctype=text/css";
      loadStyle(cssSource);
      loadScript(javascriptSource, function () {
        handleDamageSimulator(cardInformation);
      });
    } else {
      var splitKey = key.split("-")[0];
      if (Object.keys(filterInformation.range).indexOf(splitKey) !== -1) {
        var rangeElement = document.getElementById(key);
        if (!rangeElement) return;
        rangeElement.value = value;
        var rangeInformation = filterInformation.range[splitKey];
        incrementCounter(rangeInformation.counter, 0);
        var extremum = key.split("-")[1];
        var rangeFilter = filters.rangeFilter;
        if (rangeFilter[splitKey]) {
          rangeFilter[splitKey][extremum] = value;
        } else {
          rangeFilter[splitKey] = {
            min: rangeInformation.init.min,
            max: rangeInformation.init.max,
          };
          rangeFilter[splitKey][extremum] = value;
        }
      }
    }
  }

  var url = new URL(window.location.href);
  var urlHash = url.hash;
  var useParams = true;
  var filters = filterInformation.filters;

  if (urlHash) {
    var start = ".3F";
    var equal = ".3D";
    var and = ".26";
    var startParametersIndex = urlHash.indexOf(start);

    if (startParametersIndex !== -1) {
      useParams = false;
      var parameters = urlHash.slice(startParametersIndex + start.length);

      parameters.split(and).forEach(function (keyValue) {
        var [key, value] = keyValue.split(equal);
        processParameter(key, value, filters);
      });
    }
  }

  if (useParams) {
    var URLparams = new URLSearchParams(url.search);

    for (var [key, value] of URLparams.entries()) {
      processParameter(key, value, filters);
    }
  }
}

function loadScript(src, callback) {
  var script = document.createElement("script");
  script.src = src;

  function onComplete() {
    if (script.parentNode) {
      script.parentNode.removeChild(script);
    }
    callback();
  }

  document.head.appendChild(script);

  script.onload = onComplete;
  script.onerror = onComplete;
}

function loadStyle(src) {
  var link = document.createElement("link");
  link.href = src;
  link.rel = "stylesheet";

  document.head.appendChild(link);
}

(function () {
  var [filterInformation, filterParameters] = filterInitialization();
  var cardInformation = getCardInformation(filterParameters);

  observeLanguageChange(cardInformation);
  handleDropdowns(filterInformation);
  filterWithUrl(filterInformation, cardInformation);
  filterItems(filterInformation, cardInformation);
  updateFilterObject(filterInformation, cardInformation);
  loading();
})();