just a few more todo items

This commit is contained in:
darkicewolf50 2023-12-09 12:46:26 -07:00
parent d8ca3be56a
commit 992bf5017b
3 changed files with 156 additions and 111 deletions

View File

@ -42,6 +42,7 @@
#OurSponsors h2 { #OurSponsors h2 {
background-color: aquamarine; background-color: aquamarine;
text-align: center; text-align: center;
margin: 0px;
} }
#OurSponsors h3 { #OurSponsors h3 {

View File

@ -1,6 +1,16 @@
import { useEffect } from 'react';
import { useState } from 'react';
import './OurSponsors.css' import './OurSponsors.css'
const OurSponsors = () => { //can be removed later
import fakeDelay from '../TestingTools/fakeDelay';
/* /*
things to do
*add link to become a sponsor at top, and thank you message
*/
const OurSponsors = () => {
/*
OurSponsors Page OurSponsors Page
REQUIRES: REQUIRES:
Nothing Nothing
@ -9,120 +19,136 @@ const OurSponsors = () => {
Develop in part by: Brock Develop in part by: Brock
Contact: darkicewolf50@gmail.com Contact: darkicewolf50@gmail.com
*/ */
const getSponsors = () => { const [sponsorsDict, setSponsorsDict] = useState(); //variable states for the dictionary of sponsors
/*
Gets the list of sponsors from the synology drive (not implemented), converts the json file into a dictionary useEffect(() => {
REQUIRES: getSponsors(); //get sponsors on startup of page
constant html link to synology drive }, []);
PROMISES:
returns Dictionary list of all our sponsors const getSponsors = async () => {
Develop in part by: Brock /*
Contact: darkicewolf50@gmail.com Gets the list of sponsors from the synology drive (not implemented), converts the json file into a dictionary
*/ REQUIRES:
const tempListOfSponsors = { constant html link to synology drive
"Main Tier": { PROMISES:
1:{ returns Dictionary list of all our sponsors in this format of json file
"Name":"Hello", Develop in part by: Brock
"LogoUrl":"", Contact: darkicewolf50@gmail.com
"Url":"", */
"DescriptionAboutSponsor":"this has text i dont care", const tempListOfSponsors = {
"DecriptionOnHelp":"this has text i dont care" "Main Tier": {
} 1:{
}, "Name":"Hello",
"Platnum Tier": { "LogoUrl":"",
1:{ "Url":"",
"Name":"Schulich School of Engineering", "DescriptionAboutSponsor":"this has text i dont care",
"LogoUrl":"https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcQj9L3ZGK6WtOmJbzxmCzRxwLXYKGC5SDcAKHb0ScfbUmbtG0IujQt6eQDaI_Pm9g4DZvc&usqp=CAU", "DecriptionOnHelp":"this has text i dont care"
"Url":"https://schulich.ucalgary.ca/", }
"DescriptionAboutSponsor":"Lorem ipsum dolor sit amet, consectetur adipiscing elit. Fusce eu magna in diam consectetur rhoncus vel nec turpis. Sed finibus mi eu sem varius faucibus. Donec semper erat et bibendum pharetra. Suspendisse cursus lorem sed nisi semper, a rutrum nunc luctus. Nunc ullamcorper enim id orci interdum ultrices. Donec vestibulum nunc vel nisl pretium tempus. Morbi quis ante et ligula eleifend eleifend. Proin bibendum maximus elit vitae congue. Vivamus egestas, ex in tempor posuere, ligula nunc iaculis massa, in imperdiet dui justo eu dolor. Nullam placerat velit quis sem mattis, laoreet pharetra elit tempor. ", },
"DecriptionOnHelp":"this has text i dont care" "Platnum Tier": {
}, 1:{
2:{ "Name":"Schulich School of Engineering",
"Name":"", "LogoUrl":"https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcQj9L3ZGK6WtOmJbzxmCzRxwLXYKGC5SDcAKHb0ScfbUmbtG0IujQt6eQDaI_Pm9g4DZvc&usqp=CAU",
"LogoUrl":"", "Url":"https://schulich.ucalgary.ca/",
"Url":"", "DescriptionAboutSponsor":"Lorem ipsum dolor sit amet, consectetur adipiscing elit. Fusce eu magna in diam consectetur rhoncus vel nec turpis. Sed finibus mi eu sem varius faucibus. Donec semper erat et bibendum pharetra. Suspendisse cursus lorem sed nisi semper, a rutrum nunc luctus. Nunc ullamcorper enim id orci interdum ultrices. Donec vestibulum nunc vel nisl pretium tempus. Morbi quis ante et ligula eleifend eleifend. Proin bibendum maximus elit vitae congue. Vivamus egestas, ex in tempor posuere, ligula nunc iaculis massa, in imperdiet dui justo eu dolor. Nullam placerat velit quis sem mattis, laoreet pharetra elit tempor. ",
"DescriptionAboutSponsor":"this has text i dont care", "DecriptionOnHelp":"this has text i dont care"
"DecriptionOnHelp":"this has text i dont care" },
} 2:{
}, "Name":"",
"Gold Tier":{ "LogoUrl":"",
1:{ "Url":"",
"Name":"", "DescriptionAboutSponsor":"this has text i dont care",
"LogoUrl":"", "DecriptionOnHelp":"this has text i dont care"
"Url":"", }
"DescriptionAboutSponsor":"this has text i dont care", },
"DecriptionOnHelp":"this has text i dont care" "Gold Tier":{
}, 1:{
2:{ "Name":"",
"Name":"", "LogoUrl":"",
"LogoUrl":"", "Url":"",
"Url":"", "DescriptionAboutSponsor":"this has text i dont care",
"DescriptionAboutSponsor":"1this has text i dont care", "DecriptionOnHelp":"this has text i dont care"
"DecriptionOnHelp":"2this has text i dont care" },
} 2:{
}, "Name":"",
"Silver Tier": { "LogoUrl":"",
1:{ "Url":"",
"Name":"Father", "DescriptionAboutSponsor":"1this has text i dont care",
"LogoUrl":"", "DecriptionOnHelp":"2this has text i dont care"
"Url":"" }
//"DescriptionAboutSponsor":"", //Dont get this },
//"DecriptionOnHelp":"" //Dont get this "Silver Tier": {
}, 1:{
2:{ "Name":"Father",
"Name":"Help", "LogoUrl":"",
"LogoUrl":"", "Url":""
"Url":"" //"DescriptionAboutSponsor":"", //Dont get this
//"DescriptionAboutSponsor":"", //Dont get this //"DecriptionOnHelp":"" //Dont get this
//"DecriptionOnHelp":"" //Dont get this },
} 2:{
}, "Name":"Help",
"Bronze Tier":{ "LogoUrl":"",
1:{ "Url":""
"Name":"I'm", //"DescriptionAboutSponsor":"", //Dont get this
//"LogoUrl":"", //Dont get this //"DecriptionOnHelp":"" //Dont get this
"Url":"" }
//"DescriptionAboutSponsor":"", //Dont get this },
//"DecriptionOnHelp":"" //Dont get this "Bronze Tier":{
}, 1:{
2:{ "Name":"I'm",
"Name":"Stuck to a cactus", //"LogoUrl":"", //Dont get this
//"LogoUrl":"", //Dont get this "Url":""
"Url":"" //"DescriptionAboutSponsor":"", //Dont get this
//"DescriptionAboutSponsor":"", //Dont get this //"DecriptionOnHelp":"" //Dont get this
//"DecriptionOnHelp":"" //Dont get this },
2:{
"Name":"Stuck to a cactus",
//"LogoUrl":"", //Dont get this
"Url":""
//"DescriptionAboutSponsor":"", //Dont get this
//"DecriptionOnHelp":"" //Dont get this
}
}
};
try {
await fakeDelay(1000);
console.log("It ran");
let res = tempListOfSponsors;
setSponsorsDict(res);
} catch (error) { //error checking
console.error('Error sending data to server:', error);
} }
} }
};
console.log("It ran");
return tempListOfSponsors;
}
const dictOfSponsors = getSponsors();
//to fix make each of these a function and return the proper
return (<div id='OurSponsors'> if (!sponsorsDict) { //awaiting for a resposne from the backend
{Object.keys(dictOfSponsors).map((sponsorTier) => ( return <p>Loading...</p>
<div key={sponsorTier} className={sponsorTier}> }
<h2>{sponsorTier}</h2> if(sponsorsDict) { //maps out the dictionary and displays the content
{Object.keys(dictOfSponsors[sponsorTier]).map((sponsorKey) => { return (<div id='OurSponsors'>
const sponsor = dictOfSponsors[sponsorTier][sponsorKey]; {Object.keys(sponsorsDict).map((sponsorTier) => (
return ( <div key={sponsorTier} className={sponsorTier}>
<div key={sponsorKey}> <h2>{sponsorTier}</h2>
<div> {Object.keys(sponsorsDict[sponsorTier]).map((sponsorKey) => {
<div> const sponsor = sponsorsDict[sponsorTier][sponsorKey];
{sponsor.Name && <h3>{sponsor.Name}</h3>} return (
{sponsor.LogoUrl && <a href={sponsor.Url}><img src={sponsor.LogoUrl} alt="Sponsor Logo" /></a>} <div key={sponsorKey}>
<div>
<div>
{sponsor.Name && <h3>{sponsor.Name}</h3>}
{sponsor.LogoUrl && <a href={sponsor.Url}><img src={sponsor.LogoUrl} alt="Sponsor Logo" /></a>}
</div>
{(sponsor.DescriptionAboutSponsor !== undefined && sponsor.DecriptionOnHelp !== undefined) && <p>Another Element</p>}
</div>
{sponsor.DescriptionAboutSponsor !== undefined && <p>{sponsor.DescriptionAboutSponsor}</p>}
{sponsor.DecriptionOnHelp !== undefined && <p>{sponsor.DecriptionOnHelp}</p>}
</div>
);
})}
</div> </div>
{(sponsor.DescriptionAboutSponsor !== undefined && sponsor.DecriptionOnHelp !== undefined) && <p>Another Element</p>} ))}
</div> </div>);
{sponsor.DescriptionAboutSponsor !== undefined && <p>{sponsor.DescriptionAboutSponsor}</p>} }
{sponsor.DecriptionOnHelp !== undefined && <p>{sponsor.DecriptionOnHelp}</p>}
</div>
);
})}
</div>
))}
</div>);
}; };

View File

@ -0,0 +1,18 @@
function fakeDelay(ms) {
/*
useful for testing allows for a fake response, allow us to see what the program does while waiting for data from the backend
REQUIRES:
time in milliseconds
needs a line like this to run
await fakeDelay(5000);
PROMISES:
nothing
Develop in part by: Brock
Contact: darkicewolf50@gmial.com
*/
return new Promise(resolve => setTimeout(resolve, ms));
}
export default fakeDelay;