frontend/src/routes/list/utilities-sector/+page.ts
2024-09-19 16:04:35 +02:00

70 lines
1.8 KiB
TypeScript

import { getCache, setCache } from "$lib/store";
export const load = async ({ parent }) => {
const getUtilitiesSector = async () => {
let output;
// Get cached data for the specific tickerID
const cachedData = getCache("", "getUtilitiesSector");
if (cachedData) {
output = cachedData;
} else {
const { apiKey, apiURL } = await parent();
const postData = { filterList: "utilities" };
const response = await fetch(apiURL + "/filter-stock-list", {
method: "POST",
headers: {
"Content-Type": "application/json",
"X-API-KEY": apiKey,
},
body: JSON.stringify(postData),
});
output = await response.json();
// Cache the data for this specific tickerID with a specific name 'getUtilitiesSector'
setCache("", output, "getUtilitiesSector");
}
return output;
};
const getHistoricalSector = async () => {
let output;
// Get cached data for the specific tickerID
const cachedData = getCache("utilities", "getHistoricalSector");
if (cachedData) {
output = cachedData;
} else {
const { apiKey, apiURL } = await parent();
const postData = { filterList: "utilities" };
const response = await fetch(apiURL + "/historical-sector-price", {
method: "POST",
headers: {
"Content-Type": "application/json",
"X-API-KEY": apiKey,
},
body: JSON.stringify(postData),
});
output = await response.json();
// Cache the data for this specific tickerID with a specific name 'getHistoricalSector'
setCache("utilities", output, "getHistoricalSector");
}
return output;
};
// Make sure to return a promise
return {
getUtilitiesSector: await getUtilitiesSector(),
getHistoricalSector: await getHistoricalSector(),
};
};