chnged from dictionary to external yml file

This commit is contained in:
darkicewolf50 2024-03-09 18:15:50 -07:00
parent 6bdcdd57ca
commit 01c7a9d3da
5 changed files with 22220 additions and 22152 deletions

43931
package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@ -1,41 +1,45 @@
{ {
"name": "bajauofcwebsite", "name": "bajauofcwebsite",
"version": "0.1.0", "version": "0.1.0",
"private": true, "private": true,
"dependencies": { "dependencies": {
"@svgr/webpack": "^8.1.0", "@svgr/webpack": "^8.1.0",
"@testing-library/jest-dom": "^5.16.5", "@testing-library/jest-dom": "^5.16.5",
"@testing-library/react": "^13.4.0", "@testing-library/react": "^13.4.0",
"@testing-library/user-event": "^13.5.0", "@testing-library/user-event": "^13.5.0",
"react": "^18.2.0", "js-yaml": "^4.1.0",
"react-dom": "^18.2.0", "react": "^18.2.0",
"react-native": "^0.72.6", "react-dom": "^18.2.0",
"react-router-dom": "^6.20.0", "react-native": "^0.72.6",
"react-scripts": "5.0.1", "react-router-dom": "^6.20.0",
"web-vitals": "^2.1.4" "react-scripts": "5.0.1",
}, "web-vitals": "^2.1.4"
"scripts": { },
"start": "react-scripts start", "scripts": {
"build": "react-scripts build", "start": "react-scripts start",
"test": "react-scripts test", "build": "react-scripts build",
"eject": "react-scripts eject" "test": "react-scripts test",
}, "eject": "react-scripts eject"
"eslintConfig": { },
"extends": [ "eslintConfig": {
"react-app", "extends": [
"react-app/jest" "react-app",
] "react-app/jest"
}, ]
"browserslist": { },
"production": [ "browserslist": {
">0.2%", "production": [
"not dead", ">0.2%",
"not op_mini all" "not dead",
], "not op_mini all"
"development": [ ],
"last 1 chrome version", "development": [
"last 1 firefox version", "last 1 chrome version",
"last 1 safari version" "last 1 firefox version",
] "last 1 safari version"
} ]
},
"devDependencies": {
"yaml-loader": "^0.8.1"
}
} }

View File

@ -0,0 +1,50 @@
Diamond Tier:
- 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: Money
Platinum Tier:
- Name: Platinum Sponsor Name
LogoUrl:
Url:
DescriptionAboutSponsor:
DescriptionOnHelp: Money
Gold Tier:
- Name: Suri
LogoUrl: https://lh5.googleusercontent.com/WJsBsmcLypQhY0MMOLQtJSGFXrLQqPKNc3502rYUGKPCq_SfS9CxuoB3n541Kn9bKPm2b5aixCnYsCVYZAts2Y8xvmOHWL3nnbKtWUkE1KoFYYQ4bXUlikfF0NPIynxhzQ=w1280
Url: https://www.surimanufacturing.com/
DescriptionAboutSponsor:
DescriptionOnHelp: I am not sure of the time of writing this
- Name: SKF
LogoUrl: https://www.skf.com/v2/assets/img/skf-logo-white.svg
Url: https://www.skf.com/ca/en
DescriptionAboutSponsor: I am not sure
DescriptionOnHelp: I am not sure of the time of writing this
- Name: WRMA
LogoUrl: https://wildrosemx.com/wp-content/uploads/2021/08/wild-rose-motocross-calgary-rasterized.png
Url: https://wildrosemx.com/
DescriptionAboutSponsor:
DescriptionOnHelp: Lets us use their trak during the warm months
Silver Tier:
- Name: Encore Metals
LogoUrl: https://www.encoremetals.com/assets/images/logos/encore-metals-logo.png
Url: https://www.encoremetals.com/
DescriptionAboutSponsor: Metal supplier
DescriptionOnHelp: Where we buy metals from at a discounted rate
- Name: CNOOC
LogoUrl: https://cnoocinternational.com/img/cnooc-logo.png
Url: https://cnoocinternational.com/
DescriptionAboutSponsor:
DescriptionOnHelp: Money
Bronze Tier:
- Name: Redbull
LogoUrl: "https://img.redbull.com/redbullcom/static/redbullcom-logo_double-with-text.svg"
Url: https://www.redbull.com/ca-en/
DescriptionAboutSponsor:
DescriptionOnHelp: Free Energy Drinks
- Name: Canada Action
LogoUrl:
Url: I dont know
DescriptionAboutSponsor:
DescriptionOnHelp: Money

View File

@ -1,51 +1,50 @@
#OurSponsors { #OurSponsors {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
justify-content: center; justify-content: center;
background-color: gray; background-color: gray;
padding-left: 10%; padding-left: 10%;
padding-right: 10%; padding-right: 10%;
} }
#OurSponsors div div { #OurSponsors div div {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
justify-content: center; justify-content: center;
background-color: white; background-color: white;
} }
#OurSponsors div div div div img { #OurSponsors div div div div div img {
display: flex; display: flex;
justify-content: left; justify-content: left;
} }
#OurSponsors div div p { #OurSponsors div div div p {
display: flex; display: flex;
justify-content: left; justify-content: left;
}
#OurSponsors div div div div div {
padding: 0%;
display: flex;
flex-direction: column;
justify-content: left;
} }
#OurSponsors div div div div { #OurSponsors div div div div {
padding: 0%; display: flex;
display: flex; flex-direction: row;
flex-direction: column; justify-content: end;
justify-content: left; padding: 0%;
} width: 100%;
#OurSponsors div div div {
display: flex;
flex-direction: row;
justify-content: end;
padding: 0%;
width: 100%;
} }
#OurSponsors h2 { #OurSponsors h2 {
background-color: aquamarine; background-color: aquamarine;
text-align: center; text-align: center;
margin: 0px; margin: 0px;
} }
#OurSponsors h3 { #OurSponsors h3 {
text-align: left; text-align: left;
} }

View File

@ -1,9 +1,11 @@
import { useEffect } from 'react'; import { useEffect } from "react";
import { useState } from 'react'; import { useState } from "react";
import './OurSponsors.css' import "./OurSponsors.css";
import sponsorData from "../MockDB/sponsorship.yml";
//can be removed later //can be removed later
import fakeDelay from '../TestingTools/fakeDelay'; import fakeDelay from "../TestingTools/fakeDelay";
import { useNavigate } from 'react-router-dom'; import { useNavigate } from "react-router-dom";
import yaml from "js-yaml";
/** /**
* @param {null} null - requires onthing * @param {null} null - requires onthing
@ -13,145 +15,105 @@ import { useNavigate } from 'react-router-dom';
* @todo add link to become a sponsor at top, and thank you message * @todo add link to become a sponsor at top, and thank you message
*/ */
const OurSponsors = () => { const OurSponsors = () => {
const [sponsorsDict, setSponsorsDict] = useState(); //variable states for the dictionary of sponsors
const [sponsorsDict, setSponsorsDict] = useState(); //variable states for the dictionary of sponsors
useEffect(() => { //get sponsors on startup of page not optimized useEffect(() => {
getSponsors(); //get sponsors on startup of page not optimized
}, []); getSponsors();
}, []);
const OpenPage = (arg) => { const OpenPage = (arg) => {
const navigate = useNavigate(); const navigate = useNavigate();
navigate(arg); navigate(arg);
console.log(arg); console.log(arg);
}; };
/** /**
* @param {null} null - requires nothing (link) * @param {null} null - requires nothing (link)
* @returns {Object} sponsorsDict - gets a Dictionary of our sponsors from synology drive * @returns {Object} sponsorsDict - gets a Dictionary of our sponsors from synology drive
* @description Gets the list of sponsors from the synology drive (not implemented), converts the json file into a dictionary * @description Gets the list of sponsors from the synology drive (not implemented), converts the json file into a dictionary
* @author Brock <darkicewolf50@gmail.com> * @author Brock <darkicewolf50@gmail.com>
* @todo add gPRC to backend and front end * @todo add gPRC to backend and front end
*/ */
const getSponsors = async () => { const getSponsors = async () => {
const tempListOfSponsors = { const res = await fetch(sponsorData);
"Main Tier": { const rawText = await res.text();
1:{ const yamlDict = yaml.load(rawText);
"Name":"Hello", try {
"LogoUrl":"", await fakeDelay(1000);
"Url":"", console.log("It ran");
"DescriptionAboutSponsor":"this has text i dont care", let res = yamlDict;
"DecriptionOnHelp":"this has text i dont care" setSponsorsDict(res);
} } catch (error) {
}, //error checking
"Platnum Tier": { console.error("Error sending data to server:", error);
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);
}
}
if (!sponsorsDict) { //awaiting for a resposne from the backend
return <p>Loading...</p>
}
if(sponsorsDict) { //maps out the dictionary and displays the content
return (<div id='OurSponsors'>
<div id='BecomeASponsors'>
<button onClick={() => OpenPage('/BecomeASponsor')}>Become A Sponsor</button>
</div>
{Object.keys(sponsorsDict).map((sponsorTier) => (
<div key={sponsorTier} className={sponsorTier}>
<h2>{sponsorTier}</h2>
{Object.keys(sponsorsDict[sponsorTier]).map((sponsorKey) => {
const sponsor = sponsorsDict[sponsorTier][sponsorKey];
return (
<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>);
}
if (!sponsorsDict) {
//awaiting for a resposne from the backend
return <p>Loading...</p>;
}
if (sponsorsDict) {
//maps out the dictionary and displays the content
return (
<div id="OurSponsors">
<div id="BecomeASponsors">
<button onClick={() => OpenPage("/BecomeASponsor")}>
Become A Sponsor
</button>
</div>
<div>
<h3>Current Sponsors</h3>
{Object.keys(sponsorsDict).map((sponsorTier) => (
<div
key={sponsorTier}
className={sponsorTier}>
<h2>{sponsorTier}</h2>
{Object.keys(sponsorsDict[sponsorTier]).map((sponsorKey) => {
const sponsor = sponsorsDict[sponsorTier][sponsorKey];
return (
<div key={sponsorKey}>
<div>
<div>
{sponsor.Name && <h3>{sponsor.Name}</h3>}
{sponsor.LogoUrl && (
<a
href={sponsor.Url}
target="_blank">
<img
src={sponsor.LogoUrl}
alt="Sponsor Logo"
/>
</a>
)}
</div>
{sponsor.DescriptionAboutSponsor !== undefined &&
sponsor.DecriptionOnHelp !== undefined &&
(sponsorTier != "Bronze Tier" ||
sponsorTier != "Silver Tier") && (
<p>Another Element</p>
)}
</div>
{sponsor.DescriptionAboutSponsor !== undefined &&
(sponsorTier != "Bronze Tier" ||
sponsorTier != "Silver Tier") && (
<p>{sponsor.DescriptionAboutSponsor}</p>
)}
{sponsor.DecriptionOnHelp !== undefined &&
(sponsorTier != "Bronze Tier" ||
sponsorTier != "Silver Tier") && (
<p>{sponsor.DecriptionOnHelp}</p>
)}
</div>
);
})}
</div>
))}
</div>
</div>
);
}
}; };
export default OurSponsors; export default OurSponsors;