EZ Upkeep

Use the Torn API to manage upkeep and display amount

您需要先安装一个扩展,例如 篡改猴Greasemonkey暴力猴,之后才能安装此脚本。

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

您需要先安装一个扩展,例如 篡改猴暴力猴,之后才能安装此脚本。

您需要先安装一个扩展,例如 篡改猴Userscripts ,之后才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。

您需要先安装用户脚本管理器扩展后才能安装此脚本。

(我已经安装了用户脚本管理器,让我安装!)

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

(我已经安装了用户样式管理器,让我安装!)

// ==UserScript==
// @name         EZ Upkeep
// @namespace    http://tampermonkey.net/
// @version      2024-09-24
// @description  Use the Torn API to manage upkeep and display amount
// @author       JeffBezas | xDp64x
// @match        https://www.torn.com/*
// @icon         
// @grant        none
// @license MIT
// ==/UserScript==
function addButton() {
    console.log("Initializing buttons...");

    // Create buttons and result span
    const upkeepButton = $('<button id="Upkeep" style="color: var(--default-blue-color); cursor: pointer; margin-right: 10px;">Loading Upkeep...</button>');
    const resetButton = $('<button id="ResetKey" style="color: var(--default-red-color); cursor: pointer;">Reset API Key</button>');
    const resultSpan = $('<span id="Result" style="font-size: 12px; font-weight: 100;"></span>');

    $('div.content-title > h4').append(upkeepButton);
    $('div.content-title > h4').append(resetButton);
    $('div.content-title > h4').append(resultSpan);

    // Check for existing API token
    let apiToken = localStorage.getItem('tornApiToken');

    if (!apiToken) {
        apiToken = prompt("Please enter your Torn API token key:");
        if (apiToken) {
            localStorage.setItem('tornApiToken', apiToken);
        }
    }

    if (apiToken) {
        fetchPropertyId(apiToken).then(propertyId => {
            if (propertyId) {
                console.log("Property ID retrieved: ", propertyId);
                const totalNum = fetchCurrentUpkeep(propertyId, apiToken);
                console.log(totalNum);
                fetchUpkeepData(propertyId, apiToken).then(totalCost => {
                    console.log("Total cost fetched: ", totalCost);

                    // Check if totalCost is valid before updating the button
                    if (totalCost !== null && totalCost !== undefined) {
                        $('#Upkeep').text(`Pay Upkeep: $${totalCost}`);
                        const upkeepUrl = `https://www.torn.com/properties.php#/p=options&ID=${propertyId}&tab=upkeep`;

                        $('#Upkeep').off('click').on('click', () => {
                            console.log("Redirecting to upkeep URL...");
                            window.location.href = upkeepUrl; // Redirect to the upkeep URL
                        });
                    } else {
                        $('#Result').text('Failed to retrieve upkeep amount.').css('color', 'red');
                        console.error('Total cost is invalid.');
                    }
                }).catch(error => {
                    $('#Result').text('Error fetching upkeep data.').css('color', 'red');
                    console.error('Error in fetchUpkeepData:', error);
                });
            } else {
                $('#Result').text('Failed to retrieve property ID.').css('color', 'red');
                console.error('Failed to retrieve property ID.');
            }
        });
    } else {
        $('#Result').text('No API token provided.').css('color', 'red');
        console.error('No API token provided.');
    }

    // Reset API key button click event
    $('#ResetKey').on('click', () => {
        const newApiToken = prompt("Please enter your new Torn API token key:");
        if (newApiToken) {
            localStorage.setItem('tornApiToken', newApiToken);
            $('#Result').text('API token updated.').css('color', 'green');
        } else {
            $('#Result').text('No API token provided.').css('color', 'red');
        }
    });
}

async function fetchPropertyId(apiToken) {
    console.log("Fetching property ID with token: ", apiToken);
    try {
        const apiURL = `https://api.torn.com/user/?key=${apiToken}&comment=TornAPI&selections=properties`;
        const response = await fetch(apiURL);
        const data = await response.json();
        console.log("Fetched property data: ", data);

        const propertyIds = Object.keys(data.properties);
        return propertyIds.length > 0 ? propertyIds[0] : null; // Return the first property ID or null if none exist
    } catch (error) {
        console.error('Error fetching property ID:', error);
        return null; // Return null if there is an error
    }
}

async function fetchCurrentUpkeep(propertyId, apiToken) {
    const upkeepUrl = `https://www.torn.com/properties.php#/p=options&ID=${propertyId}&tab=upkeep`;

    try {
        const response = await fetch(upkeepUrl);
        const text = await response.text();

        // Create a DOM parser to extract the upkeep amount from the HTML
        const parser = new DOMParser();
        const doc = parser.parseFromString(text, 'text/html');

        // Log the parsed document to see its structure
        console.log(doc.documentElement.innerHTML);

        console.log("Doc2: ", doc.documentElement);

        // Step 1: Select the desired <ul> element with the specific data-id
        const upkeepList = doc.querySelector(`ul.options-list.left.upkeep[data-id="${propertyId}"]`);
        console.log("UpkeepList: ", upkeepList);
        //content-wrapper autumn travelling
        console.log("Testing: ", doc.querySelector(`content-wrapper autumn traveling`));

        if (upkeepList) {
            // Step 2: Find the <li> with the specific class and get the <span class="desc">
            const upkeepItem = upkeepList.querySelector('li.t-last.warning.upkeep-prop-act span.desc');

            if (upkeepItem) {
                // Step 3: Extract the text content from the span
                const textContent = upkeepItem.textContent;

                // Step 4: Use a regular expression to extract the numeric part
                const numberMatch = textContent.match(/\$[\d,]+/); // Matches "$885,761"

                if (numberMatch) {
                    // Step 5: Extract the matched number
                    const numericValue = numberMatch[0]; // This will be "$885,761"

                    // Optional: If you want to convert it to a number, remove the '$' and ',' characters
                    const amount = parseFloat(numericValue.replace(/[$,]/g, ''));

                    console.log(`Extracted Upkeep Amount: ${numericValue}`); // Logs: $885,761
                    console.log(`Numeric Value: ${amount}`); // Logs: 885761
                    return numericValue; // Return the numeric value if needed
                } else {
                    console.warn('No numeric value found in the text.');
                    return null; // Return null if no numeric value is found
                }
            } else {
                console.warn('No upkeep item found.');
                return null; // Return null if the upkeep item is not found
            }
        } else {
            console.warn(`No upkeep list found for property ID: ${propertyId}`);
            return null; // Return null if the upkeep list is not found
        }
} catch (error) {
    console.error('Error fetching upkeep data:', error);

}
}
//This is only getting total cost via staff and regular upkeep, not currently owed, but seems off with upgrades perhaps
async function fetchUpkeepData(propertyId, apiToken) {
    console.log("Fetching upkeep data for property ID: ", propertyId);
    try {
        //Access Property for user via API token, sort the data from upkeep and staff cost
        const apiURL = `https://api.torn.com/user/?key=${apiToken}&comment=TornAPI&selections=properties`;
        const response = await fetch(apiURL);
        const data = await response.json();
        console.log("Fetched upkeep data: ", data);

        const properties = data.properties;

        if (properties && properties[propertyId]) {
            const upkeepAmount = properties[propertyId].upkeep || 0; // Get the upkeep amount or default to 0
            const staffAmount = properties[propertyId].staff_cost || 0; // Get the staff cost or default to 0
            const totalCost = upkeepAmount + staffAmount; // Calculate total cost

            console.log(`Upkeep for property ID ${propertyId}: $${upkeepAmount}`);
            console.log(`Staff cost for property ID ${propertyId}: $${staffAmount}`);
            console.log(`Total cost for property ID ${propertyId}: $${totalCost}`);

            return totalCost; // Return the total cost
        } else {
            console.warn(`Property ID ${propertyId} not found.`);
            return 0; // Return 0 if the property ID does not exist
        }
    } catch (error) {
        console.error('Error fetching upkeep data:', error);
        return null; // Return null if there is an error
    }
}

(function() {
    'use strict';
    addButton();
})();