hwmAdvancedPlayerInfo

Добавляет в инфу персов и на домашнюю: ХП армии, очки и загрузку навыков, баланс рулетки и таверны, сумму умений, перекач, день рождения персонажа. Спойлеры. Статистика клана. Книга магии.

// ==UserScript==
// @name hwmAdvancedPlayerInfo
// @author alex_kocharin 2008-2012, Demin 2013-2015, Tamozhnya1 2024
// @namespace Tamozhnya1
// @version 24.3
// @description Добавляет в инфу персов и на домашнюю: ХП армии, очки и загрузку навыков, баланс рулетки и таверны, сумму умений, перекач, день рождения персонажа. Спойлеры. Статистика клана. Книга магии.
// @include     /^https{0,1}:\/\/(www|my|mirror)\.(heroeswm|lordswm)\.(ru|com)\/(home|pl_info|clan_info|tournaments|transfer)\.php/
// @grant GM_deleteValue
// @grant GM_getValue
// @grant GM_setValue
// @grant GM.xmlHttpRequest
// @license MIT
// ==/UserScript==

// Включить/выключить загрузку навыков на домашней странице можно щелчком по надписи "Навыки". День рождения загружается щелчком по надписи. Стоимость боя показывается скриптом hwmOptimalRepairAtMarket. Туда же перенесены расчет ОА и крафта.
// Оригинальный скрипт https://userscripts-mirror.org/scripts/show/178809 (скрипт демина с greasyfork почему-то удален, как и таймеры)
const playerIdMatch = document.cookie.match(/pl_id=(\d+)/);
const PlayerId = playerIdMatch ? playerIdMatch[1] : "";
const lang = document.documentElement.lang || (location.hostname == "www.lordswm.com" ? "en" : "ru");
const isEn = lang == "en";
const win = window.wrappedJSObject || unsafeWindow;
const isHeartOnPage = (document.querySelector("canvas#heart") || document.querySelector("div#heart_js_mobile")) ? true : false;
const isMooving = location.pathname == '/map.php' && !document.getElementById("map_right_block");
const isNewInterface = document.querySelector("div#hwm_header") ? true : false;
const isMobileInterface = document.querySelector("div#btnMenuGlobal") ? true : false;
const isMobileDevice = mobileCheck(); // Там нет мышки
const isNewPersonPage = document.querySelector("div#hwm_no_zoom") ? true : false;

fetch.get = (url) => fetch({ url });
fetch.post = (url, data) => fetch({ url, method: 'POST', body: data });

if(!PlayerId) {
    return;
}

const unitsHealth = {
    peasant: [1, 4],
    conscript: [1, 6],
    archer: [1, 7],
    marksman: [1, 10],
    footman: [1, 16],
    squire: [1, 26],
    griffon: [1, 30],
    impergriffin: [1, 35],
    priest: [1, 54],
    inquisitor: [1, 80],
    cavalier: [1, 90],
    paladin: [1, 100],
    angel: [1, 180],
    archangel: [1, 220],

    brute: [101, 8],
    crossman: [101, 8],
    vindicator: [101, 23],
    battlegriffon: [101, 52],
    zealot: [101, 80],
    champion: [101, 100],
    seraph2: [101, 220],

    skeleton: [2, 4],
    skeletonarcher: [2, 4],
    zombie: [2, 17],
    plaguezombie: [2, 17],
    ghost: [2, 8],
    spectre: [2, 19],
    vampire: [2, 30],
    vampirelord: [2, 35],
    lich: [2, 50],
    archlich: [2, 55],
    wight: [2, 95],
    wraith: [2, 100],
    bonedragon: [2, 150],
    spectraldragon: [2, 160],

    sceletonwar: [102, 5],
    rotzombie: [102, 23],
    poltergeist: [102, 20],
    vampireprince: [102, 40],
    masterlich: [102, 55],
    banshee: [102, 110],
    ghostdragon: [102, 150],

    gremlin: [3, 5],
    mastergremlin: [3, 6],
    stone_gargoyle: [3, 15],
    obsgargoyle: [3, 20],
    iron_golem: [3, 18],
    steelgolem: [3, 24],
    mage: [3, 18],
    archmage: [3, 30],
    djinn: [3, 40],
    djinn_sultan: [3, 45],
    rakshasa_rani: [3, 120],
    rakshasa_raja: [3, 140],
    colossus: [3, 175],
    titan: [3, 190],

    saboteurgremlin: [103, 6],
    elgargoly: [103, 16],
    magneticgolem: [103, 28],
    battlemage: [103, 29],
    djinn_vizier: [103, 50],
    rakshasa_kshatra: [103, 135],
    stormtitan: [103, 190],

    pixel: [4, 5],
    sprite: [4, 6],
    dancer: [4, 12],
    wardancer: [4, 12],
    elf: [4, 10],
    masterhunter: [4, 14],
    druid: [4, 34],
    druideld: [4, 38],
    unicorn: [4, 57],
    silverunicorn: [4, 77],
    treant: [4, 175],
    ancienent: [4, 181],
    greendragon: [4, 200],
    emeralddragon: [4, 200],

    dryad: [104, 6],
    wdancer: [104, 14],
    arcaneelf: [104, 12],
    ddhigh: [104, 34],
    pristineunicorn: [104, 80],
    savageent: [104, 175],
    crystaldragon: [104, 200],

    goblin: [5, 3],
    hobgoblin: [5, 4],
    wolfrider: [5, 10],
    wolfraider: [5, 12],
    orc: [5, 12],
    orcchief: [5, 18],
    ogre: [5, 50],
    ogremagi: [5, 65],
    rocbird: [5, 55],
    thunderbird: [5, 65],
    cyclop: [5, 85],
    cyclopking: [5, 95],
    behemoth: [5, 210],
    ancientbehemoth: [5, 250],

    goblinarcher: [105, 3],
    boarrider: [105, 14],
    orcrubak: [105, 20],
    ogrebrutal: [105, 70],
    firebird: [105, 65],
    cyclopod: [105, 100],
    dbehemoth: [105, 280],

    goblinmag: [205, 3],
    orcshaman: [205, 13],
    darkbird: [205, 60],
    hyenarider: [205, 13],
    ogreshaman: [205, 55],
    shamancyclop: [205, 105],
    cursedbehemoth: [205, 250],

    scout: [6, 10],
    assassin: [6, 14],
    stalker: [6, 15],
    maiden: [6, 16],
    fury: [6, 16],
    bloodsister: [6, 24],
    minotaur: [6, 31],
    minotaurguard: [6, 35],
    taskmaster: [6, 40],
    darkrider: [6, 40],
    grimrider: [6, 50],
    briskrider: [6, 50],
    hydra: [6, 80],
    deephydra: [6, 125],
    foulhydra: [6, 125],
    shadow_witch: [6, 80],
    matriarch: [6, 90],
    mistress: [6, 100],
    shadowdragon: [6, 200],
    blackdragon: [6, 240],
    reddragon: [6, 235],

    imp: [7, 4],
    familiar: [7, 6],
    horneddemon: [7, 13],
    hornedoverseer: [7, 13],
    hellhound: [7, 15],
    cerberus: [7, 15],
    succubus: [7, 20],
    succubusmis: [7, 30],
    hellcharger: [7, 50],
    nightmare: [7, 66],
    pitfiend: [7, 110],
    pitlord: [7, 120],
    devil: [7, 166],
    archdevil: [7, 199],

    vermin: [107, 6],
    jdemon: [107, 13],
    hotdog: [107, 15],
    seducer: [107, 26],
    hellkon: [107, 66],
    pity: [107, 140],
    archdemon: [107, 211],

    defender: [8, 7],
    shieldguard: [8, 12],
    spearwielder: [8, 10],
    skirmesher: [8, 12],
    bearrider: [8, 25],
    blackbearrider: [8, 30],
    brawler: [8, 20],
    berserker: [8, 25],
    runepriest: [8, 60],
    runepatriarch: [8, 70],
    thane: [8, 100],
    thunderlord: [8, 120],
    firedragon: [8, 230],
    magmadragon: [8, 280],

    mountaingr: [108, 12],
    harpooner: [108, 10],
    whitebearrider: [108, 30],
    battlerager: [108, 30],
    runekeeper: [108, 65],
    flamelord: [108, 120],
    lavadragon: [108, 275],

    goblinus: [9, 3],
    trapper: [9, 4],
    fcentaur: [9, 6],
    ncentaur: [9, 9],
    warrior: [9, 12],
    mauler: [9, 12],
    shamaness: [9, 30],
    sdaughter: [9, 35],
    slayer: [9, 34],
    executioner: [9, 40],
    wyvern: [9, 90],
    foulwyvern: [9, 105],
    cyclopus: [9, 220],
    untamedcyc: [9, 225],

    goblinshaman: [109, 5],
    mcentaur: [109, 10],
    warmong: [109, 20],
    eadaughter: [109, 35],
    chieftain: [109, 48],
    poukai: [109, 120],
    bloodeyecyc: [109, 235],

    scorp: [10, 4],
    scorpup: [10, 5],
    duneraider: [10, 12],
    duneraiderup: [10, 12],
    shakal: [10, 24],
    shakalup: [10, 30],
    dromad: [10, 40],
    dromadup: [10, 45],
    priestmoon: [10, 50],
    priestsun: [10, 55],
    slon: [10, 100],
    slonup: [10, 110],
    anubis: [10, 160],
    anubisup: [10, 200]
};
const perkBranchCosts = {
    1: {
        knight_mark: 5,
        attack: 9,
        defense: 8,
        luck: 10,
        leadership: 7,
        dark: 8,
        light: 7
    },
    101: {
        benediction: 7,
        defense: 10,
        leadership: 10,
        enlightenment: 8,
        light: 6,
        summon: 10,
        sorcery: 7
    },
    2: {
        necr_soul: 5,
        defense: 11,
        enlightenment: 9,
        dark: 7,
        summon: 8,
        sorcery: 8
    },
    102: {
        powerraise: 6,
        attack: 9,
        luck: 10,
        enlightenment: 8,
        summon: 6,
        sorcery: 7
    },
    3: {
        magic_mirror: 7,
        enlightenment: 9,
        light: 10,
        summon: 8,
        destructive: 10,
        sorcery: 7
    },
    103: {
        nomagicdamage: 7,
        attack: 8,
        luck: 10,
        leadership: 9,
        enlightenment: 8,
        destructive: 9,
        sorcery: 8
    },
    4: {
        elf_shot: 7,
        attack: 10,
        defense: 9,
        luck: 7,
        leadership: 10,
        enlightenment: 10,
        light: 7,
        summon: 9
    },
    104: {
        zakarrow: 4,
        attack: 9,
        defense: 8,
        luck: 10,
        leadership: 8,
        enlightenment: 12
    },
    5: {
        barb_skill: 7,
        attack: 7,
        defense: 9,
        luck: 9,
        leadership: 10
    },
    105: {
        save_rage: 6,
        attack: 7,
        defense: 8,
        luck: 7,
        leadership: 9
    },
    205: {
        dark_blood: 5,
        defense: 9,
        luck: 10,
        leadership: 10,
        enlightenment: 8,
        dark: 6,
        sorcery: 7
    },
    6: {
        dark_power: 7,
        attack: 8,
        luck: 9,
        leadership: 10,
        enlightenment: 10,
        dark: 8,
        destructive: 9,
        sorcery: 7
    },
    106: {
        cre_master: 5,
        attack: 8,
        defense: 11,
        leadership: 8,
        luck: 10,
        enlightenment: 8,
        dark: 8
    },
    7: {
        hellfire: 6,
        attack: 7,
        defense: 9,
        luck: 10,
        dark: 8,
        destructive: 10,
        sorcery: 8
    },
    107: {
        consumecorpse: 5,
        defense: 9,
        leadership: 9,
        enlightenment: 9,
        dark: 6,
        sorcery: 7
    },
    8: {
        runeadv: 7,
        defense: 9,
        destructive: 11,
        light: 7,
        leadership: 9,
        luck: 10
    },
    108: {
        firelord: 5,
        attack: 7,
        defense: 10,
        leadership: 8,
        luck: 8,
        destructive: 6,
    },
    9: {
        memoryblood: 6,
        attack: 7,
        enlightenment: 9,
        leadership: 9,
        luck: 10,
        defense: 9
    },
    109: {
        absoluterage: 7,
        attack: 7,
        shout: 7,
        leadership: 9,
        luck: 10,
        defense: 12
    },
    10: {
        dayandnight: 7,
        attack: 8,
        defense: 10,
        leadership: 10,
        light: 6,
        dark: 6,
        sorcery: 9,
        enlightenment: 9
    }
};
addStyle(`
.button-62 {
  background: linear-gradient(to bottom right, #E47B8E, #FF9A5A);
  border: 0;
  border-radius: 5px;
  color: #FFFFFF;
  cursor: pointer;
  display: inline-block;
  font-family: -apple-system,system-ui,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  font-size: 16px;
  font-weight: 500;
  outline: transparent;
  padding: 0 5px;
  text-align: center;
  text-decoration: none;
  transition: box-shadow .2s ease-in-out;
  user-select: none;
  -webkit-user-select: none;
  touch-action: manipulation;
  white-space: nowrap;
}

.button-62:not([disabled]):focus {
  box-shadow: 0 0 .25rem rgba(0, 0, 0, 0.5), -.125rem -.125rem 1rem rgba(239, 71, 101, 0.5), .125rem .125rem 1rem rgba(255, 154, 90, 0.5);
}

.button-62:not([disabled]):hover {
  box-shadow: 0 0 .25rem rgba(0, 0, 0, 0.5), -.125rem -.125rem 1rem rgba(239, 71, 101, 0.5), .125rem .125rem 1rem rgba(255, 154, 90, 0.5);
}
.button-62:disabled,button[disabled] {
    background: linear-gradient(177.9deg, rgb(58, 62, 88) 3.6%, rgb(119, 127, 148) 105.8%);
}
.bar_wrap {
    width: 120px;
    /*margin: 3px 0 3px 9px;*/
    border: 1px solid #1C1C1C;
    background-color: #8C7526;
    box-shadow: 0 0 1px #666, inset 0 1px 1px #222;
    background-image: linear-gradient(#65541B, #8C7526 50%, #65541B);
    display: inline-block;
}
.bar {
    height: 5px;
    background-color: #f9e37e;
    border-right: 1px solid #282828;
    box-shadow: inset 0 0 1px #ddd;
    background-image: linear-gradient(#e7ae6b, #be8d55 50%, #a57b4b 51%, #ae804c);
    transition: all 1s ease;
    max-width: 150px;
}
.bar:hover {
    animation: animate-stripes 3s linear infinite;
}
@keyframes animate-stripes {
    0% {background-position: 0 0;}
    100% {background-position: 0 22px;}
}
.htooltip, .htooltip: visited, .tooltip: active {
    color: #0077AA;
    text-decoration: none;
}
.htooltip:hover {
    color: #0099CC;
}
.htooltip > span {
    background-color: rgba(0,0,0, 0.8);
    border-radius: 5px 5px 0px 0px;
    box-shadow: 1px 1px 5px rgba(0, 0, 0, 0.5);
    color: #fff;
    margin-left: -1px;
    margin-top: -24px;
    opacity: 0;
    padding: 2px 5px;
    position: absolute;
    text-decoration: none;
    visibility: hidden;
    z-index: 10;
    transition: opacity 0.4s ease-in-out, visibility 0.4s ease-in-out;
}
.htooltip:hover > span {
    position: absolute;
    opacity: 1;
    visibility: visible;
}
.htooltip1 > span:first-child {
    background-color: rgba(0,0,0, 0.8);
    border-radius: 5px 5px 0px 0px;
    box-shadow: 1px 1px 5px rgba(0, 0, 0, 0.5);
    color: #fff;
    margin-left: -1px;
    margin-top: -24px;
    opacity: 0;
    padding: 2px 5px;
    position: absolute;
    text-decoration: none;
    visibility: hidden;
    z-index: 10;
    transition: opacity 0.4s ease-in-out, visibility 0.4s ease-in-out;
}
.htooltip1:hover > span:first-child {
    position: absolute;
    opacity: 1;
    visibility: visible;
}
.progressContainer {
    position: absolute;
    border-radius: 7px;
    top: 10%;
    height: 80%;
    right: 0.1em;
    box-shadow: 0 0 1px #666, inset 0 1px 1px #222;
    background-image: linear-gradient(#65541B, #8C7526 50%, #65541B);
    overflow: hidden;
}
.progressContainer > div:first-child {
    position: absolute;
    left: 0;
    right: 0;
    height: 100%;
}
.progressContainer > div > div {
    display: flex;
    height: 100%;
    justify-content: center;
    align-items: center;
    color: white;
    text-shadow: 0px 0px 2px #000, 0px 0px 2px #000;
}
.progressContainer > div:last-child {
    border-radius: 7px;
    height: 100%;
    background-image: radial-gradient(ellipse farthest-corner at right, #FEDB37 0%, #FDB931 8%, #9f7928 30%, #8A6E2F 40%, transparent 80%),
                radial-gradient(ellipse farthest-corner at left top, #FFFFFF 0%, #FFFFAC 8%, #D1B464 25%, #5d4a1f 62.5%, #5d4a1f 100%);
}
`);
const skillsAndGuilds = {
    'Knight'               : 'Рыцарь',
    'Necromancer'          : 'Некромант',
    'Wizard'               : 'Маг',
    'Elf'                  : 'Эльф',
    'Barbarian'            : 'Варвар',
    'Dark elf'             : 'Темный эльф',
    'Demon'                : 'Демон',
    'Dwarf'                : 'Гном',
    'Steepe barbarian'     : 'Степной варвар',
    'Pharaoh'              : 'Фараон',
    'Combat level'         : 'Боевой уровень',
    'Hunters\' guild'      : 'Гильдия Охотников',
    'Laborers\' guild'     : 'Гильдия Рабочих',
    'Gamblers\' guild'     : 'Гильдия Картежников',
    'Thieves\' guild'      : 'Гильдия Воров',
    'Rangers\' guild'      : 'Гильдия Рейнджеров',
    'Mercenaries\' guild'  : 'Гильдия Наемников',
    'Commanders\' guild'   : 'Гильдия Тактиков',
    'Watchers\' guild'     : 'Гильдия Стражей',
    'Adventurers\' guild'  : 'Гильдия Искателей',
    'Leaders\' Guild'      : 'Гильдия Лидеров',
    'Smiths\' guild'       : 'Гильдия Кузнецов',
    'Enchanters\' guild'   : 'Гильдия Оружейников',
    'Enchanters'   : 'Оружейников'
};
function t(str) {
    if(lang == "ru") {
        const result = skillsAndGuilds[str];
        if(result) {
            return result;
        }
    }
    return str;
}
const fractions = isEn ? ["Knight", "Necromancer", "Wizard", "Elf", "Barbarian", "Dark elf", "Demon", "Dwarf", "Tribal", "Pharaoh"]
 : ["Рыцарь", "Некромант", "Маг", "Эльф", "Варвар", "Темный эльф", "Демон", "Гном", "Степной варвар", "Фараон", "Кавалер", "Зомби-призыватель", "Волшебник", "Лесной", "Дикарь", "Зловещая тень", "Адский хулиган", "Карлик", "Кочевник", "Кот-фараон"];
const genderReadsLimit = 15;
const scales = [
    [0, 0, 1500, 4500, 15E3, 32E3, 9E4, 19E4, 4E5, 86E4, 165E4, 3E6, 5E6, 85E5, 145E5, 25E6, 43E6, 7E7, 108E6, 16E7, 23E7, 325E6, 5E8, 8E8, 12E8, 2E9, 32E8], // Уровни
    [0, 20, 50, 90, 160, 280, 500, 900, 1600, 2900, 5300, 9600, 17300, 35E3, 7E4], // Умения
    [0, 16, 60, 180, 400, 700, 1200, 2E3, 3E3, 4300, 6E3, 8E3, 10500, 13100, 16000, 19500], // Охотник
    [0, 90, 180, 360, 720, 1500, 3E3, 5E3, 8E3, 12E3, 17E3, 23E3, 3E4, 38E3, 47E3, 57E3, 7E4, 9E4, 12E4], //Рабочий
    [0, 10, 30, 60, 100, 150, 210, 280, 360, 450, 550, 660, 800, 1E3, 1300, 2E3, 3E3, 6E3, 1E4, 17E3, 25E3], // Картежник
    [0, 50, 120, 240, 400, 600, 840, 1200, 2E3, 3E3, 4300, 6E3, 8E3, 10800, 14E3, 17600, 21600, 26E3, 30800, 36600, 43600, 52E3, 65E3], // Вор
    [0, 100, 240, 480, 800, 1200, 1680, 2400, 4E3, 6E3, 8600, 12E3, 16E3, 21600, 27800], // Рейнджер
    [0, 50, 120, 300, 600, 1E3, 1500, 2200, 3E3, 4E3, 5500, 7800, 11E3, 14500, 18200, 22200], // Наемник
    [0, 150, 350, 750, 1400, 2200, 3200, 4300, 5600, 7E3, 8500, 1E4, 11700, 14500], // Тактик
    [0, 60, 200, 450, 850, 1500, 2700, 4500, 7200, 10500, 14500], // Страж
    [0, 1600, 3600, 8100], // Искатель
    [0, 80, 180, 300, 440, 600, 780, 990, 1230, 1500, 2200, 3200, 4500, 7E3, 11E3], // Лидер
    [0, 30, 80, 165, 310, 555, 970, 1680, 2885, 5770], // Кузнец
    [0, 104, 588, 2200, 7E3, 1E4], // Оружейник
    [0, 8, 29, 71, 155, 295, 505, 799, 1191, 1695, 6E3, 12E3, 24E3]];
const transparent = '%3D%3D';
const bookImage = '\
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';
const is_firefox = navigator.userAgent.toLowerCase().indexOf('firefox') > -1;
let currentBookPage = 1;

main();
async function main() {
    if(location.pathname == '/home.php' || location.pathname == "/pl_info.php") {
        birthday();
        drowBars();
        if(location.pathname == '/home.php') {
            await getTalentsToHome();
        }
        if(location.pathname == "/pl_info.php") {
            saveGender();
            addPlayerInfoSpoilers();
            tavernAndRouletteBalances();
            talentsStatistics();
        }
        calcArmyHealth(); // После загрузки навыков, если она есть, чтоб обработать навык "vitality"
        showExpBar();
        setTimeout(function() {
            const talentsChanger = document.getElementById("hwmSetsMasterSkillSetSelectedValue");
            const armyChanger = document.getElementById("hwmSetsMasterArmySetSelectedValue");
            if(talentsChanger) {
                if(location.pathname == "/pl_info.php" && getUrlParamValue(location.href, "id") == PlayerId) {
                    observe([talentsChanger], talentsStatistics);
                }
                if(location.pathname == "/home.php" || location.pathname == "/pl_info.php" && getUrlParamValue(location.href, "id") == PlayerId) {
                    const panels = [armyChanger];
                    if(location.pathname == "/pl_info.php" && getUrlParamValue(location.href, "id") == PlayerId) {
                        panels.push(talentsChanger);
                    }
                    observe(panels, calcArmyHealth);
                }
            }
        }, 1500); // Здесь ждем загрузки hwmSetsMaster, чтоб подписаться на элемент hwmSetsMasterSkillSetSelectedValue и hwmSetsMasterArmySetSelectedValue
    }
    if(location.pathname == "/clan_info.php") {
        clanGenders();
        clanStatistics();
        clanRewards();
    }
    if(location.pathname == "/tournaments.php") {
        const currentTours = [...document.querySelectorAll("center > h2")].find(x => (x.innerText == (isEn ? "Current tournaments" : "Текущие турниры")));
        const filterByLevelSpan = addElement("span", { innerHTML: `&nbsp;<input id=filterByLevelCheckbox type=checkbox title="${isEn ? "Filter by level" : "Фильтровать по уровню"}">`, style: "font-size: 12px;" }, currentTours);
        const filterByLevelCheckbox = filterByLevelSpan.querySelector("#filterByLevelCheckbox");
        filterByLevelCheckbox.checked = getPlayerBool("filterToursByLevel");
        filterByLevelCheckbox.addEventListener("change", function() { setPlayerValue("filterToursByLevel", this.checked); applyToursFilter(); });
        applyToursFilter();
    }
    if(location.pathname == "/transfer.php") {
        const clanRewardReceiver = getPlayerValue("clanRewardReceiver");
        if(clanRewardReceiver) {
            const nickInput = document.querySelector("input[name=nick]");
            nickInput.value = clanRewardReceiver;
            deletePlayerValue("clanRewardReceiver");
            
            const clanReward = getPlayerValue("clanReward");
            const goldInput = document.querySelector("input[name=gold]");
            goldInput.value = clanReward;
            deletePlayerValue("clanReward");
            
            const descInput = document.querySelector("input[name=desc]");
            descInput.value = isEn ? "Event reward" : "Награда за ивент"
        }
    }
}
async function clanRewards() {
    if(location.pathname == "/clan_info.php") {
        addStyle(`.clan-reward-cell {color: green; text-align: right; cursor: pointer; margin-left: 0.5em;}`);
        // Расчет клановых наград
        let clanHeroesTable = document.querySelector("body>center>table>tbody>tr>td>table>tbody>tr>td>table.wb:nth-of-type(2)");
        const clanActivity = clanHeroesTable.querySelector("tr > td:nth-child(2) > img[src$='clans/online.gif']") || clanHeroesTable.querySelector("tr > td:nth-child(2) > img[src$='clans/offline.gif']");
        let eventResultColumnNumber = clanActivity ? 6 : 5;
        if(eventResultColumnNumber > clanHeroesTable.rows[0].cells.length) {
            return;
        }
        const prizeFundLabel = addElement("label", { for: "prizeFundAmountInput", innerText: isEn ? "Prize fund" : "Призовой фонд" }, clanHeroesTable, "beforebegin");
        const prizeFundAmountInput = addElement("input", { id: "prizeFundAmountInput", type: "number", onfocus: "this.select();", value: getPlayerValue("prizeFundAmount", 0), style: "text-align: right; width: 100px;" }, clanHeroesTable, "beforebegin");
        prizeFundAmountInput.addEventListener("change", function() { setPlayerValue("prizeFundAmount", this.value); calcRewards(); });

        const prizeFundPlayersAmountLabel = addElement("label", { for: "prizeFundPlayersAmountInput", innerText: isEn ? "Number of participants" : "Количество участников" }, clanHeroesTable, "beforebegin");
        const prizeFundPlayersAmountInput = addElement("input", { id: "prizeFundPlayersAmountInput", type: "number", onfocus: "this.select();", value: getPlayerValue("prizeFundPlayersAmount", 100), style: "text-align: right; width: 100px;" }, clanHeroesTable, "beforebegin");
        prizeFundPlayersAmountInput.addEventListener("change", function() { setPlayerValue("prizeFundPlayersAmount", this.value); calcRewards(); });
        
        await sleep(300);
        clanHeroesTable = document.querySelector("body>center>table>tbody>tr>td>table>tbody>tr>td>table.wb:nth-of-type(2)");
        calcRewards();
        observe(clanHeroesTable, calcRewards);
    }
}
function calcRewards() {
    const prizeFundAmount = Number(getPlayerValue("prizeFundAmount", 0));
    if(prizeFundAmount > 0) {
        const clanHeroesTable = document.querySelector("body>center>table>tbody>tr>td>table>tbody>tr>td>table.wb:nth-of-type(2)");
        if(!clanHeroesTable) {
            return;
        }
        const clanActivity = clanHeroesTable.querySelector("tr > td:nth-child(2) > img[src$='clans/online.gif']") || clanHeroesTable.querySelector("tr > td:nth-child(2) > img[src$='clans/offline.gif']");
        let eventResultColumnNumber = clanActivity ? 6 : 5;
        if(eventResultColumnNumber > clanHeroesTable.rows[0].cells.length) {
            return;
        }
        const numberRe = new RegExp(`([\\d,]+)`);
        let eventResults = [...clanHeroesTable.querySelectorAll(`:scope>tbody>tr>td:nth-of-type(${eventResultColumnNumber}):has(b)`)].map(x => { const ex = numberRe.exec(x.innerHTML.replace(/,/g, "")); return { cell: x, result: Number(ex ? ex[1] : "") }; });
        const prizeFundPlayersAmount = Number(getPlayerValue("prizeFundPlayersAmount", 100));
        if(prizeFundPlayersAmount < 100) {
            eventResults.sort(sortBy("result", true));
            eventResults.slice(prizeFundPlayersAmount).forEach(x => { x.result = 0; }); //eventResults = eventResults.slice(0, prizeFundPlayersAmount);
        }
        //console.log(eventResults);
        const totalPoints = eventResults.reduce((t, x) => t + x.result, 0);
        eventResults.forEach(x => {
            let rewardBold = x.cell.querySelector("b[name=rewardBold]");
            if(rewardBold) {
                rewardBold.remove();
            }
            if(x.result > 0) {
                rewardBold = addElement("b", { name: "rewardBold", innerText: Math.round(prizeFundAmount / totalPoints * x.result).toLocaleString(), title: isEn ? "Event reward. Send?" : "Награда за ивент. Передать?", class: "clan-reward-cell" }, x.cell);
                rewardBold.addEventListener("click", function() {
                    const row = this.closest("tr");
                    const playerRef = row.querySelector("td>a[href^='pl_info.php?id=']");
                    const playerName = playerRef.innerText;
                    setPlayerValue("clanRewardReceiver", playerName);
                    setPlayerValue("clanReward", this.innerText.replace(/\s/g, ""));
                    //console.log(`playerName: ${playerName}, clanReward: ${this.innerText.replace(/\s/g, "")}`);
                    window.open("/transfer.php", "_blank");
                });
            }
        });
    }
}
function applyToursFilter() {
    [...document.querySelectorAll("td > b > font")].filter(x => x.closest("td").innerHTML.includes(isEn ? "Participants level" : "Уровень участников")).forEach(x => {
        x.closest("table").style.display = getPlayerBool("filterToursByLevel") ? "none" : "";
    });
}
async function getTalentsToHome() {
    if(location.pathname == '/home.php') {
        const playerLevel = getViewingPlayerLevel();
        if(playerLevel < 5) {
            return;
        }
        let hwmAdvancedPlayerInfoTalentsContainer = document.getElementById("hwmAdvancedPlayerInfoTalentsContainer");
        if(!hwmAdvancedPlayerInfoTalentsContainer) {
            if(isNewPersonPage) {
                const homePageTalentsContainer = document.querySelector("div.home_friends_block");
                if(!homePageTalentsContainer) {
                    return;
                }
                homePageTalentsContainer.insertAdjacentHTML("afterend", `<div class="home_container_block" style="align-items: left;">
            <div class="global_container_block_header global_a_hover">
                <span id=hwmAdvancedPlayerInfoTalentsCaptionContainer title="${getShowTalentsTitleSpanTitle()}"><b>${isEn ? "Talents" : "Навыки"}:</b><b id="hwmAdvancedPlayerInfoTalentsPointsContainer"></b></span>
            </div>
            <div id=hwmAdvancedPlayerInfoTalentsContainer class="home_inside_margins global_a_hover">
            </div>
        </div>`);
            } else {
                const combatLevelCell = document.querySelector("body > center > table:nth-child(2) > tbody > tr:nth-child(1) > td:nth-child(1) > table > tbody > tr:nth-child(2) > td:nth-child(1) > table > tbody > tr > td > table > tbody > tr > td");
                if(!combatLevelCell) {
                    return;
                }
                let html = `<br>
                <span id=hwmAdvancedPlayerInfoTalentsCaptionContainer title="${getShowTalentsTitleSpanTitle()}">&nbsp;&raquo;&nbsp;<b>${isEn ? "Talents" : "Навыки"}:</b><b id="hwmAdvancedPlayerInfoTalentsPointsContainer"></b></span>
                <br>
                <div id=hwmAdvancedPlayerInfoTalentsContainer></div>
`;
                const cellBreaked = combatLevelCell.querySelector(":scope>div") ? true : false;
                if(cellBreaked) {
                    html = html.split("<br>").map(x => `<div>${x}</div>`).filter(x => x).join("");
                }
                combatLevelCell.insertAdjacentHTML("beforeend", html);
            }
            document.getElementById("hwmAdvancedPlayerInfoTalentsCaptionContainer").addEventListener("click", function() { setValue("ShowTalents", !getBool("ShowTalents")); this.title = getShowTalentsTitleSpanTitle(); getTalentsToHomeCore(); });
        }
        await getTalentsToHomeCore();
        const talentsChanger = document.getElementById("hwmSetsMasterSkillSetSelectedValue");
        if(talentsChanger) {
            observe([talentsChanger], getTalentsToHomeCore);
            //setTimeout(function() { observe([talentsChanger], getTalentsToHomeCore); }, 3000);
        }
    }
}
async function getTalentsToHomeCore() {
    if(location.pathname == '/home.php' && getBool("ShowTalents")) {
        const doc = await getRequest(`/pl_info.php?id=${PlayerId}`);
        const perksTable = getParent(doc.querySelector("a[href^='showperkinfo.php']"), "table", 2);
        if(perksTable) {
            Array.from(perksTable.querySelectorAll("a[href^='showperkinfo.php'] > img")).forEach(x => { x.style.width = `48px`; x.style.height = "auto"; });
            //Array.from(perksTable.querySelectorAll("a[href^='showperkinfo.php'] > img")).forEach(x => { x.setAttribute("title", x.getAttribute("hint")); x.style.width = `48px`; x.style.height = "auto"; });
            document.getElementById("hwmAdvancedPlayerInfoTalentsContainer").innerHTML = perksTable.outerHTML;
            if(typeof win.hwm_hints_init === 'function') win.hwm_hints_init();
            talentsStatistics();
            calcArmyHealth();
        }
    }
}
function getShowTalentsTitleSpanTitle() { return isEn ? `Click for ${getBool("ShowTalents") ? "disable" : "enable"} talents loading` : `Нажмите для ${getBool("ShowTalents") ? "выключения" : "включения"} загрузки навыков`; }
function talentsStatistics() {
    const playerLevel = getViewingPlayerLevel();
    if(playerLevel < 5) {
        initSpellBook([[]]);
        return;
    }
    let talentsContainer;
    let talentsCaptionContainer;
    let talentsPointsContainer;
    if(location.pathname == "/home.php") {
        talentsContainer = document.getElementById("hwmAdvancedPlayerInfoTalentsContainer");
        talentsCaptionContainer = document.getElementById("hwmAdvancedPlayerInfoTalentsCaptionContainer");
        talentsPointsContainer = document.getElementById("hwmAdvancedPlayerInfoTalentsPointsContainer");
    }
    if(location.pathname == "/pl_info.php") {
        talentsContainer = getParent(document.querySelector("a[href^='showperkinfo.php?name=']"), "td", 3);
        const layerTable = getParent(talentsContainer, "table");
        if(layerTable) {
            talentsCaptionContainer = Array.from(layerTable.rows[0].cells).find(x => x.innerHTML.includes(isEn ? "Talents" : "Навыки")).querySelector("b");
        }
        talentsPointsContainer = document.getElementById("hwmAdvancedPlayerInfoTalentsPointsContainer") || addElement("span", { id: "hwmAdvancedPlayerInfoTalentsPointsContainer" }, talentsCaptionContainer);
    }
    if(!talentsContainer || !talentsCaptionContainer) {
        initSpellBook([[]]);
        return;
    }
    const talentBranchRows = talentsContainer.querySelectorAll(":scope > table > tbody > tr");
    const playerTalentBranches = Array.from(talentBranchRows).map(x => Array.from(x.querySelectorAll("a[href^='showperkinfo.php?name=']")).map(y => getUrlParamValue(y.href, "name")));
    //console.log(playerTalentBranches);
    let talentPoints = 0;
    const playerFraction = getPlayerFraction();
    const playerPerkBranchCosts = perkBranchCosts[playerFraction];
    //console.log(playerPerkBranchCosts);
    for(const playerPerkBranche of playerTalentBranches) {
        let branchName = playerPerkBranche[0];
        let firstPerkPromout = 1;
        if(["1", "2", "3"].includes(branchName.slice(-1))) {
            firstPerkPromout = parseInt(branchName.slice(-1));
            branchName = branchName.slice(0, -1);
        }
        //console.log(`branchName: ${branchName}, branchCost: ${playerPerkBranchCosts[branchName]}, branchePerks: ${playerPerkBranche.length}, firstPerkPromout: ${firstPerkPromout}`);
        talentPoints += playerPerkBranchCosts[branchName] * (playerPerkBranche.length + firstPerkPromout - 1);
    }
    talentsPointsContainer.innerText = ` (${isEn ? "points" : "очки"} ${talentPoints} ${isEn ? "from" : "из"} ${10 + 5 * (playerLevel - 5)})`;
    initSpellBook(playerTalentBranches);
}
function calcArmyHealth() {
    let armyContainer;
    if(location.pathname == "/pl_info.php") {
        armyContainer = getParent(document.querySelector(".cre_creature72"), "center");
    }
    if(location.pathname == "/home.php") {
        if(isNewPersonPage) {
            armyContainer = document.querySelector("div.home_css_creature_list");
        } else {
            armyContainer = getParent(document.querySelector(".cre_creature72"), "center");
        }
    }
    if(!armyContainer) {
        return;
    }
    const creatures = Array.from(document.querySelectorAll(`div.${isNewPersonPage ? "castle_creature54" : "cre_creature72"}`)).filter(x => x.querySelector("div#add_now_count")).map(x => ({ Name: getUrlParamValue(x.querySelector("a[href^='army_info.php?name=']").href, "name"),  Amount: parseInt(x.querySelector("div#add_now_count").innerText) }));
    const hasVitality = document.querySelector("a[href='showperkinfo.php?name=vitality']") ? true : false;
    const sum = creatures.reduce((t, x) => {
        const army = unitsHealth[x.Name];
        if(army) {
            t += x.Amount * (army[1] + (hasVitality ? 2 : 0));
        }
        return t;
    }, 0);
    const unknownCreatures = creatures.filter(x => !unitsHealth[x.Name]);
    let unknownCreaturesMessage = "";
    if(unknownCreatures.length > 0) {
        unknownCreaturesMessage = isEn ? `Creatures not found: ${unknownCreatures.map(x => x.Name).join(', ')}. Please, contact developer.` : `Существа не найдены: ${unknownCreatures.map(x => x.Name).join(', ')}. Пожалуйста, сообщите разработчику.`;
    }
    let hwmAdvancedPlayerInfoArmyHealthContainer = document.getElementById("hwmAdvancedPlayerInfoArmyHealthContainer");
    if(!hwmAdvancedPlayerInfoArmyHealthContainer) {
        armyContainer.insertAdjacentHTML("afterend", `&nbsp;»&nbsp;<b>${isEn ? "Total HP" : "Общее HP"}:&nbsp;</b><span id=hwmAdvancedPlayerInfoArmyHealthContainer>${sum}</span>
<a id=hwmAdvancedPlayerInfouUknownCreaturesMessageContainer href="javascript:alert('${unknownCreaturesMessage}');" title="${unknownCreaturesMessage}"> (?)</a>`);
        hwmAdvancedPlayerInfoArmyHealthContainer = document.getElementById("hwmAdvancedPlayerInfoArmyHealthContainer");
    }
    hwmAdvancedPlayerInfoArmyHealthContainer.innerText = sum;
    hwmAdvancedPlayerInfoArmyHealthContainer.style.color = hasVitality ? "#ff0000" : "";
    const hwmAdvancedPlayerInfouUknownCreaturesMessageContainer = document.getElementById("hwmAdvancedPlayerInfouUknownCreaturesMessageContainer");
    hwmAdvancedPlayerInfouUknownCreaturesMessageContainer.style.display = unknownCreaturesMessage ? "" : "none";
    hwmAdvancedPlayerInfouUknownCreaturesMessageContainer.title = unknownCreaturesMessage;
    hwmAdvancedPlayerInfouUknownCreaturesMessageContainer.href = `javascript:alert('${unknownCreaturesMessage}');`;
}
function tavernAndRouletteBalances() {
    if(location.pathname != "/pl_info.php") {
        return;
    }
    // Баланс рулетки
    const rouletteDebitText = findChildrenTextContainsValue("td", isEn ? "Roulette bets total" : "Поставлено в рулетке");
    const rouletteCreditText = findChildrenTextContainsValue("td", isEn ? "Roulette winnings total" : "Выиграно в рулетке");
    if(rouletteDebitText.length == 1 && rouletteCreditText.length == 1 && rouletteDebitText[0].nextSibling.tagName.toLowerCase() == "b" && rouletteCreditText[0].nextSibling.tagName.toLowerCase() == "b") {
        const rouletteBalance = rouletteCreditText[0].nextSibling.innerText.replace(/,/g, "") - rouletteDebitText[0].nextSibling.innerText.replace(/,/g, "");
        rouletteCreditText[0].nextSibling.insertAdjacentHTML("afterend", `<br>&nbsp;&nbsp;${isEn ? 'Balance' : 'Баланс'}: <b>${rouletteBalance.toLocaleString()}</b>`);
    }
    // Баланс таверны
    var statisticsSecondCell = getParent(document.querySelector("td.wb > a[href^='pl_transfers.php?id']"), "td").nextSibling;
    var tavern_parent = statisticsSecondCell.querySelector("tr").parentNode.childNodes[0].childNodes[1].firstChild.firstChild.childNodes;
    const winsRow = tavern_parent[1];
    const failsRow = tavern_parent[2];
    tavern_parent[0].childNodes[1].setAttribute('style', 'white-space: nowrap;');
    winsRow.childNodes[1].setAttribute('style', 'white-space: nowrap;');
    //console.log(winsRow)
    failsRow.childNodes[1].setAttribute('style', 'white-space: nowrap;');
    var tavern_0bal = winsRow.querySelector("tr");
    var tavern_1bal = failsRow.querySelector("tr");
    if(!tavern_0bal && !tavern_1bal) return;
    let wins = 0;
    let fails = 0;
    let totalRow;
    if(tavern_0bal) {
        wins = parseInt(winsRow.cells[1].querySelector("b").innerText.replace(/,/g, ""));
        tavern_0bal.childNodes[1].setAttribute('style', 'text-align: right; padding-right: 5px;');
        tavern_0bal = tavern_0bal.childNodes[1].innerHTML.replace(/,/g, "");
        winsRow.childNodes[3].firstChild.width = "100%";
        totalRow = winsRow.cloneNode(true);
    } else {
        tavern_0bal = 0;
    }
    if(tavern_1bal) {
        fails = parseInt(failsRow.cells[1].querySelector("b").innerText.replace(/,/g, ""));
        tavern_1bal.childNodes[1].setAttribute('style', 'text-align: right; padding-right: 5px;');
        tavern_1bal = tavern_1bal.childNodes[1].innerHTML.replace(/,/g, "");
        failsRow.childNodes[3].firstChild.width = "100%";
        totalRow = totalRow || failsRow.cloneNode(true);
    } else {
        tavern_1bal = 0;
    }
    var tavern_bal = tavern_0bal - tavern_1bal;
    totalRow.firstChild.innerHTML = `&nbsp;&nbsp;${isEn ? 'Balance:' : 'Баланс:'}`;
    totalRow.childNodes[1].innerHTML = `<b>${(wins - fails).toLocaleString()}</b>`;
    totalRow.childNodes[2].innerHTML = "&nbsp;";
    totalRow.childNodes[3].innerHTML = `
<table border="0" cellspacing="0" cellpadding="0" width="100%">
    <tbody>
        <tr>
            <td>
                <img class="rs" width="24" height="24" src="https://dcdn2.heroeswm.ru/i/r/48/gold.png?v=3.23de65" border="0" title="${isEn ? "Gold" : "Золото"}" alt="">
            </td>
            <td style="text-align: right; padding-right: 5px;">
            ${tavern_bal.toLocaleString()}
            </td>
        </tr>
    </tbody>
</table>`;
    failsRow.insertAdjacentElement("afterend", totalRow);
}
function birthday() {
    if(location.pathname == "/pl_info.php") {
        const playerId = getUrlParamValue(location.href, "id");
        let bifthday = GM_getValue(`PlayerBifthday${playerId}`, "");
        const districtBold = Array.from(document.querySelectorAll("b")).find(x => x.innerHTML.includes(isEn ? "Location" : "Район"));
        if(districtBold) {
            districtBold.nextElementSibling.nextElementSibling.insertAdjacentHTML("afterend", `&nbsp;&raquo;&nbsp;<b id=hwmAdvancedPlayerInfoBirthdayCaption title="${isEn ? "Click to download birthday" : "Нажмите для загрузки дня рождения"}">${isEn ? "Birthday" : "День рождения"}: </b><span id=hwmAdvancedPlayerInfoBirthday>${bifthday}</span>`);
            document.getElementById("hwmAdvancedPlayerInfoBirthdayCaption").addEventListener("click", loadBirthday);
        }
    }
}
function clanGenders() {
    if(location.pathname == "/clan_info.php") {
        // Пол игроков
        const clanHeroesTable = document.querySelector("body>center>table>tbody>tr>td>table>tbody>tr>td>table.wb:nth-of-type(2)");
        const showGenderCheckbox = addElement("input", { id: "showGenderCheckbox", type: "checkbox", title: isEn ? "Show players gender" : "Показывать пол игроков" }, clanHeroesTable, "beforebegin");
        showGenderCheckbox.checked = getPlayerBool("showPlayersGender");
        showGenderCheckbox.addEventListener("change", function() { setPlayerValue("showPlayersGender", this.checked); showGender(); });
        showGender();
        const refreshStatisticsButtonStyle = "display: inline-block; width: fit-content;" + (true ? " max-height: 16px; vertical-align: middle; line-height: 16px;" : "");
        const refreshClanPlayersGenderButton = addElement("div", { id: "refreshClanPlayersGenderButton", class: "home_button2 btn_hover2", innerHTML: '&#8635;', title: isEn ? `Refresh next ${genderReadsLimit} clan players gender` : `Обновить пол следующих ${genderReadsLimit} игроков клана`, style: refreshStatisticsButtonStyle }, clanHeroesTable, "beforebegin");
        refreshClanPlayersGenderButton.addEventListener("click", async function(e) { await refreshClanPlayersGender(e); showGender(); });
    }
}
function saveGender(doc = document, playerId = getUrlParamValue(location.href, "id")) {
    if(location.pathname == "/pl_info.php" || doc != document) {
        const femalePng = doc.querySelector("body > center > table img[src$='female.png']");
        setValue(`PlayerGender${playerId}`, femalePng ? "w" : "m");//        console.log(`PlayerGender${playerId}: ${getValue(`PlayerGender${playerId}`, "u")}`);
    }
}
function showGender() {
    if(location.pathname == "/clan_info.php") {
        const clanHeroesTable = document.querySelector("body>center>table>tbody>tr>td>table>tbody>tr>td>table.wb:nth-of-type(2)");
        if(!clanHeroesTable) {
            return;
        }
        const playerRefs = [...clanHeroesTable.querySelectorAll("a[href^='pl_info.php?id=']")];
        for(const playerRef of playerRefs) {
            const playerId = getUrlParamValue(playerRef.href, "id");
            const gender = getValue(`PlayerGender${playerId}`);
            if(gender) {
                const cell = playerRef.closest("td");
                let playerGenderImage = cell.querySelector("img[name=playerGenderImage]");
                if(!playerGenderImage) {
                    //<img class="show_hint" src="https://dcdn2.heroeswm.ru/i/male.png" width="24" height="24" border="0" hint="муж." align="right" hwm_hint_added="1">
                    const hint = isEn ? (gender == "m" ? "male" : "female") : (gender == "m" ? "муж." : "жен.");
                    playerGenderImage = addElement("img", { name: "playerGenderImage", src: `https://dcdn2.heroeswm.ru/i/${gender == "m" ? "male" : "female"}.png`, class: "show_hint", title: hint, style: "width: 14px; height: 14px; vertical-align: middle;"}, playerRef, "beforebegin");
                }
                playerGenderImage.style.display = getPlayerBool("showPlayersGender") ? "inline-block" : "none"; //               console.log(playerGenderImage);                console.log(`${playerId}, display: ${playerGenderImage.style.display}`);
            }
        }
        //if(typeof win.hwm_hints_init === 'function') win.hwm_hints_init();
    }
}
async function refreshClanPlayersGender(e) {
    if(location.pathname == "/clan_info.php") {
        const clanHeroesTable = document.querySelector("body>center>table>tbody>tr>td>table>tbody>tr>td>table.wb:nth-of-type(2)");
        if(!clanHeroesTable) {
            return;
        }
        const playerRefs = [...clanHeroesTable.querySelectorAll("a[href^='pl_info.php?id=']")];
        let step = 1;
        let reads = 0;
        for(const playerRef of playerRefs) {
            const playerId = getUrlParamValue(playerRef.href, "id");
            const gender = getValue(`PlayerGender${playerId}`);
            if(!gender) {
                const doc = await getRequest(playerRef.href);
                saveGender(doc, playerId);
                e.target.innerHTML = step;
                reads++;
            }
            step++;
            if(reads >= genderReadsLimit) {
                break;
            }
        }
        e.target.innerHTML = '&#8635;';
    }
}
async function loadBirthday() {
    const playerId = getUrlParamValue(location.href, "id");
    const firstProtocolPage = await getRequest(`/pl_transfers.php?id=${playerId}&page=50000`);
    const lines = firstProtocolPage.querySelector(`div#set_mobile_max_width > div > div`).innerHTML.split("<br>").filter(x => x != "");
    let bifthday = lines[lines.length - 2];
    bifthday = bifthday.replace(/&nbsp;/g, "");
    setValue(`PlayerBifthday${playerId}`, bifthday);
    document.getElementById("hwmAdvancedPlayerInfoBirthday").innerHTML = bifthday;
}
function showExpBar() {
    if(location.pathname != '/home.php' && location.pathname != '/pl_info.php') {
        return;
    }
    const player = getPlayerData();
    let skillInfoCell = player?.skillInfoCell;
    if(!skillInfoCell) {
        return;
    }
    if(player.Level > 2) {
        //console.log(`isNewPersonPage: ${isNewPersonPage}`)
        const playerPersents = getPlayerPercents(player);
        //console.log(playerPersents);
        let resumeText = "В норме!";
        let resumeTitle = "";
        const prevEdgeSpan = getSpanHtml(playerPersents.prevEdge, playerPersents.prevEdgeClarification);
        const totalPointsSpan = getSpanHtml(player.TotalPoints, isEn ? "Player points" : "Очков игрока");
        const guildStatsNumberSpan = getSpanHtml(player.GuildStatsNumber, isEn ? "total guilds parameters" : "сумма параметров от всех гильдий");
        const skillSumSpan = getSpanHtml(player.SkillSum, isEn ? `total factions skill levels (${player.TotalSkillLevel}) * 0.25` : `сумма уровней умений фракций (${player.TotalSkillLevel}) * 0.25`);
        const mainSkillStatsNumberSpan = getSpanHtml(player.MainSkillStatsNumber, isEn ? "max faction skill level parameters (with possible faction potion)" : "сумма параметров от максимального умения фракции(с учётом возможного применения \"зелья фракции\")");
        const nextEdgeSpan = getSpanHtml(playerPersents.nextEdge, playerPersents.nextEdgeClarification);
        const progressText = `${isEn ? "Main progress" : "Основной прогресс"}: ${playerPersents.normalPercent}%. ${prevEdgeSpan}->${totalPointsSpan}=(${guildStatsNumberSpan}+${skillSumSpan}+${mainSkillStatsNumberSpan})->${nextEdgeSpan}`;
        if(playerPersents.advacedPersent > 0){
            resumeText = `Перекач! ${isEn ? "Exp" : "Опыт"}: +${playerPersents.advacedPersent}%`;
            //resumeTitle = `${isEn ? "More experience" : "Опыта больше на"}: ${playerPersents.advacedPersent}%`;
        }
        if(playerPersents.advacedPersent < 0) {
            resumeText = `Недокач!`;
            resumeTitle = `${isEn ? "more skill points will be awarded in proportion to the missing points" : "будет начисляться больше очков умений в соотношении к недостающим очкам"}`;
        }
        const resumeSpan = getSpanHtml(resumeText, resumeTitle);
        if(isNewPersonPage) {
            const ratioSpan = getSpanHtml(player.Ratio.toLocaleString(), isEn ? "Expirience points to one skill point" : "Очков опыта на одно очко умения");
            skillInfoCell.querySelector("div.home_inside_margins").insertAdjacentHTML("beforeend", `
<div class="home_scroll_content" id="row" onclick="show_all_hwm_exp();">
    <span class="home_guild_text">${isEn ? "Total skills" : "Сумма умений"}</span> <div class="home_text_exp" style="display: block;">${player.TotalSkills.toLocaleString()} (${ratioSpan})</div>
</div>
<div class="home_scroll_content htooltip1" id="row" onclick="show_all_hwm_exp();">
    <span>${progressText}</span>
    <span class="home_guild_text">${isEn ? "Progress" : "Прогресс"}
    <div id="bar" class="home_bar_exp" style="opacity: 1;"><div id="barprogress" style="width: ${playerPersents.normalPercent}%;"></div></div>
    <div class="home_text_exp" style="display: block;">${playerPersents.normalPercent}% ${resumeSpan}</div>
`);
        } else {
            let html = `
<span id=hwmAdvancedPlayerInfoTotalSkillsSpan>
    &nbsp;&raquo;&nbsp;<b>${isEn ? "Skills count" : "Сумма умений"}: </b>${player.TotalSkills.toLocaleString()}, ${isEn ? "ratio" : "соотношение"}: <span title="${isEn ? "Expirience points to one skill point" : "Очков опыта на одно очко умения"}">${ player.Ratio.toLocaleString() }</span>
</span>
<br>&nbsp;&raquo;&nbsp;<b>${isEn ? "Progress" : "Прогресс"}:</b> <div class="bar_wrap htooltip">
    <div class="bar" style="width: ${playerPersents.normalPercent}%"></div>
    <span>${progressText}</span>
</div>
<div style='font-size: 8px; font-weight: bold; display: inline-block;'>${playerPersents.normalPercent}% ${resumeSpan}</div>`;
            const combatLevelCell = getParent(Array.from(document.querySelectorAll("td>b, td>div>b")).find(x => x.innerHTML.includes(isEn ? "Combat level:" : "Боевой уровень:")), "td");// console.log(combatLevelCell);
            let anchor = combatLevelCell.querySelector(":scope>br");
            const cellBreaked = anchor ? false : true;
            if(cellBreaked) {
                anchor = combatLevelCell.querySelector("div");
                html = html.split("<br>").map(x => `<div>${x}</div>`).join("");
            }
            anchor.insertAdjacentHTML("afterend", html);
        }
    }
}
function getPlayerData() {
    if(location.pathname != '/home.php' && location.pathname != '/pl_info.php') {
        return;
    }
    const player = { SkillLevel: [], SkillNumber: [], Expirience: 0 };
    let skillInfoCell;
    if(isNewPersonPage) {
        const levelInfoCell = Array.from(document.querySelectorAll("div.home_pers_info")).find(x => x.innerHTML.includes(t('Combat level')));
        if(!levelInfoCell) {
            return;
        }
        player.Level = parseInt(levelInfoCell.querySelector("div[id=bartext] > span").innerText);
        player.Expirience = parseInt(levelInfoCell.querySelector("div.home_text_exp").firstChild.textContent.replace(/,/g, ""));

        const homeContainerBlocks = Array.from(document.querySelectorAll("div#set_mobile_max_width > div > div.home_container_block"));
        //console.log(homeContainerBlocks)
        skillInfoCell = homeContainerBlocks.find(x => x.innerHTML.includes(t('Knight')) || x.innerHTML.includes('Кавалер'));
        Array.from(skillInfoCell.querySelectorAll("div[id=row]")).forEach((x, i) => {
            player.SkillLevel[i] = parseInt(x.querySelector("div#bartext span").innerText);
            player.SkillNumber[i] = parseFloat(x.querySelector("div.home_text_exp").firstChild.textContent);
        });
        const guildsDiv = homeContainerBlocks.find(x => x.innerHTML.includes(t('Enchanters')));
        Array.from(guildsDiv.querySelectorAll("div[id=row]")).forEach(x => {
            const key = findKey(skillsAndGuilds, y => t(y).includes(x.querySelector("span.home_guild_text").innerText));
            if(key) {
                player[key] = parseInt(x.querySelector("div#bartext span").innerText);
            }
        });
    } else {
        const levelInfoBold = Array.from(document.querySelectorAll("td>b, td>div>b")).find(x => x.innerHTML.includes(t('Combat level')));
        if(!levelInfoBold) {
            return;
        }
        player.Level = getLevel();
        const expirienceRegex = /\(([\d\.\,]+)\)/g;
        const expirienceRegexExec = expirienceRegex.exec(levelInfoBold.parentNode.innerHTML);
        if(expirienceRegexExec) {
            player.Expirience = parseInt(expirienceRegexExec[1].replace(/,/g, ""));
        }
        skillInfoCell = Array.from(document.querySelectorAll("td:not(:has(td))")).find(x => (x.innerHTML.includes(t('Knight')) || x.innerHTML.includes('Кавалер')) && x.innerHTML.includes(t('Enchanters')));
        const regex = /\(([\d\.\,]+)\)/g;
        for(const fraction of fractions) {
            const skillRegex = new RegExp(`${fraction}: (\\d{1,2})`);
            const skillsData = skillRegex.exec(skillInfoCell.innerHTML);
            if(!skillsData) {
                continue;
            }
            player.SkillLevel.push(parseInt(skillsData[1]));
            const skillsNumberData = regex.exec(skillInfoCell.innerHTML);
            let skillNumber = 0;
            if(skillsNumberData) {
                skillNumber = parseFloat(skillsNumberData[1]);
            }
            player.SkillNumber.push(skillNumber);
        }
        for(const key of Object.keys(skillsAndGuilds).filter(x => x.includes("guild") || x.includes("Guild"))) {
            const guildName = t(key);
            const shortGuildName = guildName.replace("Гильдия ", "").replace("' guild", "");
            let guildRegex = new RegExp(`&nbsp;&nbsp;${guildName}: (\\d{1,2}) \\(`, "g");
            let shortGuildRegex = new RegExp(`&nbsp;&nbsp;${shortGuildName}: (\\d{1,2}) \\(`, "g");
            if(key == 'Hunters\' guild') {
                guildRegex = new RegExp(`&nbsp;&nbsp;${guildName}: .+>(\\d{1,2})<`, "g");
                shortGuildRegex = new RegExp(`&nbsp;&nbsp;${shortGuildName}: .+>(\\d{1,2})<`, "g");
            }
            player[key] = parseInt((guildRegex.exec(skillInfoCell.innerHTML) || shortGuildRegex.exec(skillInfoCell.innerHTML))[1]);
        }
    }
    player.GuildStatsNumber = getGuildStatsNumber(player);
    player.MainSkillStatsNumber = getMainSkillStatsNumber(player);
    player.TotalSkillLevel = player.SkillLevel.reduce((t, x) => t + x, 0);
    player.SkillSum = Math.floor(player.TotalSkillLevel * 0.25);
    player.TotalPoints = player.GuildStatsNumber + player.MainSkillStatsNumber + player.SkillSum;
    player.TotalSkills = round00(player.SkillNumber.reduce((t, x) => t + x, 0));
    player.Ratio = player.TotalSkills > 0 ? Math.round(player.Expirience / player.TotalSkills) : 0;
    player.skillInfoCell = skillInfoCell;
    //console.log(player);
    return player;
}
function getLevel(doc = document) {
    const levelInfoBold = Array.from(doc.querySelectorAll("td>b, td>div>b")).find(x => x.innerHTML.includes(t('Combat level')));
    if(levelInfoBold) {
        const levelRegex = new RegExp(`${t('Combat level')}: (\\d{1,2})`);
        return parseInt(levelRegex.exec(levelInfoBold.innerHTML)[1]);
    }
}
function getFraction(doc = document) {
    const fractionImage = doc.querySelector("td>b>img[src*='/i/f/r']");
    if(fractionImage) {
        const fractionRegex = new RegExp(`/i/f/r(\\d{1,3}).png`);
        return parseInt(fractionRegex.exec(fractionImage.src)[1]);
    }
}
function getPlayerParameters() {
    if(location.pathname == "/pl_info.php") {
        const statsTable = getParent(document.querySelector("table img[src*='attr_attack.png']"), "table");
        if(statsTable) {
            const magicpowerRow = statsTable.querySelector("tr:has(td>img[src*='/i/icons/attr_magicpower.png'])");
            const magicpower = parseInt(magicpowerRow.querySelector("td>b").innerText);
            const knowledgeRow = statsTable.querySelector("tr:has(td>img[src*='/i/icons/attr_knowledge.png'])");
            const knowledge = parseInt(knowledgeRow.querySelector("td>b").innerText);
            return { magicpower: magicpower, knowledge: knowledge };
        }
    }
    if(location.pathname == "/home.php") {
        if(isNewPersonPage) {
            const statsContainer = document.querySelector("div#home_css_stats_wrap_div > div");
            const magicpowerRow = statsContainer.querySelector("div>div:has(div>img[src*='/i/icons/attr_magicpower.png'])");
            const magicpower = parseInt(magicpowerRow.querySelector("div.inv_stat_text.home_stat_text").innerText);
            const knowledgeRow = statsContainer.querySelector("div>div:has(div>img[src*='/i/icons/attr_knowledge.png'])");
            const knowledge = parseInt(knowledgeRow.querySelector("div.inv_stat_text.home_stat_text").innerText);
            return { magicpower: magicpower, knowledge: knowledge };
        } else {
            const statsContainer = getParent(document.querySelector("table img[src*='attr_attack.png']"), "tr", 2);
            const magicpowerRow = statsContainer.querySelector("tr:has(td>img[src*='/i/icons/attr_magicpower.png'])");
            const magicpower = parseInt(magicpowerRow.querySelector("td>b").innerText);
            const knowledgeRow = statsContainer.querySelector("tr:has(td>img[src*='/i/icons/attr_knowledge.png'])");
            const knowledge = parseInt(knowledgeRow.querySelector("td>b").innerText);
            return { magicpower: magicpower, knowledge: knowledge };
        }
    }
}
function drowBars() {
    if(location.pathname == "/pl_info.php" || location.pathname == "/home.php" && !isNewPersonPage) {
        const skillInfoCell = Array.from(document.querySelectorAll("td:not(:has(td))")).find(x => (x.innerHTML.includes(t('Knight')) || x.innerHTML.includes('Кавалер')) && x.innerHTML.includes(t('Enchanters')));
        if(!skillInfoCell) {
            return;
        }
        if(location.pathname == "/pl_info.php") {
            const skillsTitleCell = skillInfoCell.closest("tr").previousSibling.cells[1];
            const showSkillBarsCheckbox = addElement("input", { id: "showSkillBarsCheckbox", type: "checkbox", title: isEn ? "Show progressbars" : "Показать прогрессбары", style: "vertical-align: middle;" }, skillsTitleCell);
            showSkillBarsCheckbox.checked = getPlayerBool("showSkillBarsOnPlayerInfo");
            showSkillBarsCheckbox.addEventListener("change", function() { setPlayerValue("showSkillBarsOnPlayerInfo", this.checked); location.reload(); });
        }
        if(location.pathname == "/home.php" && !isNewPersonPage) {
            const skillsTitleCell = skillInfoCell.closest("table").previousSibling;
            const showSkillBarsCheckbox = addElement("input", { id: "showSkillBarsCheckbox", type: "checkbox", title: isEn ? "Show progressbars" : "Показать прогрессбары", style: "vertical-align: middle;" }, skillsTitleCell);
            showSkillBarsCheckbox.checked = getPlayerBool("showSkillBarsOnHome");
            showSkillBarsCheckbox.addEventListener("change", function() { setPlayerValue("showSkillBarsOnHome", this.checked); location.reload(); });
        }
        if(location.pathname == "/pl_info.php" && !getPlayerBool("showSkillBarsOnPlayerInfo") || location.pathname == "/home.php" && !isNewPersonPage && !getPlayerBool("showSkillBarsOnHome")) {
            return;
        }
        const barWidth = location.pathname == "/pl_info.php" ? "40%" : "35%";

        const combatLevelCell = getParent(Array.from(document.querySelectorAll("td>b, td>div>b")).find(x => x.innerHTML.includes(isEn ? "Combat level:" : "Боевой уровень:")), "td");
        combatLevelCell.innerHTML = combatLevelCell.innerHTML.split("<br>").filter(x => x).map(x => `<div style="position: relative;">${x}</div>`).join("");
        const combatLevelDiv = combatLevelCell.querySelector("div");
        createBarContainer(combatLevelDiv.innerHTML, barWidth, scales[0], combatLevelDiv, true);
        document.getElementById("hwmAdvancedPlayerInfoBirthdayCaption")?.addEventListener("click", loadBirthday);
        
        // Кэшируем хтмл
        let home_2 = document.querySelector("div#home_2");
        const home_2Html = home_2.innerHTML;

        win.a();
        let mod_guild = document.querySelector("div#mod_guild");
        const mod_guildHtml = mod_guild.innerHTML;

        const home_2Pos = skillInfoCell.innerHTML.indexOf('<div id="home_2">');
        const innerHTML = skillInfoCell.innerHTML.substring(0, home_2Pos);
        // Заново вставляем обработанный
        const barsDatas = innerHTML.split("<br>").filter(x => x.trim() != "");
        skillInfoCell.innerHTML = "";
        barsDatas.forEach((x, i) => {
            if(i == 10) {
                const barContainer = addElement("div", { innerHTML: `<center><b>${isEn ? "Guilds" : "Гильдии"}</b></center>` }, skillInfoCell);
            }
            const scale = (i <= 9 ? scales[1] : scales[i - 8]);
            createBarContainer(x.replace("Гильдия ", "").replace("' guild", ""), barWidth, scale, skillInfoCell);
        });

        home_2 = addElement("div", { id: "home_2" }, skillInfoCell);
        createBarContainer(home_2Html.replace("Гильдия ", "").replace("' guild", ""), barWidth, scales[13], home_2);
        //home_2.querySelector("a").setAttribute("onclick", "var mod_guild = document.querySelector('div#mod_guild'); mod_guild.style.display = (mod_guild.style.display == 'none') ? '' : 'none'; return false;");
        home_2.querySelector("a").removeAttribute("onclick");
        home_2.querySelector("a").href = "javascript:void(0);"
        home_2.addEventListener("click", function() {
            const mod_guild = document.querySelector('div#mod_guild');
            const expanded = mod_guild.style.display != 'none';
            mod_guild.style.display = !expanded ? '' : 'none';
            this.querySelector("a").innerText = expanded ? "+" : "-";
        });

        mod_guild = addElement("div", { id: "mod_guild" }, skillInfoCell);
        const mod_guildDatas = mod_guildHtml.split("<br>").filter(x => x.trim() != "");
        mod_guildDatas.forEach((x, i) => { createBarContainer(x, barWidth, scales[14], mod_guild); });
        mod_guild.style.display = "none";
    }
}
function createBarContainer(barText, barWidth, scale, container, isAddProgressOnly = false) {
    let barContainer = container;
    if(!isAddProgressOnly) {
        barContainer = addElement("div", { innerHTML: barText, style: `position: relative;` }, container);
    }
    const restFont = barContainer.querySelector("font");
    const rest = restFont ? parseFloat(restFont.innerText.replace(/,/g, "")) : undefined;

    let guildRegex = new RegExp(`.+: (\\d{1,2})(</b>|</a>)?( \\(([\\d,\\. ]+)\\))?`, "g");
    let guildRegexExec = guildRegex.exec(barText);
    if(!guildRegexExec) {
        guildRegex = new RegExp(`.+: .+>(\\d{1,2})(</a>)( \\(([\\d,\\. ]+)\\))?`, "g");
        guildRegexExec = guildRegex.exec(barText);
    }
    //console.log(barText);
    //console.log(guildRegexExec);
    let guildLevel;
    let guildExp;
    if(guildRegexExec) {
        guildLevel = parseInt(guildRegexExec[1]);
        guildExp = parseFloat(guildRegexExec[4]?.replace(/,/g, "") || 0);
    } else {
        //console.log(barText);
    }
    const beginExp = scale[guildLevel];
    const endExp = guildLevel == scale.length - 1 ? beginExp : scale[guildLevel + 1];
    //console.log(`guildLevel: ${guildLevel}, beginExp: ${beginExp}, endExp: ${endExp}, guildExp: ${guildExp}, rest: ${rest}`);
    let percent = (guildLevel == scale.length - 1) ? 100 : 0;
    if(guildExp > 0 && (guildLevel < scale.length - 1)) {
        percent = Math.floor((guildExp - beginExp) * 100 / (endExp - beginExp));
    }
    barContainer.insertAdjacentHTML("beforeend", getProgressHtml(percent, barWidth));
    return barContainer;
}
function getProgressHtml(percent, width) {
    return `
<div class="progressContainer" style="width: ${width};">
  <div>
    <div>${percent.toLocaleString()}%</div>
  </div>
  <div style="width: ${percent}%;"></div>
</div>`;
}function getSpanHtml(value, title) { return `<span title="${title}">${value}</span>`; }
function getGuildStatsNumber(player) {
    const mercStats = [0, 0, 1, 1, 2, 2, 3, 3, 4, 5, 6, 7, 8, 9, 10, 11];
    const commandersStats = [0, 0, 1, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11];
    const watchersStats = [0, 1, 2, 3, 4, 5, 6, 7, 7.5, 8.5, 9.5];
    const leadersStats = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0.5, 0.5, 0.5, 0.5, 0.5, 1];
    const hunters = player['Hunters\' guild'];
    const laborers = Math.floor(player['Laborers\' guild'] / 2);
    const thieves = Math.max(player['Thieves\' guild'], player['Rangers\' guild']) / 2;
    const mercenaries = mercStats[player['Mercenaries\' guild']];
    const commanders = commandersStats[player['Commanders\' guild']];
    const watchers = watchersStats[player['Watchers\' guild']];
    const adventurers = player['Adventurers\' guild'];
    const leaders = leadersStats[player['Leaders\' Guild']];
    //console.log(`Hunters: ${hunters}, Laborers: ${laborers}, Thieves/Rangers: ${thieves}, Mercenaries: ${mercenaries}, Commanders: ${commanders}, Watchers: ${watchers}, Adventurers: ${adventurers}, Leaders: ${leaders}`);
    return hunters + laborers + thieves + mercenaries + commanders + watchers + adventurers + leaders;
}
function getMainSkillStatsNumber(player) {
    let skillLevel = player.SkillLevel.reduce((t, x) => Math.max(t, x), 0);
    const averageSkill = [0, 0, 0, 1, 2, 3, 4, 5, 6, 7, 8, 8, 9, 10, 10, 11, 12, 12, 12, 13, 13, 13, 13, 14, 14, 14];
    skillLevel = Math.max(skillLevel, averageSkill[player.Level]);
    const skillStats = [0, 1, 2, 2.5, 4, 5.5, 6.5, 9, 11.5, 16, 21, 27, 33, 35, 36.5];
    return skillStats[skillLevel];
}
function getPlayerPercents(player) {
    //player.Level++; //для тестов
    const averagePoints = [0, 0, 0, 3, 5, 7, 10, 13, 17, 20, 25,
    29, 35, 41, 48, 58, 68, 77, 84, 90, 96,
    101, 108, 114,       125, 136, 147, 158, 169];
    const penaltyProcents = [0, 25, 500, 1000, 1000, 1000, 1000, 1000, 1000, 1000];
    // Ищем перекач // 101, 108, 114, 125
    let advacedPersent = 0;
    const hiLevel = Math.min(player.Level + 6, averagePoints.length - 1);
    const nextLevels = averagePoints.slice(player.Level + 1, hiLevel);
    const lowLevel = Math.max(player.Level - 4, 0);
    const prevLevels = averagePoints.slice(lowLevel, player.Level).reverse();
    //console.log(prevLevels)
    const averagePoint = averagePoints[player.Level];
    let beginNormalPoint = prevLevels[0];
    let endNormalPoint = nextLevels[0] + 2;
    //console.log(`beginNormalPoint: ${beginNormalPoint}, endNormalPoint: ${endNormalPoint}, player.TotalPoints: ${player.TotalPoints}, player.Level: ${player.Level}`)
    let prevEdge = beginNormalPoint;
    let nextEdge = endNormalPoint;
    let prevEdgeClarification = isEn ? `Average points on ${player.Level - 1} level` : `Средние очки на ${player.Level - 1} уровне`;
    let nextEdgeClarification = isEn ? `Average points + 2 on ${player.Level + 1} level` : `Средние очки + 2 на ${player.Level + 1} уровне`;
    if(player.TotalPoints <= endNormalPoint) {
        if(player.TotalPoints < beginNormalPoint) {
            // Недокач - будет начисляться больше очков умений в соотношении к недостающим очкам
        }
        if(player.TotalPoints < beginNormalPoint) {
            prevLevels.forEach((x, i) => {
                const add = i == 0 ? 0 : 0;
                if(player.TotalPoints < (x - add) && player.TotalPoints >= prevLevels[i + 1]) {
                    const beginPoint = x - add;
                    const endPoint = prevLevels[i + 1];
                    const beginProcent = -penaltyProcents[i] - 1;
                    const endProcent = penaltyProcents[i + 1];
                    const advacedPoints = beginPoint - player.TotalPoints;
                    const percentStep = Math.round((endProcent - beginProcent) / (endPoint - beginPoint));
                    advacedPersent = beginProcent + percentStep * advacedPoints;
                    //console.log(`excessLevel: ${i}, player.TotalPoints: ${player.TotalPoints}, levelAveragePoints: ${x}, add: ${add}, beginPoint: ${beginPoint}, endPoint: ${endPoint}, beginProcent: ${beginProcent}, endProcent: ${endProcent}, advacedPoints: ${advacedPoints}, percentStep: ${percentStep}, advacedPersent: ${advacedPersent}`);
                    prevEdge = endPoint;
                    nextEdge = beginPoint;
                    prevEdgeClarification = isEn ? `Average points on ${player.Level - (i + 2)} level` : `Средние очки на ${player.Level - (i + 2)} уровне`;
                    nextEdgeClarification = isEn ? `Average points on ${player.Level - (i + 1)} level` : `Средние очки на ${player.Level - (i + 1)} уровне`;
                }
                if(i == prevLevels.length - 1 && player.TotalPoints < prevLevels[i + 1]) {
                    advacedPersent = penaltyProcents[i + 1];
                    //console.log(`excessLevel: ${i}, player.TotalPoints: ${player.TotalPoints}, levelAveragePoints: ${x}, add: ${add}, advacedPersent: ${advacedPersent}`);
                }
            });
        }
    } else {
        nextLevels.forEach((x, i) => {
            const add = i == 0 ? 2 : 0;
            if(player.TotalPoints > (x + add) && player.TotalPoints <= nextLevels[i + 1]) {
                const beginPoint = x + add;
                const endPoint = nextLevels[i + 1];
                const beginProcent = Math.min(penaltyProcents[i] + 1, penaltyProcents[i + 1]);
                const endProcent = penaltyProcents[i + 1];
                const advacedPoints = player.TotalPoints - beginPoint;
                const percentStep = Math.round((endProcent - beginProcent) / (endPoint - beginPoint));
                advacedPersent = beginProcent + percentStep * advacedPoints;
                //console.log(`excessLevel: ${i}, player.TotalPoints: ${player.TotalPoints}, levelAveragePoints: ${x}, add: ${add}, beginPoint: ${beginPoint}, endPoint: ${endPoint}, beginProcent: ${beginProcent}, endProcent: ${endProcent}, advacedPoints: ${advacedPoints}, percentStep: ${percentStep}, advacedPersent: ${advacedPersent}`);
                prevEdge = x + add;
                nextEdge = endPoint;
                prevEdgeClarification = isEn ? `Average points${add > 0 ? ` + ${add}` : ""} on ${player.Level + 1 + i} level` : `Средние очки${add > 0 ? ` + ${add}` : ""} на ${player.Level + 1 + i} уровне`;
                nextEdgeClarification = isEn ? `Average points on ${player.Level + 1 + i + 1} level` : `Средние очки на ${player.Level + 1 + i + 1} уровне`;
            }
            if(i == nextLevels.length - 1 && player.TotalPoints > nextLevels[i + 1]) {
                advacedPersent = penaltyProcents[i + 1];
                //console.log(`excessLevel: ${i}, player.TotalPoints: ${player.TotalPoints}, levelAveragePoints: ${x}, add: ${add}, advacedPersent: ${advacedPersent}`);
            }
        });
    }
    return {
        averagePoint: averagePoint,
        beginNormalPoint: beginNormalPoint,
        endNormalPoint: endNormalPoint,
        normalPercent: Math.max(Math.min(Math.round((player.TotalPoints - beginNormalPoint) * 100 / (endNormalPoint - beginNormalPoint)), 100), 0),
        advacedPersent: advacedPersent,
        prevEdge: prevEdge,
        nextEdge: nextEdge,
        prevEdgeClarification: prevEdgeClarification,
        nextEdgeClarification: nextEdgeClarification
    };
}
function addPlayerInfoSpoilers() {
    if(location.pathname == "/pl_info.php") {
        const panelNames = isEn ? ["Statistics", "Clans", "Resources", "Best stacks in the Leaders' Guild", "Achievements", "Personal info"] : ["Статистика", "Кланы", "Ресурсы", "Лучшие отряды Гильдии Лидеров", "Достижения", "Личная информация"];
        const bolds = Array.from(document.querySelectorAll("td > b"));
        for(const panelName of panelNames) {
            const panelTitleBold = bolds.find(x => x.innerText == panelName);
            if(panelTitleBold) {
                const panelTitle = panelTitleBold.closest("td");
                const spoiler = addElement("div", { id: getSpoilerId(panelName),  style: "display: inline-block; cursor: pointer;", innerHTML: `<img src="https://dcdn.heroeswm.ru/i/inv_im/btn_expand.svg" style="vertical-align: middle;">` }, panelTitle);
                spoiler.addEventListener("click", function() { setPlayerValue(this.id, !getPlayerBool(this.id)); bindPlayerInfoSpolers(this.id); });
                if(panelName == (isEn ? "Statistics" : "Статистика")) {
                    panelTitle.insertAdjacentHTML("beforeend", `&nbsp;`);
                    addElement("a", { innerHTML: ` <b>${isEn ? "Battles" : "Бои"}</b>`, href: `/pl_warlog.php?id=${getUrlParamValue(location.href, "id")}` }, panelTitle);
                    panelTitle.insertAdjacentHTML("beforeend", `&nbsp;`);
                    addElement("a", { innerHTML: ` <b>${isEn ? "Transfers" : "Передачи"}</b>`, href: `/pl_transfers.php?id=${getUrlParamValue(location.href, "id")}` }, panelTitle);
                    panelTitle.insertAdjacentHTML("beforeend", `&nbsp;`);
                    addElement("a", { innerHTML: ` <b>${isEn ? "Games" : "Игры"}</b>`, href: `/pl_cardlog.php?id=${getUrlParamValue(location.href, "id")}` }, panelTitle);
                    const pl_info_realtyRef = document.querySelector("a[href^='pl_info_realty.php?id']");
                    if(pl_info_realtyRef) {
                        panelTitle.insertAdjacentHTML("beforeend", `&nbsp;`);
                        addElement("a", { innerHTML: ` <b>${isEn ? "Real estaties" : "Недвижимость"}</b>`, href: pl_info_realtyRef.href }, panelTitle);
                    }
                }
                if(panelName == (isEn ? "Clans" : "Кланы")) {
                    const showLength = 4;
                    const clanRefs = [...panelTitle.closest("tr").nextElementSibling.querySelectorAll("a[href^='clan_info.php']")];
                    clanRefs.slice(0, showLength).forEach((x, i) => {
                        const clone = x.cloneNode(true);
                        panelTitle.insertAdjacentHTML("beforeend", i == 0 ? ":&nbsp;" : `,&nbsp;`);
                        panelTitle.insertAdjacentElement("beforeend", clone);
                    });
                    if(clanRefs.length > showLength) {
                        panelTitle.insertAdjacentHTML("beforeend", `...`);
                    }
                }
            }
        }
        bindPlayerInfoSpolers();
    }
}
function bindPlayerInfoSpolers(spoilerId) {
    const panelNames = isEn ? ["Statistics", "Clans", "Resources", "Best stacks in the Leaders' Guild", "Achievements", "Personal info"] : ["Статистика", "Кланы", "Ресурсы", "Лучшие отряды Гильдии Лидеров", "Достижения", "Личная информация"];
    const spoilerIds = spoilerId ? [spoilerId] : panelNames.map(x => getSpoilerId(x));
    for(const spoilerId of spoilerIds) {
        const spoiler = document.getElementById(spoilerId);
        if(spoiler) {
            const spoiled = getPlayerBool(spoilerId);
            spoiler.querySelector("img").style.transform = spoiled ? 'rotate(0deg)' : 'rotate(90deg)';
            spoiler.closest("tr").nextElementSibling.style.display = spoiled ? "none" : "";
        }
    }
}
function getSpoilerId(panelName) { return `${panelName.replace(/\s/g, "").replace(/'/g, "")}Spoiler`; }
function clanStatistics() {
    if(location.pathname == "/clan_info.php") {
        const clanHeroesTable = document.querySelector("body>center>table>tbody>tr>td>table>tbody>tr>td>table.wb:nth-of-type(2)");
        const clanActivity = clanHeroesTable.querySelector("tr > td:nth-child(2) > img[src$='clans/online.gif']") || clanHeroesTable.querySelector("tr > td:nth-child(2) > img[src$='clans/offline.gif']");
        if(!clanActivity) {
            return;
        }
        const onlineAmount = clanHeroesTable.querySelectorAll("img[src$='clans/online.gif']").length;
        const offlineAmount = clanHeroesTable.querySelectorAll("img[src$='clans/offline.gif']").length;
        const inBattleAmount = clanHeroesTable.querySelectorAll("img[src$='clans/battle.gif']").length;
        const playArcomagAmount = clanHeroesTable.querySelectorAll("img[src$='clans/arcomag.gif']").length;

        const clanInfoTable = document.querySelector("a[href^='clan_log.php?id']").closest("table");
        const firstRow = clanInfoTable.rows[0];
        firstRow.cells[0].insertAdjacentHTML("beforeend", `
<span id=shortClanActivityInfoSpan>
    <span style="${onlineAmount > 0 ? "" : "display: none;"}"><img src="https://dcdn.heroeswm.ru/i/clans/online.gif" align="absmiddle" border="0" height="15" width="15"> <b>${isEn ? "Online" : "В игре"}:</b> ${onlineAmount}&nbsp;&nbsp;&nbsp;</span>
    <span style="${inBattleAmount > 0 ? "" : "display: none;"}"><img src="https://dcdn.heroeswm.ru/i/clans/battle.gif" align="absmiddle" border="0" height="15" width="15"> <b>${isEn ? "In combat" : "В бою"}:</b> ${inBattleAmount}&nbsp;&nbsp;&nbsp;</span>
    <span style="${playArcomagAmount > 0 ? "" : "display: none;"}"><img src="https://dcdn.heroeswm.ru/i/clans/arcomag.gif" align="absmiddle" border="0" height="15" width="15"> <b>${isEn ? "In card match" : "В таверне"}:</b> ${playArcomagAmount}&nbsp;&nbsp;&nbsp;</span>
</span>`);
        const spoiler = addElement("div", { id: `clanStatisticsSpoiler`,  style: "display: inline-block; cursor: pointer;", innerHTML: `<img src="https://dcdn.heroeswm.ru/i/inv_im/btn_expand.svg" style="vertical-align: middle;">` }, document.getElementById("shortClanActivityInfoSpan"));
        spoiler.addEventListener("click", function() { setPlayerValue("clanStatisticsSpoiled", !getPlayerBool("clanStatisticsSpoiled")); clanStatisticsRowBind(); });


        const clanHeroes = Array.from(clanHeroesTable.rows).filter(x => x.cells[2].querySelector("a[href^='pl_info.php?id=']")).map(x => {
            const level = parseInt(x.cells[3].innerText);
            const fractionImage = x.cells[2].querySelector("img[src*='/i/f/r']");
            let fractionNumber = 0;
            let fraction = isEn ? "In smoke" : "В тумане";
            if(fractionImage) {
                fraction = fractionImage.title;
                let fractionImageMatch = fractionImage.src.match(/\/i\/f\/r(\d+).png/);
                if(fractionImageMatch) {
                    fractionNumber = parseInt(fractionImageMatch[1]);
                } else {
                    console.log(fractionImage);
                }
            }
            return { level: level, fractionImage: fractionImage, fraction: fraction, fractionNumber: fractionNumber };
        });
        const clanHeroesAmount = clanHeroes.length;
        const heroesLevels = groupBy(clanHeroes, "level");
        const clanLevels = Object.keys(heroesLevels).map(x => ({ level: parseInt(x), amount: heroesLevels[x].length }));
        clanLevels.sort((a, b) => b.level - a.level);

        const heroesFractions = groupBy(clanHeroes, "fractionNumber"); // console.log(heroesFractions);
        const clanFractions = Object.keys(heroesFractions).map(x => ({
            fractionNumber: parseInt(x) % 100,
            amount: heroesFractions[x].length,
            fractionImage: heroesFractions[x][0].fractionImage,
            fraction: heroesFractions[x][0].fraction,
            altNumber: parseInt(x) >= 100 ? Math.round(parseInt(x) / 100) : 0
        }));
        clanFractions.sort((a, b) => a.fractionNumber == b.fractionNumber ? a.altNumber - b.altNumber : a.fractionNumber - b.fractionNumber);  //console.log(clanFractions);


        const clanStatisticsRow = addElement('tr', { id: "clanStatisticsRow" }, firstRow, "afterend");
        clanStatisticsRow.innerHTML = `
<td colspan="2" class="wbwhite">
    <table width="100%" height="100%">
        <tr>
            <td width="60%" valign="top" style="border-right:1px #5D413A solid;">
                <table width="100%" cellpadding="5">
                    <tr>
                        <td align="center">
                            <b>${isEn ? 'All' : 'Всего'}:</b> ${clanHeroesAmount}&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<b>${isEn ? 'Online' : 'В сети'}:</b> ${clanHeroesAmount - offlineAmount} (${Math.round((clanHeroesAmount - offlineAmount) / clanHeroesAmount * 100)}%)
                        </td>
                    </tr>
                    <tr>
                        <td align="center" style="white-space:nowrap">
                            <img src="https://dcdn.heroeswm.ru/i/clans/online.gif" align="absmiddle" border="0" height="15" width="15"> <b>${isEn ? "Online" : "В игре"}:</b> ${onlineAmount}&nbsp;&nbsp;&nbsp;
                            <img src="https://dcdn.heroeswm.ru/i/clans/battle.gif" align="absmiddle" border="0" height="15" width="15"> <b>${isEn ? "In combat" : "В бою"}:</b> ${inBattleAmount}&nbsp;&nbsp;&nbsp;
                            <img src="https://dcdn.heroeswm.ru/i/clans/arcomag.gif" align="absmiddle" border="0" height="15" width="15"> <b>${isEn ? "In card match" : "В таверне"}:</b> ${playArcomagAmount}&nbsp;&nbsp;&nbsp;
                            <img src="https://dcdn.heroeswm.ru/i/clans/offline.gif" align="absmiddle" border="0" height="15" width="15"> <b>${isEn ? "Offline" : "Не в игре"}:</b> ${offlineAmount}
                        </td>
                    </tr>
                    <tr>
                        <td>
                        ${clanFractions.map(x => `<img src="${x.fractionImage?.src || "/i/unk_kukla.png"}" align="absmiddle" border="0" height="15" width="15"> <b>${x.fraction}:</b> ${x.amount} (${Math.round(x.amount / clanHeroesAmount * 100)}%)`).join("<br>")}
                        </td>
                    </tr>
                </table>
            </td>
            <td valign="top" height="100%">
                <table width="100%" height="100%" cellpadding="5">
                    <tr>
                        <td align="center">
                            <b>${isEn ? 'The average level of heroes' : 'Средний уровень героев'}:</b> ${round0(clanHeroes.reduce((t, x) => t + x.level, 0) / clanHeroesAmount)}
                        </td>
                    </tr>
                    <tr>
                        <td height="100%" valign="middle">
                            ${clanLevels.map(x => `<b>${x.level} ${isEn ? 'level' : 'уровней'}:</b> ${x.amount} (${Math.round(x.amount / clanHeroesAmount * 100)}%)`).join("<br>")}
                        </td>
                    </tr>
                    <tr>
                        <td align="right" valign="bottom">
                        </td>
                    </tr>
                </table>
            </td>
        </tr>
    </table>
</td>`;
        clanStatisticsRowBind();
    }
}
function clanStatisticsRowBind() {
    const spoiled = getPlayerBool("clanStatisticsSpoiled");
    const clanStatisticsSpoiler = document.getElementById("clanStatisticsSpoiler");
    clanStatisticsSpoiler.querySelector("img").style.transform = spoiled ? 'rotate(0deg)' : 'rotate(90deg)';
    clanStatisticsSpoiler.title = isEn ? (spoiled ? "Show clan statistics" : "Hide clan statistics") : (spoiled ? "Показать статистику клана" : "Скрыть статистику клана");
    document.getElementById("clanStatisticsRow").style.display = spoiled ? "none" : "";
}
function getViewingPlayerLevel() {
    if(location.pathname == "/home.php" || location.pathname == "/pl_info.php") {
        if(isNewPersonPage) {
            const levelInfoCell = Array.from(document.querySelectorAll("div.home_pers_info")).find(x => x.innerHTML.includes(isEn ? "Combat level" : "Боевой уровень"));
            if(levelInfoCell) {
                setPlayerValue("playerLevel", parseInt(levelInfoCell.querySelector("div[id=bartext] > span").innerText));
            }
        } else {
            const playerLevelExec = new RegExp(`<b>${isEn ? "Combat level" : "Боевой уровень"}: (\\d+?)<\\/b>`).exec(document.documentElement.innerHTML);
            if(playerLevelExec) {
                setPlayerValue("playerLevel", parseInt(playerLevelExec[1]));
            }
        }
    }
    return parseInt(getPlayerValue("playerLevel", 0));
}
function getPlayerFraction() {
    let fractionSourceText;
    if(location.pathname == '/home.php') {
        const fractionImage = isNewPersonPage ? document.querySelector("div#hwm_no_zoom div.home_main_pers_block center a[href^='castle.php'] img") : document.querySelector("body > center table.wb > tbody > tr:nth-child(2) center a[href^='castle.php'] img");
        fractionSourceText = fractionImage?.src;
    }
    const playerFractionExec = /\/i\/f\/r(\d{1,3})\.png/.exec(fractionSourceText || document.querySelector("body").innerHTML);
    if(playerFractionExec) {
        return playerFractionExec[1];
    }
}
function initSpellBook(playerTalentBranches) {
    if(location.pathname == "/pl_info.php" || location.pathname == "/home.php") {
        const playerLevel = getViewingPlayerLevel();
        const playerFraction = parseInt(getPlayerFraction());
        const playerParameters = getPlayerParameters();
        if(!playerParameters) {
            return;
        }
        const spell_power = playerParameters.magicpower;
        const knowledge = playerParameters.knowledge;

        const playerData = getPlayerData();
        const ability = playerData.SkillLevel[playerFraction%100 - 1];

        let pharaonSpellPowerAmplification = 0;
        if(playerFraction == 10) {
            pharaonSpellPowerAmplification = Math.floor(1 + ability / 2);
        }
        let sсhoolsLevel = playerLevel >= 5 ? (playerLevel >= 8 ? (playerLevel >= 10 ? (playerLevel >= 14 ? (playerLevel >= 18 ? 5 : 4) : 3) : 2) : 1) : 0;
        if(playerFraction%100 == 9) {
            sсhoolsLevel = playerLevel >= 5 ? (playerLevel >= 10 ? (playerLevel >= 17 ? 3 : 2) : 1) : 0;
        }
        let schools;
        switch(playerFraction) {
            case 1:
            case 10:
                schools = ['light', 'dark'];
                break;
            case 101:
            case 4:
                schools = ['light', 'nature'];
                break;
            case 2:
                schools = ['dark', 'nature'];
                break;
            case 102:
                schools = ['nature'];
                break;
            case 3:
                schools = ['nature', 'chaos'];
                if(playerLevel >= 10) {
                    schools.push('light');
                }
                break;
            case 103:
            case 104:
            case 108:
                schools = ['chaos'];
                break;
            case 5:
            case 105:
                schools = [];
                break;
            case 205:
            case 107:
                schools = ['dark'];
                break;
            case 6:
            case 106:
            case 7:
                schools = ['dark', 'chaos'];
                break;
            case 8:
                schools = ['light', 'chaos'];
                break;
            case 9:
            case 109:
                schools = ['cries'];
                break;
        }
        const magic_perks = {};
        const perks = playerTalentBranches.reduce((t, x) => { return [...t, ...x]; }, []);
        //console.log(perks);
        for(const perk of perks) {
            switch(perk) {
                case 'intelligence':
                    magic_perks.intelligence = true;
                    break;
                case 'summon1':
                    magic_perks.nature = 1;
                    break;
                case 'summon2':
                    magic_perks.nature = 2;
                    break;
                case 'summon3':
                    magic_perks.nature = 3;
                    break;
                case 'master_of_life':
                    magic_perks.master_of_life = true;
                    break;
                case 'destructive1':
                    magic_perks.chaos = 1;
                    break;
                case 'destructive2':
                    magic_perks.chaos = 2;
                    break;
                case 'destructive3':
                    magic_perks.chaos = 3;
                    break;
                case 'sorcery1':
                    magic_perks.sorcery = 1;
                    break;
                case 'sorcery2':
                    magic_perks.sorcery = 2;
                    break;
                case 'sorcery3':
                    magic_perks.sorcery = 3;
                    break;
                case 'magic_insight':
                    magic_perks.magic_insight = true;
                    break;
                case 'arcane_training':
                    magic_perks.arcane_training = true;
                    break;
                case 'erratic_mana':
                    magic_perks.erratic_mana = true;
                    break;
                case 'light1':
                    magic_perks.light = 1;
                    break;
                case 'light2':
                    magic_perks.light = 2;
                    break;
                case 'light3':
                    magic_perks.light = 3;
                    break;
                case 'master_of_abjuration':
                    magic_perks.master_of_abjuration = true;
                    break;
                case 'master_of_blessings':
                    magic_perks.master_of_blessings = true;
                    break;
                case 'master_of_wrath':
                    magic_perks.master_of_wrath = true;
                    break;
                case 'twilight':
                    magic_perks.twilight = true;
                    break;
                case 'power_of_speed':
                    magic_perks.power_of_speed = true;
                    break;
                case 'power_of_endurance':
                    magic_perks.power_of_endurance = true;
                    break;
                case 'dark1':
                    magic_perks.dark = 1;
                    break;
                case 'dark2':
                    magic_perks.dark = 2;
                    break;
                case 'dark3':
                    magic_perks.dark = 3;
                    break;
                case 'master_of_curses':
                    magic_perks.master_of_curses = true;
                    break;
                case 'master_of_mind':
                    magic_perks.master_of_mind = true;
                    break;
                case 'master_of_pain':
                    magic_perks.master_of_pain = true;
                    break;
                case 'fallen_knight':
                    magic_perks.fallen_knight = true;
                    break;
                case 'dark_power':
                    magic_perks.dark_power = true;
                    break;
                case 'knight_mark':
                    magic_perks.knight_mark = true;//надзор
                    break;
                case 'divine_guidance':
                    magic_perks.divine_guidance = true;//воодух
                    break;
                case 'elf_shot':
                    magic_perks.elf_shot = true;//ливень
                    break;
                case 'zakarrow':
                    magic_perks.zakarrow = true;//Заколдованная стрела
                    break;
                case 'necr_soul':
                    magic_perks.necr_soul = true;//духовная связь
                    break;
                case 'powerraise':
                    magic_perks.powerraise = true;//совершенное поднятие мертвецов
                    break;
                case 'benediction':
                    magic_perks.benediction = true;//Молитва
                    break;
                case 'cre_master':
                    magic_perks.cre_master = true;//Повелитель существ
                    break;
                case 'consumecorpse':
                    magic_perks.consumecorpse = true;//Поглощение трупов
                    break;
                case 'dayandnight':
                    magic_perks.dayandnight = true;//Сияние Луны и Солнца
                    break;
            }
        }
        magic_perks.nature = magic_perks.nature || 0;
        magic_perks.chaos = magic_perks.chaos || 0;
        magic_perks.sorcery = magic_perks.sorcery || 0;
        magic_perks.light = magic_perks.light || 0;
        magic_perks.dark = magic_perks.dark || 0;
        //console.log(magic_perks);
        
	// magicbooknames = ['Raise Dead', 'Magic punch', 'Lightning', 'Magic arrow', 'Delay', 'Rapid','Wasp swarm','Curse','Bless','Stoneskin','Earthen spikes','Decay','Mass rapid','Mass bless','Mass stoneskin',
    // 'Dispersion','Disruption ray','Ice clod','Fireball','Gating','Explosion','Mass dispersion','Chastise','Evasion','Weakness','Confusion','Ice ring','Summon phantom','Mass delay','Mass curse','Mass decay',
    // 'Mass disruption ray','Mass weakness','Mass confusion','Mass chastise','Mass evasion','Fervor','Armageddon','Rain of arrows','Escort','Spirit link','Mana feed','Blind','Berserker','Hypnosis','Teleportation',
    // 'Meteorite rain', 'Chain lightning','Summon elementals','Anti-magic','Fire wall','Earthquake','Summop Pit demons','Leap','Sacrifice tribal goblin',
    //'Tribal supremacy','Tribute to spirits','Lessons of history','Ancestral wrath','Battle cry','Tribal unity',
    //'Set traps','Earth and sky','Mass earth and sky','First blood','Waves of renewal','Spirit ties',
    
    //'Vampirism','Implosion','Permeating cold','Summon phoenix','Celestial shield','Resurrection','Divine retribution',
  
  //'Seduction','Telekinesis', 'Consume corpse','Siphon mana','Divine retribution', 'Prayer', 'Affliction','Djin Luck','Djin Unluck',
  //'Storm Caller','Magical miner','Channel', 'Enchanted arrow', 'Mirth', 'Invisibility',
  // 'Summon fire elementals','Summon air elementals','Summon water elementals','Summon earth elementals', 'Flame', 'Necromancy', 'Fire arrow'];

// var magicbookspells = ['raisedead', 'magicfist', 'lighting', 'magicarrow', 'slow', 'fast','swarm','curse','bless','stoneskin','stonespikes','poison','mfast','mbless','mstoneskin','dispel','dray','icebolt',
// 'fireball','gating','explosion','mdispel','righteous_might','deflect_missile','suffering','confusion','circle_of_winter','phantom_forces','mslow','mcurse','mpoison','mdray','msuffering','mconfusion',
// 'mrighteous_might','mdeflect_missile','divine_guidance','armageddon','elfshot','knightmark','necr_soul','manafeed','blind','frenzy','hypnos','teleport','meteor','chainlighting','summonel','antimagic','firewall',
// 'earthquake','summonpitlords','leap','sacrificegoblin',
//'rallingcry','callofblood','wordofchief','fearmyroar','battlecry','angerofhorde',
//'setsnares','skyandearth','mskyandearth','firstblood','waves','spiritlink',

//'vampirizm','implosion','deepfreeze','summonphoenix','arcanearmor','resurrection2','divinevengeance',

//'seduction','teleportother','consumecorpse','siphonmana','divinev', 'benediction','sorrow','djinluck','djinunluck','stormcaller', 'magicmine','channeling','zakarrow', 'satyrmorale','invisibility',
// 'summonel_f','summonel_a','summonel_w','summonel_e', 'flamestrike', 'raisedead_enemy', 'firearrow'];

// var magicbooknames = ['Поднятие мертвецов', 'Магический кулак', 'Молния', 'Магическая стрела', 'Замедление', 'Ускорение','Осиный рой','Проклятие','Благословение','Каменная кожа','Каменные шипы','Разложение',
// 'Массовое ускорение','Массовое благословление','Массовая каменная кожа','Рассеивание','Разрушающий луч','Ледяная глыба','Огненный шар','Открытие врат','Взрыв','Массовое рассеивание','Карающий удар','Уклонение',
// 'Слабость','Забывчивость','Кольцо холода','Создание фантома','Массовое замедление','Массовое проклятие','Массовое разложение','Массовый разрушающий луч','Массовая слабость','Массовая забывчивость',
// 'Массовый карающий удар','Массовое уклонение','Воодушевление','Армагеддон','Ливень стрел','Надзор','Духовная связь','Передача маны','Ослепление','Берсерк','Гипноз', 'Телепорт', 'Метеоритный дождь',
// 'Цепная молния','Призыв элементалей','Антимагия','Огненная стена','Землетрясение','Призыв Пещерных владык','Прыжок','Приношение в жертву',
//'Объединяющий клич','Зов крови','Слово вождя','Устрашающий рык','Боевой клич','Ярость орды',
//'Установка капканов','Небо и земля','Массовое небо и земля','Первая кровь','Волны обновления','Духовные узы',

//'Вампиризм','Взрыв','Останавливающий холод','Призыв феникса','Небесный щит','Воскрешение','Божественная месть',

//'Искушение','Телепортация к себе', 'Поглощение трупов','Откачивание маны','Божественная месть', 'Молитва','Скорбь', 'Удача джина', 'Неудача джина','Штормозов',
// 'Гремлемина','Канал','Заколдованная стрела', 'Веселье','Невидимость',
// 'Призыв элементалей огня','Призыв элементалей воздуха','Призыв элементалей воды','Призыв элементалей земли', 'Пламя', 'Некромантия', 'Огненная стрела'];

        const fiveSchoolTest = false;
        // [Заклинание] [Название] [Доступность] [Мана] [Урон] [Эффективность] [Длительность] [Картинка]
        const allSpells = {
            // Природа
            'magicFist':		[isEn ? "Magic punch" : 'Магический кулак',         (playerFraction == 3 || (sсhoolsLevel >= 1 && schools.includes("nature")) ), 5, damage(magic_perks.master_of_life ? (Number(spell_power) + 4) : spell_power, magic_perks.nature, 20,  4, 25,  5, 30,  6, 35,  7), false, false, "magicfist"],
            'waspSwarm':		[isEn ? "Wasp swarm" : 'Осиный рой',				(sсhoolsLevel >= 2 && schools.includes("nature")), 5, damage(spell_power, magic_perks.nature, 10,  2, 15,  3, 20,  4, 25,  5), false, false, "swarm"],
            'raiseDead':		[isEn ? "Raise dead" : 'Поднятие мертвецов',		(playerFraction == 2 || (sсhoolsLevel >= 2 && schools.includes("nature")) ),9,false,damage(magic_perks.master_of_life ? (spell_power + 4) : spell_power,magic_perks.nature,120, 15, 136, 17, 160, 20, 180,  23, (checkSet('necr') ? 2 : 1) * (magic_perks.powerraise ? 1 + ability / 10 : 1)),false,"raisedead"],
            'phantom':			[isEn ? "Summon phantom" : 'Создание фантома',		(sсhoolsLevel >= 3 && schools.includes("nature") && (magic_perks.nature >= 1 || magic_perks.magic_insight) ),18,false,(Number(magic_perks.nature) + 4),spell_power < 1 ? 0.5 : spell_power,"phantom_forces"],
            'earthquake':		[isEn ? "Earthquake" : 'Землетрясение',				(sсhoolsLevel >= 3 && schools.includes("nature") && (magic_perks.nature >= 1 || magic_perks.magic_insight) ),7,false,damage(spell_power,magic_perks.nature,15, 15,  25, 25,  35, 35,  50,  50),false,"earthquake"],
            'summonElemental':	[isEn ? "Summon elementals" : 'Призыв элементалей',	(sсhoolsLevel >= 4 && schools.includes("nature") && magic_perks.nature >= 2),17,false,damage(spell_power,magic_perks.nature,0,  0,   0,  0,   1,  1,   2, 1.5),false,"summonel"],
            'fireWall':			[isEn ? "Fire wall" : 'Огненная стена',				(sсhoolsLevel >= 4 && schools.includes("nature") && magic_perks.nature >= 2),16,false,damage(spell_power,magic_perks.nature,0,  0,   0,  0,   9,  9,  10,  10),false,"firewall"],
            //		Хаос
            'magicArrow':		[isEn ? "Magic arrow" : 'Магическая стрела',		(sсhoolsLevel >= 1 && schools.includes("chaos")),4,damage(spell_power,magic_perks.chaos,24,  8, 32,  8, 40,  8, 48,  8),false,false,"magicarrow"],
            'stoneSpikes':		[isEn ? "Earthen spikes" : 'Каменные шипы',			(playerFraction == 6 || (sсhoolsLevel >= 1 && schools.includes("chaos"))),5,damage(spell_power,magic_perks.chaos,8,   4, 12,  4, 16,  4, 20,  4),false,false,"stonespikes"],
            'lightning':		[isEn ? "Lightning" : 'Молния',						(sсhoolsLevel >= 2 && schools.includes("chaos")),5,damage(spell_power,magic_perks.chaos,11, 11, 13, 13, 15, 15, 17, 17),false,false,'lighting'],
            'iceBolt':			[isEn ? "Ice clod" : 'Ледяная глыба',				(sсhoolsLevel >= 2 && schools.includes("chaos")),6,damage(spell_power,magic_perks.chaos,30,  9, 44,  9, 59,  9, 74,  9),false,false,'icebolt'],
            'coldRing':			[isEn ? "Ice ring" : 'Кольцо холода',				(sсhoolsLevel >= 3 && schools.includes("chaos") && (magic_perks.chaos >= 1 || magic_perks.magic_insight) ),9,damage(spell_power,magic_perks.chaos,15,  6, 27,  6, 39,  6, 51,  6),false,false,'circle_of_winter'],
            'fireBall':			[isEn ? "Fireball" : 'Огненный шар',				((sсhoolsLevel >= 3 && schools.includes("chaos") && (magic_perks.chaos >= 1 || magic_perks.magic_insight)) || checkSet('demon')),checkSet('demon') ? 5 : 10,damage(spell_power,checkSet('demon') ? 3 : magic_perks.chaos,	 8,  8,  9,  9, 10, 10, 11, 11),false,false,'fireball'],
            'chainLightning':	[isEn ? "Chain lightning" : 'Цепная молния',		(sсhoolsLevel >= 4 && schools.includes("chaos") && magic_perks.chaos >= 2),16,damage(spell_power,magic_perks.chaos,0,  0,  0,  0, 16, 16, 19, 19),false,false,'chainlighting'],
            'meteorRain':		[isEn ? "Мeteorite rain" : 'Метеоритный дождь',		(sсhoolsLevel >= 4 && schools.includes("chaos") && magic_perks.chaos >= 2),16,damage(spell_power,magic_perks.chaos,0,  0,  0,  0, 16, 16, 19, 19),false,false,'meteor'],
            //		Свет
            'speed':			[isEn ? "Rapid" : 'Ускорение',					    (sсhoolsLevel >= 1 && schools.includes("light")),4,false,damage(magic_perks.twilight ? (Number(spell_power) + 3) : spell_power,magic_perks.light,20,  0,  25,  0,  30,  0,  40,   0, playerFraction == 101 ? 1 + ability / 50 : 1) + '%',(magic_perks.twilight ? (Number(spell_power) + 3) : spell_power) < 1 ? 0.5 : magic_perks.twilight ? (Number(spell_power) + 3) : spell_power,'fast'],
            'bless':			[isEn ? "Bless" : 'Благословение',				    (sсhoolsLevel >= 1 && schools.includes("light")),4,false,damage(magic_perks.twilight ? (Number(spell_power) + 3) : spell_power,magic_perks.light,50,  0,  65,  0,  85,  0, 100,   0) + '%',(magic_perks.twilight ? (Number(spell_power) + 3) : spell_power) < 1 ? 0.5 : magic_perks.twilight ? (Number(spell_power) + 3) : spell_power,'bless'],
            'stoneSkin':		[isEn ? "Stoneskin" : 'Каменная кожа',				(sсhoolsLevel >= 2 && schools.includes("light")),6,false,damage(magic_perks.twilight ? (Number(spell_power) + 3) : spell_power,magic_perks.light,3,  0,   6,  0,   9,  0,  12,   0, playerFraction == 101 ? 1 + ability / 50 : 1),(magic_perks.twilight ? (Number(spell_power) + 3) : spell_power) < 1 ? 0.5 : magic_perks.twilight ? (Number(spell_power) + 3) : spell_power,'stoneskin'],
            'dispell':			[isEn ? "Dispersion" : 'Рассеивание',				(sсhoolsLevel >= 2 && schools.includes("light")),10,false,damage(magic_perks.twilight ? (Number(spell_power) + 3) : spell_power,magic_perks.light,40,  0,  60,  0,  80,  0, 100,   0),false,'dispel'],
            'evasion':			[isEn ? "Evasion" : 'Уклонение',					(sсhoolsLevel >= 3 && schools.includes("light") && (magic_perks.light >= 1 || magic_perks.magic_insight)),6,false,damage(magic_perks.twilight ? (Number(spell_power) + 3) : spell_power,magic_perks.light,25,  0,  40,  0,  55,  0,  70,   0) + '%',(magic_perks.twilight ? (Number(spell_power) + 3) : spell_power) < 1 ? 0.5 : magic_perks.twilight ? (Number(spell_power) + 3) : spell_power,'deflect_missile'],
            'punishingBlow':	[isEn ? "Chastise" : 'Карающий удар',				(sсhoolsLevel >= 3 && schools.includes("light") && (magic_perks.light >= 1 || magic_perks.magic_insight) ),6,false,damage(magic_perks.twilight ? (Number(spell_power) + 3) : spell_power,magic_perks.light,3,  0,   6,  0,   9,  0,  12,   0, playerFraction == 101 ? 1 + ability / 50 : 1),(magic_perks.twilight ? (Number(spell_power) + 3) : spell_power) < 1 ? 0.5 : magic_perks.twilight ? (Number(spell_power) + 3) : spell_power,'righteous_might'],
            'antiMagic':		[isEn ? "Antimagic" : 'Антимагия',					(sсhoolsLevel >= 4 && schools.includes("light") && magic_perks.light >= 2),7,false,damage(magic_perks.twilight ? (Number(spell_power) + 3) : spell_power,magic_perks.light,0,  0,   0,  0,  80, 40, 100,  50),(magic_perks.twilight ? (Number(spell_power) + 3) : spell_power) < 1 ? 0.5 : magic_perks.twilight ? (Number(spell_power) + 3) : spell_power,'antimagic'],
            'teleport':			[isEn ? "Teleport" : 'Телепорт',					(sсhoolsLevel >= 4 && schools.includes("light") && magic_perks.light >= 2),8,false,damage(magic_perks.twilight ? (Number(spell_power) + 3) : spell_power,magic_perks.light,0,  0,   0,  0, 200, 40, 300,  50),false,'teleport'],
            //		Тьма
            'slow':				[isEn ? "Delay" : 'Замедление',					    (sсhoolsLevel >= 1 && schools.includes("dark")),4,false,damage(magic_perks.twilight ? (Number(spell_power) + magic_perks.fallen_knight ? 8 : 3) : magic_perks.fallen_knight ? (Number(spell_power) + 5) : spell_power,	magic_perks.dark,20,  0,  25,  0,  30,  0,  40,   0, playerFraction == 107 ? 1 + ability / 50 : 1) + '%',(magic_perks.twilight ? (Number(spell_power) + magic_perks.fallen_knight ? 8 : 3) : magic_perks.fallen_knight ? (Number(spell_power) + 5) : spell_power) < 1 ? 0.5 : magic_perks.twilight ? (Number(spell_power) + magic_perks.fallen_knight ? 8 : 3) : magic_perks.fallen_knight ? (Number(spell_power) + 5) : spell_power,'slow'],
            'curse':			[isEn ? "Curse" : 'Проклятие',					    (sсhoolsLevel >= 1 && schools.includes("dark")),4,false,damage(magic_perks.twilight ? (Number(spell_power) + magic_perks.fallen_knight ? 8 : 3) : magic_perks.fallen_knight ? (Number(spell_power) + 5) : spell_power,	magic_perks.dark,50,  0,  65,  0,  80,  0, 100,   0) + '%',(magic_perks.twilight ? (Number(spell_power) + magic_perks.fallen_knight ? 8 : 3) : magic_perks.fallen_knight ? (Number(spell_power) + 5) : spell_power) < 1 ? 0.5 : magic_perks.twilight ? (Number(spell_power) + magic_perks.fallen_knight ? 8 : 3) : magic_perks.fallen_knight ? (Number(spell_power) + 5) : spell_power,'curse'],
            'disruptingRay':	[isEn ? "Disruption ray" : 'Разрушающий луч',		(sсhoolsLevel >= 2 && schools.includes("dark")),5,false,damage(magic_perks.twilight ? (Number(spell_power) + magic_perks.fallen_knight ? 8 : 3) : magic_perks.fallen_knight ? (Number(spell_power) + 5) : spell_power,	magic_perks.dark,3,  0,   4,  0,   5,  0,   6,   0, playerFraction == 107 ? 1 + ability / 50 : 1),false,'dray'],
            'poison':			[isEn ? "Decay" : 'Разложение',					    (sсhoolsLevel >= 2 && schools.includes("dark")),6,false,damage(magic_perks.twilight ? (Number(spell_power) + magic_perks.fallen_knight ? 8 : 3) : magic_perks.fallen_knight ? (Number(spell_power) + 5) : spell_power,	magic_perks.dark,16,  4,  16,  4,  16,  4,  16,   4),false,'poison'],
            'weakness':			[isEn ? "Weakness" : 'Слабость',					(sсhoolsLevel >= 3 && schools.includes("dark") && (magic_perks.dark >= 1 || magic_perks.magic_insight)),5,false,damage(magic_perks.twilight ? (Number(spell_power) + magic_perks.fallen_knight ? 8 : 3) : magic_perks.fallen_knight ? (Number(spell_power) + 5) : spell_power,	magic_perks.dark,3,  0,   6,  0,   9,  0,  12,   0, playerFraction == 107 ? 1 + ability / 50 : 1),(magic_perks.twilight ? (Number(spell_power) + magic_perks.fallen_knight ? 8 : 3) : magic_perks.fallen_knight ? (Number(spell_power) + 5) : spell_power) < 1 ? 0.5 : magic_perks.twilight ? (Number(spell_power) + magic_perks.fallen_knight ? 8 : 3) : magic_perks.fallen_knight ? (Number(spell_power) + 5) : spell_power,'suffering'],
            'distraction':		[isEn ? "Confusion" : 'Забывчивость',				(sсhoolsLevel >= 3 && schools.includes("dark") && (magic_perks.dark >= 1 || magic_perks.magic_insight)),9,false,damage(magic_perks.twilight ? (Number(spell_power) + magic_perks.fallen_knight ? 8 : 3) : magic_perks.fallen_knight ? (Number(spell_power) + 5) : spell_power,	magic_perks.dark,25,  0,  40,  0,  55,  0,  70,   0) + '%',(magic_perks.twilight ? (Number(spell_power) + magic_perks.fallen_knight ? 8 : 3) : magic_perks.fallen_knight ? (Number(spell_power) + 5) : spell_power) < 1 ? 0.5 : magic_perks.twilight ? (Number(spell_power) + magic_perks.fallen_knight ? 8 : 3) : magic_perks.fallen_knight ? (Number(spell_power) + 5) : spell_power,'confusion'],
            'berserker':		[isEn ? "Berserker" : 'Берсерк',					(sсhoolsLevel >= 4 && schools.includes("dark") && magic_perks.dark >= 2 && playerFraction != 205),15,false,damage(magic_perks.twilight ? (Number(spell_power) + magic_perks.fallen_knight ? 8 : 3) : magic_perks.fallen_knight ? (Number(spell_power) + 5) : spell_power,	magic_perks.dark,0,  0,   0,  0,  80, 30, 100,  35),1,'frenzy'],
            'blindness':		[isEn ? "Blind" : 'Ослепление',					    (sсhoolsLevel >= 4 && schools.includes("dark") && magic_perks.dark >= 2 && playerFraction != 205),10,false,damage(magic_perks.twilight ? (Number(spell_power) + magic_perks.fallen_knight ? 8 : 3) : magic_perks.fallen_knight ? (Number(spell_power) + 5) : spell_power,	magic_perks.dark,0,  0,   0,  0, 150, 30, 250,  40),(magic_perks.twilight ? (Number(spell_power) + magic_perks.fallen_knight ? 8 : 3) : magic_perks.fallen_knight ? (Number(spell_power) + 5) : spell_power) < 1 ? 0.5 : magic_perks.twilight ? (Number(spell_power) + magic_perks.fallen_knight ? 8 : 3) : magic_perks.fallen_knight ? (Number(spell_power) + 5) : spell_power,'blind'],
            //		Массовый Свет
            'm_speed':			[isEn ? "Mass Rapid" : 'Массовое Ускорение',			(sсhoolsLevel >= 1 && magic_perks.master_of_wrath) || magic_perks.power_of_speed || checkSet('inq'),8,false,damage(magic_perks.twilight ? (Number(spell_power) + 3) : spell_power,checkSet('inq') ? 3 : (magic_perks.power_of_speed && (magic_perks.light < 2 || !magic_perks.master_of_wrath) ) ? 2 : magic_perks.light,20,  0,  25,  0,  30,  0,  40,   0, playerFraction == 101 ? 1 + ability / 50 : 1) + '%',(magic_perks.twilight ? (Number(spell_power) + 3) : spell_power) < 1 ? 0.5 : magic_perks.twilight ? (Number(spell_power) + 3) : spell_power,'fast'],
            'm_bless':			[isEn ? "Mass Bless" : 'Массовое Благословение',		(sсhoolsLevel >= 1 && magic_perks.master_of_blessings ),8,false,damage(magic_perks.twilight ? (Number(spell_power) + 3) : spell_power,magic_perks.light,50,  0,  65,  0,  85,  0, 100,   0) + '%',(magic_perks.twilight ? (Number(spell_power) + 3) : spell_power) < 1 ? 0.5 : magic_perks.twilight ? (Number(spell_power) + 3) : spell_power,'bless'],
            'm_stoneSkin':		[isEn ? "Mass Stoneskin" : 'Массовая Каменная кожа',		((sсhoolsLevel >= 2 && magic_perks.master_of_abjuration) || magic_perks.power_of_endurance || checkSet('druid') ),12,false,damage(magic_perks.twilight ? (Number(spell_power) + 3) : spell_power,checkSet('druid') ? 3 : ((magic_perks.power_of_endurance && (magic_perks.light < 2 || !magic_perks.master_of_abjuration) ) ? 2 : magic_perks.light),	  3,  0,   6,  0,   9,  0,  12,   0, playerFraction == 101 ? 1 + ability / 50 : 1),(magic_perks.twilight ? (Number(spell_power) + 3) : spell_power) < 1 ? 0.5 : magic_perks.twilight ? (Number(spell_power) + 3) : spell_power,'stoneskin'],
            'm_dispell':		[isEn ? "Mass Dispersion" : 'Массовое Рассеивание',		(sсhoolsLevel >= 2 && magic_perks.master_of_blessings ),20,false,damage(magic_perks.twilight ? (Number(spell_power) + 3) : spell_power,magic_perks.light,40,  0,  60,  0,  80,  0, 100,   0),false,'dispel'],
            'm_evasion':		[isEn ? "Mass Evasion" : 'Массовое Уклонение',			(sсhoolsLevel >= 3 && magic_perks.master_of_abjuration ),12,false,damage(magic_perks.twilight ? (Number(spell_power) + 3) : spell_power,magic_perks.light,25,  0,  40,  0,  55,  0,  70,   0) + '%',(magic_perks.twilight ? (Number(spell_power) + 3) : spell_power) < 1 ? 0.5 : magic_perks.twilight ? (Number(spell_power) + 3) : spell_power,'deflect_missile'],
            'm_punishingBlow':	[isEn ? "Mass Chastise" : 'Массовый Карающий удар',		((sсhoolsLevel >= 3 && magic_perks.master_of_wrath) || checkSet('paladin')),12,false,damage(magic_perks.twilight ? (Number(spell_power) + 3) : spell_power,checkSet('paladin') ? 3 : magic_perks.light,3,  0,   6,  0,   9,  0,  12,   0, playerFraction == 101 ? 1 + ability / 50 : 1),(magic_perks.twilight ? (Number(spell_power) + 3) : spell_power) < 1 ? 0.5 : magic_perks.twilight ? (Number(spell_power) + 3) : spell_power,'righteous_might'],
            //		Массовая Тьма
            'm_slow':			[isEn ? "Mass Delay" : 'Массовое Замедление',			(sсhoolsLevel >= 1 && magic_perks.master_of_mind ),8,false,damage(magic_perks.twilight ? (Number(spell_power) + magic_perks.fallen_knight ? 8 : 3) : magic_perks.fallen_knight ? (Number(spell_power) + 5) : spell_power,	magic_perks.dark,20,  0,  25,  0,  30,  0,  40,   0, playerFraction == 107 ? 1 + ability / 50 : 1) + '%',(magic_perks.twilight ? (Number(spell_power) + magic_perks.fallen_knight ? 8 : 3) : magic_perks.fallen_knight ? (Number(spell_power) + 5) : spell_power) < 1 ? 0.5 : magic_perks.twilight ? (Number(spell_power) + magic_perks.fallen_knight ? 8 : 3) : magic_perks.fallen_knight ? (Number(spell_power) + 5) : spell_power, 	'slow'],
            'm_curse':			[isEn ? "Mass Curse" : 'Массовое Проклятие',			(sсhoolsLevel >= 1 && magic_perks.master_of_curses ),8,false,damage(magic_perks.twilight ? (Number(spell_power) + magic_perks.fallen_knight ? 8 : 3) : magic_perks.fallen_knight ? (Number(spell_power) + 5) : spell_power,	magic_perks.dark,50,  0,  65,  0,  80,  0, 100,   0) + '%',(magic_perks.twilight ? (Number(spell_power) + magic_perks.fallen_knight ? 8 : 3) : magic_perks.fallen_knight ? (Number(spell_power) + 5) : spell_power) < 1 ? 0.5 : magic_perks.twilight ? (Number(spell_power) + magic_perks.fallen_knight ? 8 : 3) : magic_perks.fallen_knight ? (Number(spell_power) + 5) : spell_power, 	'curse'],
            'm_disruptingRay':	[isEn ? "Mass Disruption ray" : 'Массовый Разрушающий луч',	(sсhoolsLevel >= 2 && magic_perks.master_of_pain ),10,false,damage(magic_perks.twilight ? (Number(spell_power) + magic_perks.fallen_knight ? 8 : 3) : magic_perks.fallen_knight ? (Number(spell_power) + 5) : spell_power,	magic_perks.dark,3,  0,   4,  0,   5,  0,   6,   0, playerFraction == 107 ? 1 + ability / 50 : 1),false,'dray'],
            'm_poison':			[isEn ? "Mass Decay" : 'Массовое Разложение',			(sсhoolsLevel >= 2 && magic_perks.master_of_pain ),12,false,damage(magic_perks.twilight ? (Number(spell_power) + magic_perks.fallen_knight ? 8 : 3) : magic_perks.fallen_knight ? (Number(spell_power) + 5) : spell_power,	magic_perks.dark,16,  4,  16,  4,  16,  4,  16,   4),false,'poison'],
            'm_weakness':		[isEn ? "Mass Weakness" : 'Массовое Слабость',			(sсhoolsLevel >= 3 && magic_perks.master_of_curses ),10,false,damage(magic_perks.twilight ? (Number(spell_power) + magic_perks.fallen_knight ? 8 : 3) : magic_perks.fallen_knight ? (Number(spell_power) + 5) : spell_power,	magic_perks.dark,3,  0,   6,  0,   9,  0,  12,   0, playerFraction == 107 ? 1 + ability / 50 : 1),(magic_perks.twilight ? (Number(spell_power) + magic_perks.fallen_knight ? 8 : 3) : magic_perks.fallen_knight ? (Number(spell_power) + 5) : spell_power) < 1 ? 0.5 : magic_perks.twilight ? (Number(spell_power) + magic_perks.fallen_knight ? 8 : 3) : magic_perks.fallen_knight ? (Number(spell_power) + 5) : spell_power, 	'suffering'],
            'm_distraction':	[isEn ? "Mass Confusion" : 'Массовое Забывчивость',		(sсhoolsLevel >= 3 && magic_perks.master_of_mind),18,false,damage(magic_perks.twilight ? (Number(spell_power) + magic_perks.fallen_knight ? 8 : 3) : magic_perks.fallen_knight ? (Number(spell_power) + 5) : spell_power,	magic_perks.dark,25,  0,  40,  0,  55,  0,  70,   0) + '%',(magic_perks.twilight ? (Number(spell_power) + magic_perks.fallen_knight ? 8 : 3) : magic_perks.fallen_knight ? (Number(spell_power) + 5) : spell_power) < 1 ? 0.5 : magic_perks.twilight ? (Number(spell_power) + magic_perks.fallen_knight ? 8 : 3) : magic_perks.fallen_knight ? (Number(spell_power) + 5) : spell_power, 	'confusion'],
            //		Усиленный Хаос
            'm_magicArrow':		[isEn ? "Forced Magic arrow" : 'Усиленная Магическая стрела',	((sсhoolsLevel >= 1 && schools.includes("chaos")) && magic_perks.dark_power),8,Math.round(damage(spell_power,magic_perks.chaos,24,  8, 32,  8, 40,  8, 48,  8) * 1.5),false,false,'magicarrow'],
            'm_stoneSpikes':	[isEn ? "Forced Earthen spikes" : 'Усиленные Каменные шипы',		((playerFraction == 6 || (sсhoolsLevel >= 1 && schools.includes("chaos")) ) && magic_perks.dark_power),10,Math.round(damage(spell_power,magic_perks.chaos,8,   4, 12,  4, 16,  4, 20,  4) * 1.5),false,false,'stonespikes'],
            'm_lightning':		[isEn ? "Forced Lightning" : 'Усиленная Молния',			((sсhoolsLevel >= 2 && schools.includes("chaos")) && magic_perks.dark_power),10,Math.round(damage(spell_power,magic_perks.chaos,11, 11, 13, 13, 15, 15, 17, 17) * 1.5),false,false,'lighting'],
            'm_iceBolt':		[isEn ? "Forced Ice clod" : 'Усиленная Ледяная глыба',		((sсhoolsLevel >= 2 && schools.includes("chaos")) && magic_perks.dark_power),12,Math.round(damage(spell_power,magic_perks.chaos,30,  9, 44,  9, 59,  9, 74,  9) * 1.5),false,false,'icebolt'],
            'm_coldRing':		[isEn ? "Forced Ice ring" : 'Усиленное Кольцо холода',		((sсhoolsLevel >= 3 && schools.includes("chaos") && (magic_perks.chaos >= 1 || magic_perks.magic_insight)) && magic_perks.dark_power),18,Math.round(damage(spell_power,magic_perks.chaos,15,  6, 27,  6, 39,  6, 51,  6) * 1.5),false,false,'circle_of_winter'],
            'm_fireBall':		[isEn ? "Forced Fireball" : 'Усиленный Огненный шар',		(((sсhoolsLevel >= 3 && schools.includes("chaos") && (magic_perks.chaos >= 1 || magic_perks.magic_insight)) || checkSet('demon') ) && magic_perks.dark_power),checkSet('demon') ? 10 : 20,	Math.round(damage(spell_power,magic_perks.chaos,8,  8,  9,  9, 10, 10, 11, 11) * 1.5),false,false,'fireball'],
            'm_chainLightning':	[isEn ? "Forced Chain lightning" : 'Усиленная Цепная молния',		((sсhoolsLevel >= 4 && schools.includes("chaos") && magic_perks.chaos >= 2) && magic_perks.dark_power),32,Math.round(damage(spell_power,magic_perks.chaos,0,  0,  0,  0, 16, 16, 19, 19) * 1.5),false,false,'chainlighting'],
            'm_meteorRain':		[isEn ? "Forced Мeteorite rain" : 'Усиленный Метеоритный дождь',	((sсhoolsLevel >= 4 && schools.includes("chaos") && magic_perks.chaos >= 2) && magic_perks.dark_power),32,Math.round(damage(spell_power,magic_perks.chaos,0,  0,  0,  0, 16, 16, 19, 19) * 1.5),false,false,'meteor'],
            //		Уникальные умения
            'knight_mark':		[isEn ? "Escort" : 'Надзор',						magic_perks.knight_mark,0,false,false,false,'knightmark'],
            'divine':			[isEn ? "Fervor" : 'Воодушевление',				magic_perks.divine_guidance,0,false,33,false,'divine_guidance'],
            'elf_shot':		    [isEn ? "Rain of arrows" : 'Ливень стрел',				magic_perks.elf_shot,0,false,false,false,'elfshot'],
            'zakarrow':		    [isEn ? "Imbue arrow" : 'Заколдованная стрела',		magic_perks.zakarrow,0,false,false,false,'zakarrow'],
            'necr_soul':		[isEn ? "Spirit link" : 'Духовная связь',				magic_perks.necr_soul,0,false,false,false,'necr_soul'],
            'benediction':		[isEn ? "Prayer" : 'Молитва',				        magic_perks.benediction,0,false,false,false,'benediction'],
            'consumecorpse':	[isEn ? "Consume corpse" : 'Поглощение трупов',			magic_perks.consumecorpse,0,false,false,false,'consumecorpse'],
            // Кличи
            "rallingcry":       [isEn ? "Tribal supremacy" : "Объединяющий клич", sсhoolsLevel >= 1 && schools.includes("cries"), 8, false, `<img src="/i/icons/attr_morale.png" class="inline-image" title="${isEn ? "Morale" : "Мораль"}" alt="${isEn ? "Morale" : "Мораль"}">+${1 + Math.floor(playerLevel / 8)}`, 3, "rallingcry"],
            "callofblood":      [isEn ? "Tribute to spirits" : "Зов крови", sсhoolsLevel >= 1 && schools.includes("cries"), 5, false, `<img src="/i/klichi/blood_rage.jpg" class="inline-image" title="${isEn ? "Blood Rage" : "Ярость крови"}" alt="${isEn ? "Blood Rage" : "Ярость крови"}">+${playerLevel * 10}`, false, "callofblood"],
            "wordofchief":      [isEn ? "Lessons of history" : "Слово вождя", sсhoolsLevel >= 2 && schools.includes("cries"), 2, false, 0.1 + 0.02 * playerLevel, false, "wordofchief"],
            "fearmyroar":       [isEn ? "Ancestral wrath" : "Устрашающий рык", sсhoolsLevel >= 2 && schools.includes("cries"), 10, false, `${healthIco()} ${playerLevel * 70}`, false, "fearmyroar"],
            "battlecry":        [isEn ? "Battle cry" : "Боевой клич", sсhoolsLevel >= 3 && schools.includes("cries"), 10, false, `<img title="${isEn ? "Speed" : "Скорость"}" src="/i/icons/attr_speed.png" class="inline-image">+1 <img src="/i/icons/attr_attack.png" class="inline-image" title="${isEn ? "Attack" : "Атака"}" alt="${isEn ? "Attack" : "Атака"}">+${Math.floor(playerLevel / 2)}` , 1, "battlecry"],
            "angerofhorde":     [isEn ? "Tribal unity" : "Ярость орды", sсhoolsLevel >= 3 && schools.includes("cries"), 10, getTribalUnityDamage(), false, false, "angerofhorde"],
            // Умения тёмного эльфа-укротителя
            "summoncreature1":  [isEn ? "Summon Spiders" : "Призыв пауков",          playerFraction == 106 && sсhoolsLevel >= 1 && !magic_perks.cre_master, 10, false, darkElfSummon(playerLevel, 1, ability), false, "summoncreature1"],
            "summoncreature2":  [isEn ? "Summon Venomous spiders" : "Призыв ядовитых пауков", playerFraction == 106 && sсhoolsLevel >= 1 && magic_perks.cre_master, 10, false, darkElfSummon(playerLevel, 1, ability), false, "summoncreature2"],
            "summoncreature3":  [isEn ? "Summon Harpies" : "Призыв гарпий",          playerFraction == 106 && sсhoolsLevel >= 2 && !magic_perks.cre_master, 10, false, darkElfSummon(playerLevel, 2, ability), false, "summoncreature3"],
            "summoncreature4":  [isEn ? "Summon Raiding harpies" : "Призыв гарпий-ведьм",    playerFraction == 106 && sсhoolsLevel >= 2 && magic_perks.cre_master, 10, false, darkElfSummon(playerLevel, 2, ability), false, "summoncreature4"],
            "summoncreature5":  [isEn ? "Summon Beholders" : "Призыв бехолдеров",      playerFraction == 106 && sсhoolsLevel >= 3 && !magic_perks.cre_master, 10, false, darkElfSummon(playerLevel, 3, ability), false, "summoncreature5"],
            "summoncreature6":  [isEn ? "Summon shadow eyes" : "Призыв глаз тьмы",       playerFraction == 106 && sсhoolsLevel >= 3 && magic_perks.cre_master, 10, false, darkElfSummon(playerLevel, 3, ability), false, "summoncreature6"],
            "summoncreature7":  [isEn ? "Summon Trolls" : "Призыв троллей",         playerFraction == 106 && sсhoolsLevel >= 4 && !magic_perks.cre_master, 10, false, darkElfSummon(playerLevel, 4, ability), false, "summoncreature7"],
            "summoncreature8":  [isEn ? "Summon crazed trolls" : "Призыв черных троллей",  playerFraction == 106 && sсhoolsLevel >= 4 && magic_perks.cre_master, 10, false, darkElfSummon(playerLevel, 4, ability), false, "summoncreature8"],
            // Пятая школа магии
            'arcanearmor':	    [isEn ? "Celestial shield" : 'Небесный щит',	    fiveSchoolTest||(sсhoolsLevel >= 5 && schools.includes("nature") && magic_perks.nature >= 3),20,false,`${healthIco()} ${damage(spell_power,magic_perks.nature,250,25,500,50,600,60,600,60)}`,false,"arcanearmor"],
            'summonphoenix':	[isEn ? "Summon phoenix" : 'Призыв Феникса',	    fiveSchoolTest||(sсhoolsLevel >= 5 && schools.includes("nature") && magic_perks.nature >= 3),35,false,`${healthIco()} ${300 + 15 * spell_power} ${damageIco()} ${15 + 15 * spell_power}-${20 + 20 * spell_power}`,false,"summonphoenix"],
            'deepfreeze':		[isEn ? "Permeating cold" : 'Останавливающий холод',fiveSchoolTest||(sсhoolsLevel >= 5 && schools.includes("chaos") && magic_perks.chaos >= 3),11,damage(spell_power,magic_perks.chaos,10,10,14,14,15,15,30,30),false,false,'',"spell-wiki-image"],
            'implosion':		[isEn ? "Implosion" : 'Взрыв',		                fiveSchoolTest||(sсhoolsLevel >= 5 && schools.includes("chaos") && magic_perks.chaos >= 3),18,damage(spell_power,magic_perks.chaos,12,12,17,17,20,20,40,40),false,false,'implosion'],
            'armageddon':		[isEn ? "Armageddon" : 'Армагеддон',		        fiveSchoolTest||(sсhoolsLevel >= 5 && schools.includes("chaos") && magic_perks.chaos >= 3),20,`${damage(spell_power,magic_perks.chaos,9,9,12,12,15,15,30,30)} + ${damage(spell_power,magic_perks.chaos,5,5,10,10,15,15,20,20)}`,false,false,'https://daily-help.ru/img/armagedon-fake.png'],
            'divinevengeance':	[isEn ? "Divine retribution" : 'Божественная месть',fiveSchoolTest||(sсhoolsLevel >= 5 && schools.includes("light") && magic_perks.light >= 3),14,`X*${30 + 2 * spell_power}`,false,false,'divinev'],
            'WordofLight':	[isEn ? "Word of Light" : 'Святое слово',		        fiveSchoolTest||(sсhoolsLevel >= 5 && schools.includes("light") && magic_perks.light >= 3),11,damage(spell_power,magic_perks.light,8, 2, 12, 3, 30, 6, 144, 12),false,false,'',"spell-wiki-image"],
            'resurrection2':	[isEn ? "Resurrection" : 'Воскрешение',		        fiveSchoolTest||(sсhoolsLevel >= 5 && schools.includes("light") && magic_perks.light >= 3),15,false,`${healthIco()} ${damage(spell_power,magic_perks.light,20, 5, 40, 10, 60, 15, 240, 30)}`,false,'resurrection2'],
            'sorrow':		    [isEn ? "Affliction" : 'Скорбь',				    fiveSchoolTest||(sсhoolsLevel >= 5 && schools.includes("dark") && magic_perks.dark >= 3 && playerFraction != 205),5,false,`${moraleluckIco()}-2`,Math.max(spell_power,1),'https://daily-help.ru/img/sorrow-fake.png'],
            'vampirizm':		[isEn ? "Vampirism" : 'Вампиризм',					fiveSchoolTest||(sсhoolsLevel >= 5 && schools.includes("dark") && magic_perks.dark >= 3 && playerFraction != 205),10,false,`${50 + 2 * spell_power}2%`,false,'', "spell-wiki-image"],
            'Netherworld':		[isEn ? "Curse of the Netherworld" : 'Нечестивое слово',fiveSchoolTest||(sсhoolsLevel >= 5 && schools.includes("dark") && magic_perks.dark >= 3 && playerFraction != 205),15,damage(spell_power + (magic_perks.master_of_pain ? 4 : 0),magic_perks.dark,8, 2, 12, 3, 30, 6, 144, 12),false,false,'', "spell-wiki-image"],
            'hypnos':		    [isEn ? "Hypnosis" : 'Гипноз',					    fiveSchoolTest||(sсhoolsLevel >= 5 && schools.includes("dark") && magic_perks.dark >= 3 && playerFraction != 205),18,false,0.25 * spell_power,false,'https://daily-help.ru/img/hypnos-fake.png'],
        }
        const spells = Object.keys(allSpells).filter(x => allSpells[x][1]).map(x => allSpells[x]);
        if(spells.length == 0) {
            return;
        }
        //console.log(spells);
        //console.log(`playerLevel: ${playerLevel}, playerFraction: ${playerFraction}, sсhoolsLevel: ${sсhoolsLevel}, ability: ${ability}, schools: ${schools.join(", ")}`);
        let bookRefContainer = document.querySelector("div.slot11");
        if(!bookRefContainer) {
            const skillInfoCell = Array.from(document.querySelectorAll("td:not(:has(td))")).find(x => (x.innerHTML.includes(t('Knight')) || x.innerHTML.includes('Кавалер')) && x.innerHTML.includes(t('Enchanters')));
            bookRefContainer = skillInfoCell.closest("table").previousSibling;
            bookRefContainer.style.position = "relative";
        }
        //console.log(bookRefContainer);
        if(!bookRefContainer) {
            return;
        }
        const spell_book_img = addElement("div", { style: `position: absolute; bottom: 0px; right: 0px; width: 24px; height: 24px; cursor: pointer; z-index: 19; background-size: contain; background-repeat: no-repeat; background-image: url(https://qcdn3.heroeswm.ru/i/combat/btn_book_off.png);`, title: isEn ? "Magic book" : "Книга магии" }, bookRefContainer);
        spell_book_img.addEventListener('click', function() { showSpellBook(spells, magic_perks, knowledge); }, true );
        addStyle(`
.inline-image {
    width: 20px;
    height: 20px;
    vertical-align: middle;
    mix-blend-mode: multiply;
}
.spell-image {
    width: auto;
    height: 164px;
}
.spell-wiki-image {
    height: 110px;
}
table.spell-book-spells {
    width: 100%;
    height: 100%;
    border-collapse: collapse;
    border-spacing: 0;
    border: 0;
}
table.spell-book-spells>tbody>tr>td {
    padding: 0px;
}
tr.spell-cell {
    height: 164px;
}
tr.spell-cell>td {
    text-align: center;
    position: relative;
}
tr.spell-cell>td>div[name=spellName] {
    display: block;
    position: absolute;
    width: 100%;
    bottom: 16px;
    left: 0px;
    height: 16px;
    align-items: center;
    color: white;
    text-shadow: 0px 0px 2px #000, 0px 0px 2px #000;
    font-weight: bold;
}
tr.spell-cell>td>div[name=spellEffects] {
    display: block;
    position: absolute;
    width: 100%;
    bottom: 16px;
    left: 0px;
    height: 0px;
    align-items: center;
    color: white;
    text-shadow: 0px 0px 2px #000, 0px 0px 2px #000;
    font-weight: bold;
}
.book_arrow {
    width: 98%;
    height: 100%;
    cursor: pointer;
    display: none;
}
.book_arrow_left{
	left: 2%;
	background:url('/i/combat/book_btn_arrow_left.png') right center no-repeat;
	background-size: 90%;
}

.book_arrow_right {
	right: 2%;
	background:url('/i/combat/book_btn_arrow_right.png') left center no-repeat;
	background-size: 90%;
}

.book_arrow_left:hover, .book_arrow_right:hover {
	background-size: 100%;
	-webkit-filter: brightness(150%) drop-shadow(0 0 5px #ffe4b3);
  	filter: brightness(150%) drop-shadow(0 0 5px #ffe4b3);
}

.book_bookmark_right {
    margin-left: 20%;
	width: 60%;
    height: 60%;
    cursor: pointer;
	background:url('https://qcdn.heroeswm.ru/i/combat/book_bookmark_right.png?v=6') center center no-repeat;
    background-size: 300%;
}

.book_bookmark_right:hover {
	-webkit-filter: brightness(125%) drop-shadow(0 0 5px #ffe4b3);
  	filter: brightness(125%) drop-shadow(0 0 5px #ffe4b3);
}
`);
    }
}
function healthIco() { return `<font style="color: red;">❤</font>`; }
function damageIco() { return `<img class="inline-image" src="/i/icons/attr_damage.png">`; }
function moraleluckIco() { return `<img class="inline-image" src="https://daily-help.ru/img/stats-new/attr_moraleluck.png" title="${isEn ? "Changes to stack morale and luck" : "Изменение боевого духа и удачи стека"}">`; }

function checkSet(set) {
    const sets = new Array();
    let minCnt;
    switch(set) {
        case 'druid':
            sets[5] = 'druid_staff';
            sets[7] = 'druid_boots';
            sets[4] = 'druid_cloack';
            sets[3] = 'druid_armor';
            sets[2] = 'druid_amulet';
            minCnt = 4;
            break;
        case 'demon':
            sets[5] = 'dem_axe';
            sets[6] = 'dem_shield';
            sets[7] = 'dem_bootshields';
            sets[3] = 'dem_armor';
            sets[2] = 'dem_amulet';
            sets[1] = 'dem_helmet';
            minCnt = 6;
            break;
        case 'paladin':
            sets[5] = 'paladin_sword';
            sets[6] = 'paladin_shield';
            sets[7] = 'paladin_boots';
            sets[3] = 'paladin_armor';
            sets[1] = 'paladin_helmet';
            sets[4] = 'paladin_bow';
            minCnt = 6;
            break;
        case 'necr':
            sets[5] = 'necr_staff';
            sets[3] = 'necr_robe';
            sets[1] = 'necr_helm';
            sets[2] = 'necr_amulet';
            minCnt = 4;
            break;
        case 'inq':
            sets[5] = 'inq_weap';
            sets[7] = 'inq_boot';
            sets[3] = 'inq_body';
            sets[4] = 'inq_cl';
            sets[1] = 'inq_helm';
            minCnt = 4;
            break;
    }
    const arts = [...document.querySelectorAll("div[id^='slot'] > div > div > a[href^='art_info.php?id=']")].map(x => {
        return { slotIndex: parseInt(x.closest("div[id^='slot']").id.replace("slot", "")), artId: getUrlParamValue(x.href, "id") }
    });
    //console.log(arts);
    const cnt = arts.reduce((t, x) => { return t + (sets[x.slotIndex] && sets[x.slotIndex] == x.artId); }, 0);
    return cnt >= minCnt;
}
function damage(spell_power, perkLevel, base0, added0, base1, added1, base2, added2, base3, added3, multiplier = 1) {
    const dam = {
        0: (Number(base0) + (Number(added0) * spell_power)),
        1: (Number(base1) + (Number(added1) * spell_power)),
        2: (Number(base2) + (Number(added2) * spell_power)),
        3: (Number(base3) + (Number(added3) * spell_power))
    };
    return Math.round(multiplier * dam[perkLevel] - 0.5);
}
function getTribalUnityDamage() {
    const creatures = Array.from(document.querySelectorAll(`div.${isNewPersonPage ? "castle_creature54" : "cre_creature72"}`)).filter(x => x.querySelector("div#add_now_count")).map(x => ({ Name: getUrlParamValue(x.querySelector("a[href^='army_info.php?name=']").href, "name"),  Amount: parseInt(x.querySelector("div#add_now_count").innerText) }));
    const result = creatures.reduce((t, x) => { t+= x.Amount; return t; }, 0);
    return result;
}
function darkElfSummon(playerLevel, sсhoolsLevel, skillLevel = 12, summonsCount = 0) {
    let baseValues;
    if(sсhoolsLevel == 1) {
        baseValues = { 5: 5.1, 6: 6.5, 7: 8.3, 8: 12.2, 9: 16.2, 10: 21.8, 11: 28.2, 12: 40.3, 13: 47.2, 14: 55.5, 15: 62.1, 16: 69.35, 17: 76, 18: 83.3, 19: 89.39, 20: 97, 21: 103.3, 22: 105.7, 23: 107.6, 24: 111.5, 25: 117.1 };
    }
    if(sсhoolsLevel == 2) {
        baseValues = { 8: 5.5, 9: 7.2, 10: 9.6, 11: 12.4, 12: 18, 13: 20.9, 14: 24.8, 15: 27.8, 16: 30.99, 17: 34.0, 18: 37.6, 19: 40.3, 20: 43.3, 21: 46.3, 22: 47.5, 23: 48.3, 24: 50, 25: 52.5 };
    }
    if(sсhoolsLevel == 3) {
        baseValues = { 10: 10.6, 11: 13.7, 12: 19.6, 13: 22.9, 14: 26.9, 15: 30.3, 16: 33.8, 17: 37, 18: 40.9, 19: 43.9, 20: 47.1, 21: 50.6, 22: 51.8, 23: 52.6, 24: 54.5, 25: 56.7 };
    }
    if(sсhoolsLevel == 4) {
        baseValues = { 14: 4.8, 15: 5.3, 16: 5.9, 17: 6.5, 18: 7, 19: 7.8, 20: 8.4, 21: 9, 22: 9.3, 23: 9.4, 24: 9.4, 25: 10 };
    }
    const baseSummonValue = baseValues[playerLevel];
    return Math.round(baseSummonValue * (1 + 0.05 * skillLevel) * Math.pow(0.9, summonsCount));

}
function showSpellBook(spells, magic_perks, knowledge) {
    const mana = knowledge * (magic_perks.intelligence ? 15 : 10);
    // <table cellspacing="0" cellpadding="0" border="0" style="width: 981; height: 674; background-size: contain; background-repeat: no-repeat; background-image:url('/i/combat/book_bg.png');">
    let spellBookDiv = document.getElementById('spellBookDiv');
    if(spellBookDiv) {
        spellBookDiv.style.display = spellBookDiv.style.display == "block" ? "none" : "block";
        return;
    }
    spellBookDiv = addElement('div', { id: "spellBookDiv", style: `width: 100%; position: absolute; top: 150px; z-index: 20;`, align: "center" }, document.body);
    spellBookDiv.innerHTML = `
<table cellspacing="0" cellpadding="0" border="0" style="width: 981; height: 674; background-image:url(${bookImage});">
    <tr height="28">
        <td rowspan="3" style="width: 100;"></td>
        <td style="width: 781;"></td>
        <td rowspan="3" style="width: 100;"></td>
    </tr>
    <tr style="height: 508;">
        <td>
            <table style="width: 100%; height: 100%;" cellspacing="0" cellpadding="0" border="0">
                <tr>
                    <td style="width: 110;">
                        <table style="width: 100%; height: 100%;" cellspacing="0" cellpadding="0" border="0">
                            <tr style="height: 40;">
                                <td style="width: ${is_firefox ? '57' : '44'};"></td>
                                <td style="width: 40;">
                                    <div id="previousSpellBookPage" class="book_arrow book_arrow_left"></div>
                                </td>
                                <td></td>
                            </tr>
                            <tr>
                                <td></td>
                                <td></td>
                                <td></td>
                            </tr>
                        </table>
                    </td>
                    <td style="width: 230;">
                        <table class="spell-book-spells">
                            <tr class="spell-cell">
                                <td></td>
                            </tr>
                            <tr class="spell-cell">
                                <td></td>
                            </tr>
                            <tr class="spell-cell">
                                <td></td>
                            </tr>
                            <tr style="height: 16;">
                                <td></td>
                            </tr>
                        </table>
                    </td>
                    <td style="width: 100;"></td>
                    <td style="width: 230;">
                        <table class="spell-book-spells">
                            <tr class="spell-cell">
                                <td></td>
                            </tr>
                            <tr class="spell-cell">
                                <td></td>
                            </tr>
                            <tr class="spell-cell">
                                <td></td>
                            </tr>
                            <tr style="height: 16;">
                                <td></td>
                            </tr>
                        </table>
                    </td>
                    <td style="width: 110;">
                        <table style="width: 100%; height: 100%;" cellspacing="0" cellpadding="0" border="0">
                            <tr style="height: 50%;">
                                <td>
                                    <table style="width: 100%; height: 100%;" cellspacing="0" cellpadding="0" border="0">
                                        <tr style="height: 40;">
                                            <td style="width: ${is_firefox ? '10' : '4'};">
                                            </td>
                                            <td style="width: 40;">
                                                <div id="nextSpellBookPage" class="book_arrow book_arrow_right"></div>
                                            </td>
                                            <td></td>
                                        </tr>
                                        <tr>
                                            <td></td>
                                            <td></td>
                                            <td></td>
                                        </tr>
                                    </table>
                                </td>
                            </tr>
                            <tr>
                                <td>
                                    <table style="width: 100%; height: 100%;" cellspacing="0" cellpadding="0" border="0">
                                        <tr style="height: 175;">
                                            <td style="width: ${is_firefox ? '26' : '23'};">
                                            </td>
                                            <td style="width: 69;">
                                            </td>
                                            <td></td>
                                        </tr>
                                        <tr>
                                            <td></td>
                                            <td>
                                                <div id="closeSpellBookButton" class="book_bookmark_right"></div>
                                            </td>
                                            <td></td>
                                        </tr>
                                        <tr style="height: 13;">
                                            <td></td>
                                            <td></td>
                                        </tr>
                                    </table>
                                </td>
                            </tr>
                        </table>
                    </td>
                </tr>
            </table>
        </td>
    </tr>
    <tr>
        <td>
            <table style="width: 100%; height: 100%;" cellspacing="0" cellpadding="0" border="0">
                <tr style="height: 65;">
                    <td style="width: 190;"></td>
                    <td style="width: 109; position: relative;"><div style="display: ${isEn ? "block" : "none"}; position: absolute; bottom: 0; left: 5%; width: 95%; height: 30px; background-color: #e6c898; color: rgb(0, 0, 152); font-size: 21px; font-weight: bold; text-align: center;box-shadow: inset 0px 11px 8px -10px #8c7c63, inset 0px -0px 0px -10px #CCC;">${isEn ? "Mana" : 'Мана'}</div></td>
                    <td align="right" valign="middle" style="color: rgb(225, 200, 155);"><span id=bookPagesCounterSpan></span> by <a href="/pl_info.php?id=315834" style="color: rgb(225, 200, 155);">Alex_2oo8</a>&nbsp;&nbsp;&nbsp;&nbsp;</td>
                </tr>
                <tr style="height: 40;">
                    <td></td>
                    <td id="manaCell" align="center" style="color: rgb(0, 0, 152); font-size: 21px; font-weight: bold;">${mana}/${mana}</td>
                    <td></td>
                </tr>
                <tr>
                    <td></td>
                    <td></td>
                    <td></td>
                </tr>
            </table>
        </td>
    </tr>
</table>`;
    const sorcery = magic_perks.sorcery;
    document.getElementById('previousSpellBookPage').addEventListener('click', function() { currentBookPage--; showPage(spells, sorcery, mana); });
    document.getElementById('nextSpellBookPage').addEventListener('click', function() { currentBookPage++; showPage(spells, sorcery, mana) });
    document.getElementById('closeSpellBookButton').addEventListener('click', function() { spellBookDiv.style.display = "none"; });
    showPage(spells, sorcery, mana);
}
function showPage(spells, sorcery, mana) {
    const spellCells = [...document.querySelectorAll("tr.spell-cell>td")];
    const pageSize = spellCells.length;
    const bookSize = Math.ceil(spells.length / pageSize);
    document.getElementById('nextSpellBookPage').style.display = bookSize > currentBookPage ? 'block' : "none";
    document.getElementById('previousSpellBookPage').style.display = (currentBookPage > 1 ? 'block' : "none");
    const pageSpells = spells.slice((currentBookPage - 1) * pageSize, currentBookPage * pageSize); //console.log(pageSpells);
    document.getElementById('bookPagesCounterSpan').innerText = `${currentBookPage} ${isEn ? "of" : "из"} ${bookSize}`;
    
    spellCells.forEach((spellCell, i) => {
        const spell = pageSpells[i];
        const cost = spell ? (sorcery >= 2 ? (sorcery >= 3 ? (Math.round(spell[2] * 0.64)) : (Math.round(spell[2] * 0.8))) : (sorcery >= 3 ? (Math.round(spell[2] * 0.8)) : spell[2])) : 0;
        const effectsText = [];
        if(spell) {
            effectsText.push(`${isEn ? "Mana" : 'Мана'}: ${cost}`);
            const names = new Array(isEn ? "Damage" : 'Урон', isEn ? "Effect" : 'Эффект', isEn ? "Duration" : 'Ходов');
            spell.slice(3, 3 + 3).map((x, i) => { return { name: names[i], value: x }; }).filter(x => x.value).forEach((x, i) => {
                effectsText.push(`${x.name}: ${x.value}`);
            });
        }
        const spellImage = spell ? (spell[6].length > 30 ? spell[6] : `/i/combat/magicbook/${spell[6]}.png`) : "";
        spellCell.innerHTML = spell ? `<img src="${spellImage}" class="spell-image${spell[7] ? ` ${spell[7]}` : ""}" style="opacity: ${mana >= cost ? '1' : '0.5'};">
<div name=spellName>${spell[0]}</div>
<div name=spellEffects>${effectsText.join(", ")}</div>` : "";
    });
}
// API
function getURL(url) { window.location.href = url; }
function createDataList(inputElement, dataListId, buttonsClass) {
    const datalist = addElement("datalist", { id: dataListId });
    const valuesData = getValue("DataList" + dataListId);
    let values = [];
    if(valuesData) {
        values = valuesData.split(",");
    }
    for(const value of values) {
        addElement("option", { value: value }, datalist);
    }
    inputElement.parentNode.insertBefore(datalist, inputElement.nextSibling);
    inputElement.setAttribute("list", dataListId);

    const clearListButton = addElement("input", { type: "button", value: "x", title: LocalizedString.ClearList, class: buttonsClass, style: "min-width: 20px; width: 20px; text-align: center; padding: 2px 2px 2px 2px;" });
    clearListButton.addEventListener("click", function() { if(window.confirm(LocalizedString.ClearList)) { deleteValue("DataList" + dataListId); datalist.innerHTML = ""; } }, false);
    inputElement.parentNode.insertBefore(clearListButton, datalist.nextSibling);

    return datalist;
}
function showCurrentNotification(html) {
    //GM_setValue("CurrentNotification", `{"Type":"1","Message":"The next-sibling combinator is made of the code point that separates two compound selectors. The elements represented by the two compound selectors share the same parent in the document tree and the element represented by the first compound selector immediately precedes the element represented by the second one. Non-element nodes (e.g. text between elements) are ignored when considering the adjacency of elements."}`);
    if(!isHeartOnPage) {
        return;
    }
    let currentNotificationHolder = document.querySelector("div#currentNotificationHolder");
    let currentNotificationContent = document.querySelector("div#currentNotificationContent");
    if(!currentNotificationHolder) {
        currentNotificationHolder = addElement("div", { id: "currentNotificationHolder", style: "display: flex; position: fixed; transition-duration: 0.8s; left: 50%; transform: translateX(-50%); bottom: -300px; width: 200px; border: 2px solid #000000; background-image: linear-gradient(to bottom, #EAE0C8 0%, #DBD1B9 100%); font: 10pt sans-serif;" }, document.body);
        currentNotificationContent = addElement("div", { id: "currentNotificationContent", style: "text-align: center;" }, currentNotificationHolder);
        const divClose = addElement("div", { title: isEn ? "Close" : "Закрыть", innerText: "x", style: "border: 1px solid #abc; flex-basis: 15px; height: 15px; text-align: center; cursor: pointer;" }, currentNotificationHolder);
        divClose.addEventListener("click", function() {
            const rect = currentNotificationHolder.getBoundingClientRect();
            currentNotificationHolder.style.bottom = `${-rect.height-1}px`;
        });
    }
    currentNotificationContent.innerHTML = html;
    const rect = currentNotificationHolder.getBoundingClientRect();
    currentNotificationHolder.style.bottom = `${-rect.height-1}px`;
    currentNotificationHolder.style.bottom = "0";
    setTimeout(function() { currentNotificationHolder.style.bottom = `${-rect.height-1}px`; }, 3000);
}
function sleep(ms) {
    return new Promise(resolve => setTimeout(resolve, ms));
}
// Array and object
function groupBy(list, keyFieldOrSelector) { return list.reduce(function(t, item) { const keyValue = typeof keyFieldOrSelector === 'function' ? keyFieldOrSelector(item) : item[keyFieldOrSelector]; (t[keyValue] = t[keyValue] || []).push(item); return t; }, {}); };
function getKeyByValue(object, value) { return Object.keys(object).find(key => object[key] === value); }
function findKey(obj, selector) { return Object.keys(obj).find(selector); }
function pushNew(array, newValue) { if(array.indexOf(newValue) == -1) { array.push(newValue); } }
function sortBy(field, reverse, evaluator) {
    const key = evaluator ? function(x) { return evaluator(x[field]); } : function(x) { return x[field]; };
    return function(a, b) { return a = key(a), b = key(b), (reverse ? -1 : 1) * ((a > b) - (b > a)); }
}
// HttpRequests
function getRequest(url, overrideMimeType = "text/html; charset=windows-1251") {
    return new Promise((resolve, reject) => {
        GM.xmlHttpRequest({ method: "GET", url: url, overrideMimeType: overrideMimeType,
            onload: function(response) { resolve((new DOMParser).parseFromString(response.responseText, "text/html")); },
            onerror: function(error) { reject(error); }
        });
    });
}
function getRequestText(url, overrideMimeType = "text/html; charset=windows-1251") {
    return new Promise((resolve, reject) => {
        GM.xmlHttpRequest({ method: "GET", url: url, overrideMimeType: overrideMimeType,
            onload: function(response) { resolve(response.responseText); },
            onerror: function(error) { reject(error); }
        });
    });
}
function postRequest(url, data) {
    return new Promise((resolve, reject) => {
        GM.xmlHttpRequest({ method: "POST", url: url, headers: { "Content-Type": "application/x-www-form-urlencoded" }, data: data,
            onload: function(response) { resolve(response); },
            onerror: function(error) { reject(error); }
        });
    });
}
function fetch({ url, method = 'GET', type = 'document', body = null }) {
    return new Promise((resolve, reject) => {
          const xhr = new XMLHttpRequest();
          xhr.open(method, url);
          xhr.responseType = type;

          xhr.onload = () => {
            if (xhr.status === 200) return resolve(xhr.response);
            throwError(`Error with status ${xhr.status}`);
          };

          xhr.onerror = () => throwError(`HTTP error with status ${xhr.status}`);

          xhr.send(body);

          function throwError(msg) {
            const err = new Error(msg);
            err.status = xhr.status;
            reject(err);
          }
    });
}
// Storage
function getValue(key, defaultValue) { return GM_getValue(key, defaultValue); };
function setValue(key, value) { GM_setValue(key, value); };
function deleteValue(key) { return GM_deleteValue(key); };
function getPlayerValue(key, defaultValue) { return getValue(`${key}${PlayerId}`, defaultValue); };
function setPlayerValue(key, value) { setValue(`${key}${PlayerId}`, value); };
function deletePlayerValue(key) { return deleteValue(`${key}${PlayerId}`); };
function getPlayerBool(valueName, defaultValue = false) { return getBool(valueName + PlayerId, defaultValue); }
function getBool(valueName, defaultValue = false) {
    const value = getValue(valueName);
    //console.log(`valueName: ${valueName}, value: ${value}, ${typeof(value)}`)
    if(value != undefined) {
        if(typeof(value) == "string") {
            return value == "true";
        }
        if(typeof(value) == "boolean") {
            return value;
        }
    }
    return defaultValue;
}
function setOrDeleteNumberValue(key, value) {
    if(!value || value == "" || isNaN(Number(value))) {
        deleteValue(key);
    } else {
        setValue(key, value);
    }
}
function setOrDeleteNumberPlayerValue(key, value) { setOrDeleteNumberValue(key + PlayerId, value); }
function getStorageKeys(filter) { return listValues().filter(filter); }
// Html DOM
function addElement(type, data = {}, parent = undefined, insertPosition = "beforeend") {
    const el = document.createElement(type);
    for(const key in data) {
        if(key == "innerText" || key == "innerHTML") {
            el[key] = data[key];
        } else {
            el.setAttribute(key, data[key]);
        }
    }
    if(parent) {
        if(parent.insertAdjacentElement) {
            parent.insertAdjacentElement(insertPosition, el);
        } else if(parent.parentNode) {
            switch(insertPosition) {
                case "beforebegin":
                    parent.parentNode.insertBefore(el, parent);
                    break;
                case "afterend":
                    parent.parentNode.insertBefore(el, parent.nextSibling);
                    break;
            }
        }
    }
    return el;
}
function addStyle(css) { addElement("style", { type: "text/css", innerHTML: css }, document.head); }
function getParent(element, parentType, number = 1) {
    if(!element) {
        return;
    }
    let result = element;
    let foundNumber = 0;
    while(result = result.parentNode) {
        if(result.nodeName.toLowerCase() == parentType.toLowerCase()) {
            foundNumber++;
            if(foundNumber == number) {
                return result;
            }
        }
    }
}
function getNearestAncestorSibling(node) {
    let parentNode = node;
    while((parentNode = parentNode.parentNode)) {
        if(parentNode.nextSibling) {
            return parentNode.nextSibling;
        }
    }
}
function getNearestAncestorElementSibling(node) {
    let parentNode = node;
    while((parentNode = parentNode.parentNode)) {
        if(parentNode.nextElementSibling) {
            return parentNode.nextElementSibling;
        }
    }
}
function nextSequential(node) { return node.firstChild || node.nextSibling || getNearestAncestorSibling(node); }
function nextSequentialElement(element) { return element.firstElementChild || element.nextElementSibling || getNearestAncestorElementSibling(element); }
function getSequentialsUntil(firstElement, lastElementTagName) {
    let currentElement = firstElement;
    const resultElements = [currentElement];
    while((currentElement = nextSequential(currentElement)) && currentElement.nodeName.toLowerCase() != lastElementTagName.toLowerCase()) {
        resultElements.push(currentElement);
    }
    if(currentElement) {
        resultElements.push(currentElement);
    }
    return resultElements;
}
function findChildrenTextContainsValue(selector, value) { return Array.from(document.querySelectorAll(selector)).reduce((t, x) => { const match = Array.from(x.childNodes).filter(y => y.nodeName == "#text" && y.textContent.includes(value)); return [...t, ...match]; }, []); }
function findSequentialTextContainsValue(node, value) {
    if(!node) {
        return;
    }
    let curNode = node;
    while(curNode = nextSequential(curNode)) {
        //console.log(`curNode.nodeName: ${curNode.nodeName}, curNode.textContent: ${curNode.textContent}`);
        if(curNode.nodeName == "#text" && curNode.textContent.includes(value)) {
            return curNode;
        }
    }
}
function findSiblingComment(node) {
    if(!node) {
        return;
    }
    let curNode = node;
    while(curNode = curNode.nextSibling) {
        //console.log(`curNode.nodeName: ${curNode.nodeName}, curNode.textContent: ${curNode.textContent}`);
        if(curNode.nodeName == "#comment") {
            return curNode;
        }
    }
}
// Popup panel
function createPupupPanel(panelName, panelTitle, fieldsMap, panelToggleHandler) {
    const backgroundPopupPanel = addElement("div", { id: panelName, style: "position: fixed; left: 0; top: 0; width: 100%; height: 100%; overflow: auto; background-color: rgb(0,0,0); background-color: rgba(0,0,0,0.4); z-index: 200;" }, document.body);
    backgroundPopupPanel.addEventListener("click", function(e) { if(e.target == this) { hidePupupPanel(panelName, panelToggleHandler); }});
    const topStyle = isMobileDevice ? "" : "top: 50%; transform: translateY(-50%);";
    const contentDiv = addElement("div", { style: `${topStyle} padding: 5px; display: flex; flex-wrap: wrap; position: relative; margin: auto; padding: 0; width: fit-content; background-image: linear-gradient(to right, #eea2a2 0%, #bbc1bf 19%, #57c6e1 42%, #b49fda 79%, #7ac5d8 100%); border: 1mm ridge rgb(211, 220, 50);` }, backgroundPopupPanel);
    if(panelTitle) {
        addElement("b", { innerHTML: panelTitle, style: "text-align: center; margin: auto; width: 90%; display: block;" }, contentDiv);
    }
    const divClose = addElement("span", { id: panelName + "close", title: isEn ? "Close" : "Закрыть", innerHTML: "&times;", style: "cursor: pointer; font-size: 20px; font-weight: bold;" }, contentDiv);
    divClose.addEventListener("click", function() { hidePupupPanel(panelName, panelToggleHandler); });

    addElement("div", { style: "flex-basis: 100%; height: 0;"}, contentDiv);

    if(fieldsMap) {
        let contentTable = addElement("table", { style: "flex-basis: 100%; width: min-content;"}, contentDiv);
        for(const rowData of fieldsMap) {
            if(rowData.length == 0) { // Спомощью передачи пустой стороки-массива, указываем, что надо начать новую таблицу после брейка
                addElement("div", { style: "flex-basis: 100%; height: 0;"}, contentDiv);
                contentTable = addElement("table", undefined, contentDiv);
                continue;
            }
            const row = addElement("tr", undefined, contentTable);
            for(const cellData of rowData) {
                const cell = addElement("td", undefined, row);
                if(cellData) {
                    if(typeof(cellData) == "string") {
                        cell.innerText = cellData;
                    } else {
                        cell.appendChild(cellData);
                    }
                }
            }
        }
    }
    if(panelToggleHandler) {
        panelToggleHandler(true);
    }
    return contentDiv;
}
function showPupupPanel(panelName, panelToggleHandler) {
    const backgroundPopupPanel = document.getElementById(panelName);
    if(backgroundPopupPanel) {
        backgroundPopupPanel.style.display = '';
        if(panelToggleHandler) {
            panelToggleHandler(true);
        }
        return true;
    }
    return false;
}
function hidePupupPanel(panelName, panelToggleHandler) {
    const backgroundPopupPanel = document.getElementById(panelName);
    backgroundPopupPanel.style.display = 'none';
    if(panelToggleHandler) {
        panelToggleHandler(false);
    }
}
// Script autor and url
function getScriptLastAuthor() {
    let authors = GM_info.script.author;
    if(!authors) {
        const authorsMatch = GM_info.scriptMetaStr.match(/@author(.+)\n/);
        authors = authorsMatch ? authorsMatch[1] : "";
    }
    const authorsArr = authors.split(",").map(x => x.trim()).filter(x => x);
    return authorsArr[authorsArr.length - 1];
}
function getDownloadUrl() {
    let result = GM_info.script.downloadURL;
    if(!result) {
        const downloadURLMatch = GM_info.scriptMetaStr.match(/@downloadURL(.+)\n/);
        result = downloadURLMatch ? downloadURLMatch[1] : "";
        result = result.trim();
    }
    return result;
}
function getScriptReferenceHtml() { return `<a href="${getDownloadUrl()}" title="${isEn ? "Check for update" : "Проверить обновление скрипта"}" target=_blanc>${GM_info.script.name} ${GM_info.script.version}</a>`; }
function getSendErrorMailReferenceHtml() { return `<a href="sms-create.php?mailto=${getScriptLastAuthor()}&subject=${isEn ? "Error in" : "Ошибка в"} ${GM_info.script.name} ${GM_info.script.version} (${GM_info.scriptHandler} ${GM_info.version})" target=_blanc>${isEn ? "Bug report" : "Сообщить об ошибке"}</a>`; }
// Server time
function getServerTime() { return Date.now() - parseInt(getValue("ClientServerTimeDifference", 0)); }
function getGameDate() { return new Date(getServerTime() + 10800000); } // Игра в интерфейсе всегда показывает московское время // Это та дата, которая в toUTCString покажет время по москве
function toServerTime(clientTime) { return clientTime -  parseInt(GM_getValue("ClientServerTimeDifference", 0)); }
function toClientTime(serverTime) { return serverTime +  parseInt(GM_getValue("ClientServerTimeDifference", 0)); }
function truncToFiveMinutes(time) { return Math.floor(time / 300000) * 300000; }
function today() { const now = new Date(getServerTime()); now.setHours(0, 0, 0, 0); return now; }
function tomorrow() { const today1 = today(); today1.setDate(today1.getDate() + 1); return today1; }
async function requestServerTime() {
    if(parseInt(getValue("LastClientServerTimeDifferenceRequestDate", 0)) + 6 * 60 * 60 * 1000 < Date.now()) {
        setValue("LastClientServerTimeDifferenceRequestDate", Date.now());
        const responseText = await getRequestText("/time.php");
        const responseParcing = /now (\d+)/.exec(responseText); //responseText: now 1681711364 17-04-23 09:02
        if(responseParcing) {
            setValue("ClientServerTimeDifference", Date.now() - parseInt(responseParcing[1]) * 1000);
        }
    } else {
        setTimeout(requestServerTime, 60 * 60 * 1000);
    }
}
// dateString - игровое время, взятое со страниц игры. Оно всегда московское // Как результат возвращаем серверную дату
function parseDate(dateString, isFuture = false, isPast = false) {
    //console.log(dateString)
    if(!dateString) {
        return;
    }
    const dateStrings = dateString.split(" ");

    let hours = 0;
    let minutes = 0;
    let seconds = 0;
    const gameDate = getGameDate();
    let year = gameDate.getUTCFullYear();
    let month = gameDate.getUTCMonth();
    let day = gameDate.getUTCDate();
    const timePart = dateStrings.find(x => x.includes(":"));
    if(timePart) {
        var time = timePart.split(":");
        hours = parseInt(time[0]);
        minutes = parseInt(time[1]);
        if(time.length > 2) {
            seconds = parseInt(time[2]);
        }
        if(dateStrings.length == 1) {
            let result = new Date(Date.UTC(year, month, day, hours, minutes, seconds));
            if(isPast && result > gameDate) {
                result.setUTCDate(result.getUTCDate() - 1);
            }
            if(isFuture && result < gameDate) {
                result.setUTCDate(result.getUTCDate() + 1);
            }
            //console.log(`result: ${result}, gameDate: ${gameDate}`)
            result.setUTCHours(result.getUTCHours() - 3);
            return result;
        }
    }

    const datePart = dateStrings.find(x => x.includes("-"));
    if(datePart) {
        const date = datePart.split("-");
        month = parseInt(date[isEn ? (date.length == 3 ? 1 : 0) : 1]) - 1;
        day = parseInt(date[isEn ? (date.length == 3 ? 2 : 1) : 0]);
        if(date.length == 3) {
            const yearText = isEn ? date[0] : date[2];
            year = parseInt(yearText);
            if(yearText.length < 4) {
                year += Math.floor(gameDate.getUTCFullYear() / 1000) * 1000;
            }
        } else {
            if(isFuture && month == 0 && gameDate.getUTCMonth() == 11) {
                year += 1;
            }
        }
    }
    if(dateStrings.length > 2) {
        const letterDateExec = /(\d{2}):(\d{2}) (\d{2}) (.{3,4})/.exec(dateString);
        if(letterDateExec) {
            //console.log(letterDateExec)
            day = parseInt(letterDateExec[3]);
            //const monthNames = ['января', 'февраля', 'марта', 'апреля', 'мая', 'июня', 'июля', 'августа', 'сентября', 'октября', 'ноября', 'декабря'];
            const monthShortNames = ['янв', 'фев', 'март', 'апр', 'май', 'июнь', 'июль', 'авг', 'сент', 'окт', 'ноя', 'дек'];
            month = monthShortNames.findIndex(x => x.toLowerCase() == letterDateExec[4].toLowerCase());
            if(isPast && Date.UTC(year, month, day, hours, minutes, seconds) > gameDate.getTime()) {
                year -= 1;
            }
        }
    }
    //console.log(`year: ${year}, month: ${month}, day: ${day}, time[0]: ${time[0]}, time[1]: ${time[1]}, ${new Date(year, month, day, parseInt(time[0]), parseInt(time[1]))}`);
    let result = new Date(Date.UTC(year, month, day, hours, minutes, seconds));
    result.setUTCHours(result.getUTCHours() - 3);
    return result;
}
// Misc
async function initUserName() {
    if(location.pathname == "/pl_info.php" && getUrlParamValue(location.href, "id") == PlayerId) {
        //console.log(document.querySelector("h1").innerText)
        setPlayerValue("UserName", document.querySelector("h1").innerText);
    }
    if(location.pathname == "/home.php") {
        //console.log(document.querySelector(`a[href='pl_info.php?id=${PlayerId}'] > b`).innerText)
        const userNameRef = document.querySelector(`a[href='pl_info.php?id=${PlayerId}'] > b`);
        if(userNameRef) {
            setPlayerValue("UserName", userNameRef.innerText);
        }
    }
    if(!getPlayerValue("UserName")) {
        const doc = await getRequest(`/pl_info.php?id=${PlayerId}`);
        setPlayerValue("UserName", doc.querySelector("h1").innerText);
    }
}
function getUrlParamValue(url, paramName) { return (new URLSearchParams(url.split("?")[1])).get(paramName); }
function showBigData(data) { console.log(data); /*addElement("TEXTAREA", { innerText: data }, document.body);*/ }
function round0(value) { return Math.round(value * 10) / 10; }
function round00(value) { return Math.round(value * 100) / 100; }
function mobileCheck() {
    let check = false;
    (function(a){if(/(android|bb\d+|meego).+mobile|avantgo|bada\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|mobile.+firefox|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\.(browser|link)|vodafone|wap|windows ce|xda|xiino/i.test(a)||/1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\-(n|u)|c55\/|capi|ccwa|cdm\-|cell|chtm|cldc|cmd\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\-s|devi|dica|dmob|do(c|p)o|ds(12|\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\-|_)|g1 u|g560|gene|gf\-5|g\-mo|go(\.w|od)|gr(ad|un)|haie|hcit|hd\-(m|p|t)|hei\-|hi(pt|ta)|hp( i|ip)|hs\-c|ht(c(\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\-(20|go|ma)|i230|iac( |\-|\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\/)|klon|kpt |kwc\-|kyo(c|k)|le(no|xi)|lg( g|\/(k|l|u)|50|54|\-[a-w])|libw|lynx|m1\-w|m3ga|m50\/|ma(te|ui|xo)|mc(01|21|ca)|m\-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\-2|po(ck|rt|se)|prox|psio|pt\-g|qa\-a|qc(07|12|21|32|60|\-[2-7]|i\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\-|oo|p\-)|sdk\/|se(c(\-|0|1)|47|mc|nd|ri)|sgh\-|shar|sie(\-|m)|sk\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\-|v\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\-|tdg\-|tel(i|m)|tim\-|t\-mo|to(pl|sh)|ts(70|m\-|m3|m5)|tx\-9|up(\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas\-|your|zeto|zte\-/i.test(a.substr(0,4))) check = true;})(navigator.userAgent||navigator.vendor||window.opera);
    return check;
};
// MutationObserver
function observe(targets, handler, config = { childList: true, subtree: true }) {
    targets = Array.isArray(targets) ? targets : [targets];
    targets = targets.map(x => { if(typeof x === 'function') { return x(document); } return x; }); // Можем передавать не элементы, а их селекторы
    const ob = new MutationObserver(async function(mut, observer) {
        //console.log(`Mutation start`);
        observer.disconnect();
        if(handler.constructor.name === 'AsyncFunction') {
            await handler();
        } else {
            handler();
        }
        if(!config.once) {
            for(const target of targets) {
                if(target) {
                    observer.observe(target, config);
                }
            }
        }
    });
    for(const target of targets) {
        if(target) {
            ob.observe(target, config);
        }
    }
}
// UpdatePanels
// Если используется url, то это должна быть та же локация с другими параметрами
async function refreshUpdatePanels(panelSelectors, postProcessor, url = location.href) {
    panelSelectors = Array.isArray(panelSelectors) ? panelSelectors : [panelSelectors];
    let freshDocument;
    for(const panelSelector of panelSelectors) {
        const updatePanel = panelSelector(document);
        //console.log(panelSelector.toString())
        //console.log(updatePanel)
        if(updatePanel) {
            freshDocument = freshDocument || await getRequest(url);
            const freshUpdatePanel = panelSelector(freshDocument);
            if(!freshUpdatePanel) {
                console.log(updatePanel)
                continue;
            }
            if(postProcessor) {
                postProcessor(freshUpdatePanel);
            }
            updatePanel.innerHTML = freshUpdatePanel.innerHTML;
            Array.from(updatePanel.querySelectorAll("script")).forEach(x => {
                x.insertAdjacentElement("afterend", addElement("script", { innerHTML: x.innerHTML })); // Передобавляем скрипты, как элементы, что они сработали
                x.remove();
            });
        }
    }
    if(typeof win.hwm_hints_init === 'function') win.hwm_hints_init();
    return freshDocument;
}
function getPlayerLevel() {
    if(location.pathname == "/home.php") {
        if(isNewPersonPage) {
            const levelInfoCell = Array.from(document.querySelectorAll("div.home_pers_info")).find(x => x.innerHTML.includes(isEn ? "Combat level" : "Боевой уровень"));
            if(levelInfoCell) {
                setPlayerValue("PlayerLevel", parseInt(levelInfoCell.querySelector("div[id=bartext] > span").innerText));
            }
        } else {
            const playerLevelExec = new RegExp(`<b>${isEn ? "Combat level" : "Боевой уровень"}: (\\d+?)<\\/b>`).exec(document.documentElement.innerHTML);
            if(playerLevelExec) {
                setPlayerValue("PlayerLevel", parseInt(playerLevelExec[1]));
            }
        }
    }
}
function declOfNum(number, titles) {
    const cases = [2, 0, 1, 1, 1, 2];
    return titles[(number % 100 > 4 && number % 100 < 20) ? 2 : cases[(number % 10 < 5) ? number % 10 : 5]];
}

QingJ © 2025

镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址