aboutsummaryrefslogtreecommitdiffstats
path: root/src/components/FFXIVItemPrice.tsx
diff options
context:
space:
mode:
Diffstat (limited to 'src/components/FFXIVItemPrice.tsx')
-rw-r--r--src/components/FFXIVItemPrice.tsx119
1 files changed, 0 insertions, 119 deletions
diff --git a/src/components/FFXIVItemPrice.tsx b/src/components/FFXIVItemPrice.tsx
deleted file mode 100644
index d65b3ca..0000000
--- a/src/components/FFXIVItemPrice.tsx
+++ /dev/null
@@ -1,119 +0,0 @@
-import React, { useState, useEffect } from 'react';
-
-interface FFXIVItemPriceProps {
- itemId: number;
- itemName: string;
- itemImageUrl: string;
-}
-
-const FFXIVItemPrice: React.FC<FFXIVItemPriceProps> = ({ itemId = 5530, itemName="Coke", itemImageUrl="https://xivapi.com/i/021000/021462_hr1.png"}) => {
- const [selectedWorld, setSelectedWorld] = useState<string | null>(null);
- const [dailySaleVelocity, setDailySaleVelocity] = useState<number | null>(null);
- const [averageSalePrice, setAverageSalePrice] = useState<number | null>(null);
- const [inputQuantity, setInputQuantity] = useState<number>(0);
- const [potentialGil, setPotentialGil] = useState<number>(0);
- const [dataSource, setDataSource] = useState<string>('world');
-
- const fetchData = (attempt: number = 1) => {
- fetch(`https://universalis.app/api/v2/aggregated/${selectedWorld}/${itemId}`)
- .then(response => response.json())
- .then(data => {
- let result = data.results[0];
- try {
- setDailySaleVelocity(Math.round(result.nq.dailySaleVelocity.world.quantity));
- setAverageSalePrice(Math.round(result.nq.averageSalePrice.world.price));
- setDataSource('world');
- } catch (error) {
- try {
- setDailySaleVelocity(Math.round(result.nq.dailySaleVelocity.dc.quantity));
- setAverageSalePrice(Math.round(result.nq.averageSalePrice.dc.price));
- setDataSource('dc');
- } catch (error) {
- try {
- setDailySaleVelocity(Math.round(result.nq.dailySaleVelocity.region.quantity));
- setAverageSalePrice(Math.round(result.nq.averageSalePrice.region.price));
- setDataSource('region');
- } catch (error) {
- console.error('Error fetching data:', error);
- if (attempt < 3) {
- setTimeout(() => fetchData(attempt + 1), 5000);
- }
- }
- }
- }
- })
- .catch(error => {
- console.error(`Error fetching data (attempt ${attempt}):`, error);
- if (attempt < 3) {
- setTimeout(() => fetchData(attempt + 1), 5000);
- }
- });
- };
-
- useEffect(() => {
- const savedWorld = localStorage.getItem('selectedWorld');
- if (savedWorld) {
- setSelectedWorld(savedWorld);
- } else {
- setSelectedWorld('Midgardsormr');
- }
-
- fetchData();
- }, [itemId, selectedWorld]);
-
- const handleInputChange = (e: React.ChangeEvent<HTMLInputElement>) => {
- const quantity = parseInt(e.target.value, 10);
- setInputQuantity(quantity);
- setPotentialGil(quantity * (averageSalePrice || 0));
- };
-
- const formatNumber = (number: number | null) => {
- return number !== null ? new Intl.NumberFormat().format(number) : 'N/A';
- };
-
- return (
- <div className="ffxiv-container">
- <div className="ffxiv-header">
- <a href={"https://universalis.app/market/" + itemId} className="no-underline">
- <h1 className="ffxiv-h1">{itemName}</h1>
- </a>
- <img src={itemImageUrl} alt={itemName} className="ffxiv-item-icon" />
- </div>
- <table className="ffxiv-table">
- <tbody>
- <tr>
- <td className="ffxiv-label">Average Price/Item:</td>
- <td className="ffxiv-value">{formatNumber(averageSalePrice)} gil</td>
- </tr>
- <tr>
- <td className="ffxiv-label">Daily Sale Velocity:</td>
- <td className="ffxiv-value">{formatNumber(dailySaleVelocity)} items</td>
- </tr>
- <tr>
- <td className="ffxiv-label">Enter Quantity:</td>
- <td>
- <input
- type="number"
- value={inputQuantity}
- onChange={handleInputChange}
- placeholder="Enter quantity"
- className="ffxiv-input"
- />
- </td>
- </tr>
- <tr>
- <td className="ffxiv-label">Potential Gil Earnings:</td>
- <td className="ffxiv-value">{formatNumber(potentialGil)} gil</td>
- </tr>
- </tbody>
- </table>
- <footer>
- {dataSource === 'dc' ? 'Datacenter Fallback ' : dataSource === 'region' ? 'Regional Fallback ' : ''}
- {selectedWorld} Marketboard Data provided by Universalis API. <a className="eorzeadb_link" href="#" onClick={(e) => { e.preventDefault(); fetchData(); }}>Click here to reload data</a>
- <br />
- </footer>
- </div>
- );
-};
-
-export default FFXIVItemPrice; \ No newline at end of file
send patches to the email below
yukais@pinapelz.com
include the subject [PATCH repo_name]
pinapelz.com
homepage