context for color, some bugfixes and types

This commit is contained in:
Rick van Lieshout 2022-08-01 21:58:15 +02:00
parent 95d49ec986
commit 94463f673e
15 changed files with 2154 additions and 2075 deletions

12
TODO.md
View File

@ -1,17 +1,7 @@
# Todo # Todo
## Fonts
```js
// <!-- Google Webfonts -->
// <link href='https://fonts.googleapis.com/css?family=Open+Sans:400,300,400italic,600,700,800,700italic,600italic' rel='stylesheet' type='text/css'>
// <link href='https://fonts.googleapis.com/css?family=Neuton:400,200,300' rel='stylesheet' type='text/css'>
```
## Colours and languages (hooks? some state thing..) ## Colours and languages (hooks? some state thing..)
## favicon
## helmet ## helmet
<!-- code mentions META at some points (e.g disclaimer page) --> <!-- code mentions META at some points (e.g disclaimer page) -->
@ -22,5 +12,3 @@
- maybe transition to markdown loader? - maybe transition to markdown loader?
- add language switcher + download for both - add language switcher + download for both
- add highlight to "languages I like"
- tech turns red when hovered over link (need to hover on text too)

View File

@ -1,7 +0,0 @@
{
"compilerOptions": {
"baseUrl": "./src",
"checkJs": true,
"jsx": "react"
}
}

3887
package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@ -26,6 +26,7 @@
"gatsby-transformer-remark": "^5.19.0", "gatsby-transformer-remark": "^5.19.0",
"gatsby-transformer-sharp": "^4.19.0", "gatsby-transformer-sharp": "^4.19.0",
"html-react-parser": "^3.0.1", "html-react-parser": "^3.0.1",
"js-cookie": "^3.0.1",
"react": "^18.2.0", "react": "^18.2.0",
"react-bootstrap": "^2.4.0", "react-bootstrap": "^2.4.0",
"react-cookie-consent": "^7.5.0", "react-cookie-consent": "^7.5.0",
@ -35,6 +36,7 @@
}, },
"devDependencies": { "devDependencies": {
"@mastermindzh/prettier-config": "^1.0.0", "@mastermindzh/prettier-config": "^1.0.0",
"@types/js-cookie": "^3.0.2",
"@typescript-eslint/parser": "^5.30.7", "@typescript-eslint/parser": "^5.30.7",
"eslint": "^8.20.0", "eslint": "^8.20.0",
"eslint-config-prettier": "^8.5.0", "eslint-config-prettier": "^8.5.0",

View File

@ -1,6 +1,6 @@
import React, { FunctionComponent } from "react"; import React, { FunctionComponent, ReactNode } from "react";
type Props = {}; type Props = { children?: ReactNode };
export const FilterList: FunctionComponent<Props> = ({ children }) => { export const FilterList: FunctionComponent<Props> = ({ children }) => {
return ( return (

View File

@ -0,0 +1,3 @@
import React from "react";
export const SettingsContext = React.createContext(undefined);

View File

@ -0,0 +1,24 @@
import Cookies from "js-cookie";
import React, { FunctionComponent, ReactNode, useState } from "react";
import { Settings } from "./settings";
import { SettingsContext } from "./SettingsContext";
type Props = { children?: ReactNode };
export const SettingsProvider: FunctionComponent<Props> = ({ children }) => {
const cookieValue = Cookies.get("color");
const [color, setColor] = useState(cookieValue ?? "body-yellow");
const defaultSettings: Settings = {
color,
language: "en",
changeColor: (newColor: string) => {
// eslint-disable-next-line no-console
console.log(newColor);
setColor(newColor);
Cookies.set("color", newColor);
},
};
return <SettingsContext.Provider value={defaultSettings}>{children}</SettingsContext.Provider>;
};

6
src/context/settings.tsx Normal file
View File

@ -0,0 +1,6 @@
/* eslint-disable no-unused-vars */
export interface Settings {
color: string;
language: string;
changeColor: (color: string) => void;
}

View File

@ -6,10 +6,14 @@ import { Link } from "gatsby";
// import COLOR from "./../../constants/colors"; // import COLOR from "./../../constants/colors";
import { ROUTES } from "../constants/routes"; import { ROUTES } from "../constants/routes";
import { SettingsContext } from "../context/SettingsContext";
import { Settings } from "../context/settings";
// import { blue, green, lime, orange, pink, purple, red, yellow } from './../../assets/images/colors' // import { blue, green, lime, orange, pink, purple, red, yellow } from './../../assets/images/colors'
export const Footer: FunctionComponent<{}> = () => { export const Footer: FunctionComponent<{}> = () => {
return ( return (
<SettingsContext.Consumer>
{(context: Settings) => (
<footer> <footer>
<div className="row"> <div className="row">
<div className="col-md-7"> <div className="col-md-7">
@ -23,6 +27,15 @@ export const Footer: FunctionComponent<{}> = () => {
</div> </div>
<div className="col-md-5"> <div className="col-md-5">
<ul className="social"> <ul className="social">
<li>
<button
onClick={() => {
context.changeColor("body-red");
}}
>
red!
</button>
</li>
{/* <li> {/* <li>
<ButtonToolbar> <ButtonToolbar>
<DropdownButton className="plain-dropdown" title={<img style={{ marginRight: "3px", width: "21px" }} src={`/assets/images/colors/${this.props.color.split("-")[1]}.png`} alt="select color" />} dropup id="split-button-dropup"> <DropdownButton className="plain-dropdown" title={<img style={{ marginRight: "3px", width: "21px" }} src={`/assets/images/colors/${this.props.color.split("-")[1]}.png`} alt="select color" />} dropup id="split-button-dropup">
@ -61,6 +74,8 @@ export const Footer: FunctionComponent<{}> = () => {
</div> </div>
</div> </div>
</footer> </footer>
)}
</SettingsContext.Consumer>
); );
}; };

View File

@ -1,16 +1,22 @@
import { Link } from "gatsby";
import React, { FunctionComponent, ReactNode } from "react"; import React, { FunctionComponent, ReactNode } from "react";
// import CookieConsent from "react-cookie-consent"; import CookieConsent from "react-cookie-consent";
// import { Link } from "gatsby" import { Settings } from "../context/settings";
import { SettingsContext } from "../context/SettingsContext";
import { SettingsProvider } from "../context/SettingsProvider";
import "./../styles/style.scss"; import "./../styles/style.scss";
import { Footer } from "./footer"; import { Footer } from "./footer";
import { NavBar } from "./navigation/navbar"; import { NavBar } from "./navigation/navbar";
import { ProfilePicture } from "./profile-pic"; import { ProfilePicture } from "./profile-pic";
type Props = { children: ReactNode[] }; type Props = { children: ReactNode };
export const Layout: FunctionComponent<Props> = ({ children }) => { export const Layout: FunctionComponent<Props> = ({ children }) => {
return ( return (
<div className="body-red"> <SettingsProvider>
<SettingsContext.Consumer>
{(context: Settings) => (
<div className={context.color}>
<div className="main-content"> <div className="main-content">
<div className="container no-padding"> <div className="container no-padding">
<div className="row"> <div className="row">
@ -33,7 +39,7 @@ export const Layout: FunctionComponent<Props> = ({ children }) => {
</div> </div>
</div> </div>
</div> </div>
{/* <CookieConsent <CookieConsent
style={{ background: "#2B373B" }} style={{ background: "#2B373B" }}
buttonStyle={{ buttonStyle={{
background: "#e74c3c", background: "#e74c3c",
@ -45,10 +51,13 @@ export const Layout: FunctionComponent<Props> = ({ children }) => {
This website uses cookies to enhance the user experience. This website uses cookies to enhance the user experience.
<span style={{ fontSize: "10px" }}> <span style={{ fontSize: "10px" }}>
{" "} {" "}
Click <Link to="/cookies">here</Link> to learn more about cookies. Click <Link to="/legal/cookies">here</Link> to learn more about cookies.
</span> </span>
</span> </span>
</CookieConsent> */} </CookieConsent>
</div> </div>
)}
</SettingsContext.Consumer>
</SettingsProvider>
); );
}; };

View File

@ -1,6 +1,6 @@
import React, { FunctionComponent } from "react"; import React, { FunctionComponent, ReactNode } from "react";
type Props = { title: string; start: string; end: string; image: string }; type Props = { title: string; start: string; end: string; image: string; children: ReactNode };
export const ResumeItem: FunctionComponent<Props> = ({ title, start, end, image, children }) => { export const ResumeItem: FunctionComponent<Props> = ({ title, start, end, image, children }) => {
return ( return (

View File

@ -1,7 +1,7 @@
import React, { FunctionComponent } from "react"; import React, { FunctionComponent, ReactNode } from "react";
import { SectionTitle } from "../../../components/section-title"; import { SectionTitle } from "../../../components/section-title";
type Props = { title: string }; type Props = { title: string; children: ReactNode };
export const ResumeList: FunctionComponent<Props> = ({ title, children }) => { export const ResumeList: FunctionComponent<Props> = ({ title, children }) => {
return ( return (

View File

@ -14,6 +14,15 @@ $colours: (
color: $colour !important; color: $colour !important;
} }
.#{$element} .filter {
a {
&:hover {
// &:focus maybe
color: white !important;
}
}
}
.#{$element} .navigation li:before { .#{$element} .navigation li:before {
background: $colour !important; background: $colour !important;
} }
@ -30,9 +39,13 @@ $colours: (
color: $colour !important; color: $colour !important;
} }
.#{$element} #filter-list li:hover { .#{$element} #filter-list {
li {
&:hover {
background: $colour !important; background: $colour !important;
} }
}
}
.#{$element} #filter-list li.active { .#{$element} #filter-list li.active {
background: $colour !important; background: $colour !important;

21
tsconfig.json Normal file
View File

@ -0,0 +1,21 @@
{
"compilerOptions": {
"target": "es5",
"baseUrl": "src",
"lib": ["dom", "dom.iterable", "esnext"],
"allowJs": true,
"skipLibCheck": true,
"esModuleInterop": true,
"allowSyntheticDefaultImports": true,
"strict": true,
"forceConsistentCasingInFileNames": true,
"noFallthroughCasesInSwitch": true,
"module": "esnext",
"moduleResolution": "node",
"resolveJsonModule": true,
"isolatedModules": true,
"noEmit": true,
"jsx": "react-jsx"
},
"include": ["src"]
}