context for color, some bugfixes and types
This commit is contained in:
parent
95d49ec986
commit
94463f673e
12
TODO.md
12
TODO.md
@ -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)
|
|
||||||
|
@ -1,7 +0,0 @@
|
|||||||
{
|
|
||||||
"compilerOptions": {
|
|
||||||
"baseUrl": "./src",
|
|
||||||
"checkJs": true,
|
|
||||||
"jsx": "react"
|
|
||||||
}
|
|
||||||
}
|
|
3887
package-lock.json
generated
3887
package-lock.json
generated
File diff suppressed because it is too large
Load Diff
@ -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",
|
||||||
|
@ -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 (
|
||||||
|
3
src/context/SettingsContext.tsx
Normal file
3
src/context/SettingsContext.tsx
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
import React from "react";
|
||||||
|
|
||||||
|
export const SettingsContext = React.createContext(undefined);
|
24
src/context/SettingsProvider.tsx
Normal file
24
src/context/SettingsProvider.tsx
Normal 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
6
src/context/settings.tsx
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
/* eslint-disable no-unused-vars */
|
||||||
|
export interface Settings {
|
||||||
|
color: string;
|
||||||
|
language: string;
|
||||||
|
changeColor: (color: string) => void;
|
||||||
|
}
|
@ -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>
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -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>
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
@ -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 (
|
||||||
|
@ -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 (
|
||||||
|
@ -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
21
tsconfig.json
Normal 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"]
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user