From 992bf5017b843a4317217ab5ecea6bc3ff546ad0 Mon Sep 17 00:00:00 2001 From: darkicewolf50 Date: Sat, 9 Dec 2023 12:46:26 -0700 Subject: [PATCH] just a few more todo items --- src/OurSponsors/OurSponsors.css | 1 + src/OurSponsors/OurSponsors.js | 248 ++++++++++++++++++-------------- src/TestingTools/fakeDelay.js | 18 +++ 3 files changed, 156 insertions(+), 111 deletions(-) create mode 100644 src/TestingTools/fakeDelay.js diff --git a/src/OurSponsors/OurSponsors.css b/src/OurSponsors/OurSponsors.css index 7be9362..1eac26e 100644 --- a/src/OurSponsors/OurSponsors.css +++ b/src/OurSponsors/OurSponsors.css @@ -42,6 +42,7 @@ #OurSponsors h2 { background-color: aquamarine; text-align: center; + margin: 0px; } #OurSponsors h3 { diff --git a/src/OurSponsors/OurSponsors.js b/src/OurSponsors/OurSponsors.js index 30f4c3e..fde6b8b 100644 --- a/src/OurSponsors/OurSponsors.js +++ b/src/OurSponsors/OurSponsors.js @@ -1,6 +1,16 @@ +import { useEffect } from 'react'; +import { useState } from 'react'; 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 REQUIRES: Nothing @@ -9,120 +19,136 @@ const OurSponsors = () => { Develop in part by: Brock Contact: darkicewolf50@gmail.com */ - const getSponsors = () => { - /* - Gets the list of sponsors from the synology drive (not implemented), converts the json file into a dictionary - REQUIRES: - constant html link to synology drive - PROMISES: - returns Dictionary list of all our sponsors - Develop in part by: Brock - Contact: darkicewolf50@gmail.com - */ - const tempListOfSponsors = { - "Main Tier": { - 1:{ - "Name":"Hello", - "LogoUrl":"", - "Url":"", - "DescriptionAboutSponsor":"this has text i dont care", - "DecriptionOnHelp":"this has text i dont care" - } - }, - "Platnum Tier": { - 1:{ - "Name":"Schulich School of Engineering", - "LogoUrl":"https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcQj9L3ZGK6WtOmJbzxmCzRxwLXYKGC5SDcAKHb0ScfbUmbtG0IujQt6eQDaI_Pm9g4DZvc&usqp=CAU", - "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" - }, - 2:{ - "Name":"", - "LogoUrl":"", - "Url":"", - "DescriptionAboutSponsor":"this has text i dont care", - "DecriptionOnHelp":"this has text i dont care" - } - }, - "Gold Tier":{ - 1:{ - "Name":"", - "LogoUrl":"", - "Url":"", - "DescriptionAboutSponsor":"this has text i dont care", - "DecriptionOnHelp":"this has text i dont care" - }, - 2:{ - "Name":"", - "LogoUrl":"", - "Url":"", - "DescriptionAboutSponsor":"1this has text i dont care", - "DecriptionOnHelp":"2this has text i dont care" - } - }, - "Silver Tier": { - 1:{ - "Name":"Father", - "LogoUrl":"", - "Url":"" - //"DescriptionAboutSponsor":"", //Dont get this - //"DecriptionOnHelp":"" //Dont get this - }, - 2:{ - "Name":"Help", - "LogoUrl":"", - "Url":"" - //"DescriptionAboutSponsor":"", //Dont get this - //"DecriptionOnHelp":"" //Dont get this - } - }, - "Bronze Tier":{ - 1:{ - "Name":"I'm", - //"LogoUrl":"", //Dont get this - "Url":"" - //"DescriptionAboutSponsor":"", //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 + const [sponsorsDict, setSponsorsDict] = useState(); //variable states for the dictionary of sponsors + + useEffect(() => { + getSponsors(); //get sponsors on startup of page + }, []); + + const getSponsors = async () => { + /* + Gets the list of sponsors from the synology drive (not implemented), converts the json file into a dictionary + REQUIRES: + constant html link to synology drive + PROMISES: + returns Dictionary list of all our sponsors in this format of json file + Develop in part by: Brock + Contact: darkicewolf50@gmail.com + */ + const tempListOfSponsors = { + "Main Tier": { + 1:{ + "Name":"Hello", + "LogoUrl":"", + "Url":"", + "DescriptionAboutSponsor":"this has text i dont care", + "DecriptionOnHelp":"this has text i dont care" + } + }, + "Platnum Tier": { + 1:{ + "Name":"Schulich School of Engineering", + "LogoUrl":"https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcQj9L3ZGK6WtOmJbzxmCzRxwLXYKGC5SDcAKHb0ScfbUmbtG0IujQt6eQDaI_Pm9g4DZvc&usqp=CAU", + "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" + }, + 2:{ + "Name":"", + "LogoUrl":"", + "Url":"", + "DescriptionAboutSponsor":"this has text i dont care", + "DecriptionOnHelp":"this has text i dont care" + } + }, + "Gold Tier":{ + 1:{ + "Name":"", + "LogoUrl":"", + "Url":"", + "DescriptionAboutSponsor":"this has text i dont care", + "DecriptionOnHelp":"this has text i dont care" + }, + 2:{ + "Name":"", + "LogoUrl":"", + "Url":"", + "DescriptionAboutSponsor":"1this has text i dont care", + "DecriptionOnHelp":"2this has text i dont care" + } + }, + "Silver Tier": { + 1:{ + "Name":"Father", + "LogoUrl":"", + "Url":"" + //"DescriptionAboutSponsor":"", //Dont get this + //"DecriptionOnHelp":"" //Dont get this + }, + 2:{ + "Name":"Help", + "LogoUrl":"", + "Url":"" + //"DescriptionAboutSponsor":"", //Dont get this + //"DecriptionOnHelp":"" //Dont get this + } + }, + "Bronze Tier":{ + 1:{ + "Name":"I'm", + //"LogoUrl":"", //Dont get this + "Url":"" + //"DescriptionAboutSponsor":"", //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 (
- {Object.keys(dictOfSponsors).map((sponsorTier) => ( -
-

{sponsorTier}

- {Object.keys(dictOfSponsors[sponsorTier]).map((sponsorKey) => { - const sponsor = dictOfSponsors[sponsorTier][sponsorKey]; - return ( -
-
-
- {sponsor.Name &&

{sponsor.Name}

} - {sponsor.LogoUrl && Sponsor Logo} + + if (!sponsorsDict) { //awaiting for a resposne from the backend + return

Loading...

+ } + if(sponsorsDict) { //maps out the dictionary and displays the content + return (
+ {Object.keys(sponsorsDict).map((sponsorTier) => ( +
+

{sponsorTier}

+ {Object.keys(sponsorsDict[sponsorTier]).map((sponsorKey) => { + const sponsor = sponsorsDict[sponsorTier][sponsorKey]; + return ( +
+
+
+ {sponsor.Name &&

{sponsor.Name}

} + {sponsor.LogoUrl && Sponsor Logo} +
+ {(sponsor.DescriptionAboutSponsor !== undefined && sponsor.DecriptionOnHelp !== undefined) &&

Another Element

} +
+ {sponsor.DescriptionAboutSponsor !== undefined &&

{sponsor.DescriptionAboutSponsor}

} + {sponsor.DecriptionOnHelp !== undefined &&

{sponsor.DecriptionOnHelp}

} +
+ ); + })}
- {(sponsor.DescriptionAboutSponsor !== undefined && sponsor.DecriptionOnHelp !== undefined) &&

Another Element

} -
- {sponsor.DescriptionAboutSponsor !== undefined &&

{sponsor.DescriptionAboutSponsor}

} - {sponsor.DecriptionOnHelp !== undefined &&

{sponsor.DecriptionOnHelp}

} -
- ); - })} -
- ))} -
); + ))} +
); + } }; diff --git a/src/TestingTools/fakeDelay.js b/src/TestingTools/fakeDelay.js new file mode 100644 index 0000000..58c3c46 --- /dev/null +++ b/src/TestingTools/fakeDelay.js @@ -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; \ No newline at end of file