Greasy Fork is available in English.

CherryPicker Slayer! - Stow

Find those cherrypickers!

// ==UserScript==
// @name         CherryPicker Slayer! - Stow
// @namespace    http://tampermonkey.net/
// @version      1.1
// @description  Find those cherrypickers!
// @author       milcz
// @match        https://fclm-portal.amazon.com/reports/*&processId=01002976*
// @match        https://fclm-portal.amazon.com/reports/*&processId=1002976*
// @match        https://fclm-portal.amazon.com/reports/*&processId=01003016*
// @match        https://fclm-portal.amazon.com/reports/*&processId=1003016*
// @icon         
// @grant        none
// @run-at       document-idle
// ==/UserScript==


function go() {
    'use strict';

    if (document.querySelectorAll('.tablesorter-headerRow').length > 3) {
    const eachStowHeader = document.querySelectorAll('.tablesorter-headerRow')[1]
    const header = document.createElement('th')
    header.innerHTML = 'Product Mix'
    header.setAttribute('colspan', '3')
    eachStowHeader.appendChild(header)
    const eachStowHeaderS = document.createElement('th')
    const eachStowHeaderM = document.createElement('th')
    const eachStowHeaderL = document.createElement('th')
    eachStowHeaderS.innerHTML = 'Small'
    eachStowHeaderM.innerHTML = 'Medium'
    eachStowHeaderL.innerHTML = 'Large'
    eachStowHeaderS.style.cursor = 'pointer'
    eachStowHeaderM.style.cursor = 'pointer'
    eachStowHeaderL.style.cursor = 'pointer'
    document.querySelectorAll('.tablesorter-headerRow')[2].appendChild(eachStowHeaderS)
    document.querySelectorAll('.tablesorter-headerRow')[2].appendChild(eachStowHeaderM)
    document.querySelectorAll('.tablesorter-headerRow')[2].appendChild(eachStowHeaderL)
    eachStowHeaderS.setAttribute('id', 'each-stow-header-S')
    eachStowHeaderM.setAttribute('id', 'each-stow-header-M')
    eachStowHeaderL.setAttribute('id', 'each-stow-header-L')
    eachStowHeaderS.addEventListener('click', sortBySmalls)
    eachStowHeaderM.addEventListener('click', sortByMediums)
    eachStowHeaderL.addEventListener('click', sortByLarges)
    }

    const eachStowHeaderNike = document.querySelectorAll('.tablesorter-headerRow')[document.querySelectorAll('.tablesorter-headerRow').length - 2]
    const headerNike = document.createElement('th')
    headerNike.innerHTML = 'Product Mix'
    headerNike.setAttribute('colspan', '3')
    eachStowHeaderNike.appendChild(headerNike)
    const eachStowHeaderNikeS = document.createElement('th')
    const eachStowHeaderNikeM = document.createElement('th')
    const eachStowHeaderNikeL = document.createElement('th')
    eachStowHeaderNikeS.innerHTML = 'Small'
    eachStowHeaderNikeM.innerHTML = 'Medium'
    eachStowHeaderNikeL.innerHTML = 'Large'
    eachStowHeaderNikeS.style.cursor = 'pointer'
    eachStowHeaderNikeM.style.cursor = 'pointer'
    eachStowHeaderNikeL.style.cursor = 'pointer'
    document.querySelectorAll('.tablesorter-headerRow')[document.querySelectorAll('.tablesorter-headerRow').length - 1].appendChild(eachStowHeaderNikeS)
    document.querySelectorAll('.tablesorter-headerRow')[document.querySelectorAll('.tablesorter-headerRow').length - 1].appendChild(eachStowHeaderNikeM)
    document.querySelectorAll('.tablesorter-headerRow')[document.querySelectorAll('.tablesorter-headerRow').length - 1].appendChild(eachStowHeaderNikeL)
    eachStowHeaderNikeS.setAttribute('id', 'each-stow-header-nike-S')
    eachStowHeaderNikeM.setAttribute('id', 'each-stow-header-nike-M')
    eachStowHeaderNikeL.setAttribute('id', 'each-stow-header-nike-L')
    eachStowHeaderNikeS.addEventListener('click', sortBySmallsNike)
    eachStowHeaderNikeM.addEventListener('click', sortByMediumsNike)
    eachStowHeaderNikeL.addEventListener('click', sortByLargesNike)

    const rows = document.querySelectorAll('.empl-all[role="row"]:not(.total)')

    for (let row of rows) {
    const smallCell = document.createElement('td')
    const mediumCell = document.createElement('td')
    const largeCell = document.createElement('td')

    smallCell.innerHTML = Math.round(Number(row.cells[11].innerHTML) * 100 / Number(row.cells[19].innerHTML)) + '%'
    mediumCell.innerHTML = Math.round(Number(row.cells[13].innerHTML) * 100 / Number(row.cells[19].innerHTML)) + '%'
    largeCell.innerHTML = Math.round(Number(row.cells[15].innerHTML) * 100 / Number(row.cells[19].innerHTML)) + '%'
    row.appendChild(smallCell)
    row.appendChild(mediumCell)
    row.appendChild(largeCell)
    }


};

setTimeout(go,5000);

function sortBySmallsNike(){
    const eachStowHeaderNikeS = document.getElementById('each-stow-header-nike-S')
    const rowsArray = []
    for (let row of [...document.querySelectorAll('table')[document.querySelectorAll('table').length - 1].children[2].children]) {
        if (row.cells[21].innerHTML != 'NaN%') {
         rowsArray.push(row)
        }
    }
    let sortedRows = ''
    if (document.getElementById('each-stow-header-nike-S').getAttribute('data-sort') != 'asc'){
    sortedRows = rowsArray.sort((a ,b) => Number(b.cells[21].innerHTML.slice(0,-1)) - Number(a.cells[21].innerHTML.slice(0,-1)))
    document.getElementById('each-stow-header-nike-S').setAttribute('data-sort', 'asc')
    } else {
    sortedRows = rowsArray.sort((a ,b) => Number(a.cells[21].innerHTML.slice(0,-1)) - Number(b.cells[21].innerHTML.slice(0,-1)))
    document.getElementById('each-stow-header-nike-S').setAttribute('data-sort', 'dsc')
    }

    while (document.querySelectorAll('table')[document.querySelectorAll('table').length - 1].children[2].firstChild) {
    document.querySelectorAll('table')[document.querySelectorAll('table').length - 1].children[2].removeChild(document.querySelectorAll('table')[document.querySelectorAll('table').length - 1].children[2].lastChild);
  }
    for (let row of sortedRows){
        document.querySelectorAll('table')[document.querySelectorAll('table').length - 1].children[2].appendChild(row)
    }
}
function sortByMediumsNike(){
    const eachStowHeaderNikeS = document.getElementById('each-stow-header-nike-M')
    const rowsArray = []
    for (let row of [...document.querySelectorAll('table')[document.querySelectorAll('table').length - 1].children[2].children]) {
        if (row.cells[21].innerHTML != 'NaN%') {
         rowsArray.push(row)
        }
    }
    let sortedRows = ''
    if (document.getElementById('each-stow-header-nike-M').getAttribute('data-sort') != 'asc'){
    sortedRows = rowsArray.sort((a ,b) => Number(b.cells[22].innerHTML.slice(0,-1)) - Number(a.cells[22].innerHTML.slice(0,-1)))
    document.getElementById('each-stow-header-nike-M').setAttribute('data-sort', 'asc')
    } else {
    sortedRows = rowsArray.sort((a ,b) => Number(a.cells[22].innerHTML.slice(0,-1)) - Number(b.cells[22].innerHTML.slice(0,-1)))
    document.getElementById('each-stow-header-nike-M').setAttribute('data-sort', 'dsc')
    }

    while (document.querySelectorAll('table')[document.querySelectorAll('table').length - 1].children[2].firstChild) {
    document.querySelectorAll('table')[document.querySelectorAll('table').length - 1].children[2].removeChild(document.querySelectorAll('table')[document.querySelectorAll('table').length - 1].children[2].lastChild);
  }
    for (let row of sortedRows){
        document.querySelectorAll('table')[document.querySelectorAll('table').length - 1].children[2].appendChild(row)
    }
}
function sortByLargesNike(){
    const eachStowHeaderNikeL = document.getElementById('each-stow-header-nike-L')
    const rowsArray = []
    for (let row of [...document.querySelectorAll('table')[document.querySelectorAll('table').length - 1].children[2].children]) {
        if (row.cells[21].innerHTML != 'NaN%') {
         rowsArray.push(row)
        }
    }
    let sortedRows = ''
    if (document.getElementById('each-stow-header-nike-L').getAttribute('data-sort') != 'asc'){
    sortedRows = rowsArray.sort((a ,b) => Number(b.cells[23].innerHTML.slice(0,-1)) - Number(a.cells[23].innerHTML.slice(0,-1)))
    document.getElementById('each-stow-header-nike-L').setAttribute('data-sort', 'asc')
    } else {
    sortedRows = rowsArray.sort((a ,b) => Number(a.cells[23].innerHTML.slice(0,-1)) - Number(b.cells[23].innerHTML.slice(0,-1)))
    document.getElementById('each-stow-header-nike-L').setAttribute('data-sort', 'dsc')
    }

    while (document.querySelectorAll('table')[document.querySelectorAll('table').length - 1].children[2].firstChild) {
    document.querySelectorAll('table')[document.querySelectorAll('table').length - 1].children[2].removeChild(document.querySelectorAll('table')[document.querySelectorAll('table').length - 1].children[2].lastChild);
  }
    for (let row of sortedRows){
        document.querySelectorAll('table')[document.querySelectorAll('table').length - 1].children[2].appendChild(row)
    }
}
function sortBySmalls(){
    const eachStowHeaderNikeS = document.getElementById('each-stow-header-S')
    const rowsArray = []
    for (let row of [...document.querySelectorAll('table')[document.querySelectorAll('table').length - 2].children[2].children]) {
        if (row.cells[21].innerHTML != 'NaN%') {
         rowsArray.push(row)
        }
    }
    let sortedRows = ''
    if (document.getElementById('each-stow-header-S').getAttribute('data-sort') != 'asc'){
    sortedRows = rowsArray.sort((a ,b) => Number(b.cells[21].innerHTML.slice(0,-1)) - Number(a.cells[21].innerHTML.slice(0,-1)))
    document.getElementById('each-stow-header-S').setAttribute('data-sort', 'asc')
    } else {
    sortedRows = rowsArray.sort((a ,b) => Number(a.cells[21].innerHTML.slice(0,-1)) - Number(b.cells[21].innerHTML.slice(0,-1)))
    document.getElementById('each-stow-header-S').setAttribute('data-sort', 'dsc')
    }

    while (document.querySelectorAll('table')[document.querySelectorAll('table').length - 2].children[2].firstChild) {
    document.querySelectorAll('table')[document.querySelectorAll('table').length - 2].children[2].removeChild(document.querySelectorAll('table')[document.querySelectorAll('table').length - 2].children[2].lastChild);
  }
    for (let row of sortedRows){
        document.querySelectorAll('table')[document.querySelectorAll('table').length - 2].children[2].appendChild(row)
    }
}
function sortByMediums(){
    const eachStowHeaderS = document.getElementById('each-stow-header-nike-M')
    const rowsArray = []
    for (let row of [...document.querySelectorAll('table')[document.querySelectorAll('table').length - 2].children[2].children]) {
        if (row.cells[21].innerHTML != 'NaN%') {
         rowsArray.push(row)
        }
    }
    let sortedRows = ''
    if (document.getElementById('each-stow-header-M').getAttribute('data-sort') != 'asc'){
    sortedRows = rowsArray.sort((a ,b) => Number(b.cells[22].innerHTML.slice(0,-1)) - Number(a.cells[22].innerHTML.slice(0,-1)))
    document.getElementById('each-stow-header-M').setAttribute('data-sort', 'asc')
    } else {
    sortedRows = rowsArray.sort((a ,b) => Number(a.cells[22].innerHTML.slice(0,-1)) - Number(b.cells[22].innerHTML.slice(0,-1)))
    document.getElementById('each-stow-header-M').setAttribute('data-sort', 'dsc')
    }

    while (document.querySelectorAll('table')[document.querySelectorAll('table').length - 2].children[2].firstChild) {
    document.querySelectorAll('table')[document.querySelectorAll('table').length - 2].children[2].removeChild(document.querySelectorAll('table')[document.querySelectorAll('table').length - 2].children[2].lastChild);
  }
    for (let row of sortedRows){
        document.querySelectorAll('table')[document.querySelectorAll('table').length - 2].children[2].appendChild(row)
    }
}
function sortByLarges(){
    const eachStowHeaderNikeL = document.getElementById('each-stow-header-L')
    const rowsArray = []
    for (let row of [...document.querySelectorAll('table')[document.querySelectorAll('table').length - 2].children[2].children]) {
        if (row.cells[21].innerHTML != 'NaN%') {
         rowsArray.push(row)
        }
    }
    let sortedRows = ''
    if (document.getElementById('each-stow-header-L').getAttribute('data-sort') != 'asc'){
    sortedRows = rowsArray.sort((a ,b) => Number(b.cells[23].innerHTML.slice(0,-1)) - Number(a.cells[23].innerHTML.slice(0,-1)))
    document.getElementById('each-stow-header-L').setAttribute('data-sort', 'asc')
    } else {
    sortedRows = rowsArray.sort((a ,b) => Number(a.cells[23].innerHTML.slice(0,-1)) - Number(b.cells[23].innerHTML.slice(0,-1)))
    document.getElementById('each-stow-header-L').setAttribute('data-sort', 'dsc')
    }

    while (document.querySelectorAll('table')[document.querySelectorAll('table').length - 2].children[2].firstChild) {
    document.querySelectorAll('table')[document.querySelectorAll('table').length - 2].children[2].removeChild(document.querySelectorAll('table')[document.querySelectorAll('table').length - 2].children[2].lastChild);
  }
    for (let row of sortedRows){
        document.querySelectorAll('table')[document.querySelectorAll('table').length - 2].children[2].appendChild(row)
    }
}