FMP Player Stats Averager

Calculate total and average for player stats on profile page

2025-05-31 기준 버전입니다. 최신 버전을 확인하세요.

이 스크립트를 설치하려면 Tampermonkey, Greasemonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

You will need to install an extension such as Tampermonkey to install this script.

이 스크립트를 설치하려면 Tampermonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Userscripts와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 유저 스크립트 관리자 확장 프로그램이 필요합니다.

(이미 유저 스크립트 관리자가 설치되어 있습니다. 설치를 진행합니다!)

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

(이미 유저 스타일 관리자가 설치되어 있습니다. 설치를 진행합니다!)

// ==UserScript==
// @name         FMP Player Stats Averager
// @namespace    https://osama.dev
// @version      1.0
// @description  Calculate total and average for player stats on profile page
// @match        https://footballmanagerproject.com/Team/Player?id=*
// @grant        none
// ==/UserScript==

(function () {
    function parseNumber(text) {
        const val = parseFloat(text);
        return isNaN(val) ? 0 : val;
    }

    function format(value, decimals = 2) {
        return Number(value).toFixed(decimals);
    }

    function processStats() {
        const table = document.querySelector('table');
        if (!table) return;

        const rows = Array.from(table.querySelectorAll('tbody tr'));
        const totals = { matches: 0, goals: 0, assists: 0, yellow: 0, red: 0, rating: 0 };
        let ratingCount = 0;

        rows.forEach(row => {
            const cells = row.querySelectorAll('td');
            if (cells.length >= 10) {
                totals.matches += parseNumber(cells[3].innerText);
                totals.goals += parseNumber(cells[4].innerText);
                totals.assists += parseNumber(cells[5].innerText);
                totals.yellow += parseNumber(cells[6].innerText);
                totals.red += parseNumber(cells[7].innerText);
                const rating = parseNumber(cells[8].innerText);
                if (rating > 0) {
                    totals.rating += rating;
                    ratingCount++;
                }
            }
        });

        // أضف صف جديد أسفل الجدول
        const avgRating = ratingCount ? totals.rating / ratingCount : 0;

        const summaryRow = document.createElement('tr');
        summaryRow.style.fontWeight = 'bold';
        summaryRow.style.color = 'yellow';
        summaryRow.innerHTML = `
            <td colspan="3">📊 Totals:</td>
            <td>${totals.matches}</td>
            <td>${totals.goals}</td>
            <td>${totals.assists}</td>
            <td>${totals.yellow}</td>
            <td>${totals.red}</td>
            <td>${format(avgRating)}</td>
            <td></td>
        `;

        table.querySelector('tbody').appendChild(summaryRow);
    }

    window.addEventListener('load', function () {
        setTimeout(processStats, 1000);
    });
})();