mirror of
https://github.com/mastermindzh/rickvanlieshout.com
synced 2025-01-13 15:29:16 +01:00
fix(opengraph): added mandatory opengraph tags to all pages. Also fixed some other minor bugs
This commit is contained in:
parent
4e6b042a44
commit
98a3eb71f5
@ -64,6 +64,7 @@ Building an interactive and fully customizable dashboard on top of VAA's existin
|
|||||||
I'll list some of the training courses I've had whilst working.
|
I'll list some of the training courses I've had whilst working.
|
||||||
Some of these have (official) certificates, some don't, but all have brought value and knowledge.
|
Some of these have (official) certificates, some don't, but all have brought value and knowledge.
|
||||||
|
|
||||||
|
- Young Executive Program (YEP) - [De Baak](https://debaak.nl/trainingen/young-executives-program)
|
||||||
- Hiring & interview training ([icm.nl](https://www.icm.nl/opleidingen-en-trainingen/hrm/selectiegesprekken-voeren/))
|
- Hiring & interview training ([icm.nl](https://www.icm.nl/opleidingen-en-trainingen/hrm/selectiegesprekken-voeren/))
|
||||||
- Conversation techniques & de-escalation ([TIJDwinst.com](https://gesprekstechnieken.com/cursus-gesprekstechnieken/)](<https://gesprekstechnieken.com/cursus-gesprekstechnieken/>)).
|
- Conversation techniques & de-escalation ([TIJDwinst.com](https://gesprekstechnieken.com/cursus-gesprekstechnieken/)](<https://gesprekstechnieken.com/cursus-gesprekstechnieken/>)).
|
||||||
- Kubernetes (NobleProg Certification Kubernetes on Azure (AKS), 26 August 2019 - 27 August 2019)
|
- Kubernetes (NobleProg Certification Kubernetes on Azure (AKS), 26 August 2019 - 27 August 2019)
|
||||||
|
Binary file not shown.
Before Width: | Height: | Size: 2.5 MiB |
Binary file not shown.
After Width: | Height: | Size: 243 KiB |
Binary file not shown.
Before Width: | Height: | Size: 1.3 MiB |
Binary file not shown.
After Width: | Height: | Size: 89 KiB |
@ -50,7 +50,7 @@ We also started working on the controllers. The final design will be compromised
|
|||||||
![back](./media/back.jpg "Back of the controller")
|
![back](./media/back.jpg "Back of the controller")
|
||||||
![bottom](./media/bottom.jpg "bottom of the controller")
|
![bottom](./media/bottom.jpg "bottom of the controller")
|
||||||
![controller_pot](./media/controller_pot.jpg "potentiometer used inside the controller")
|
![controller_pot](./media/controller_pot.jpg "potentiometer used inside the controller")
|
||||||
![front](./media/Front_thumb.png "The front of the controller with the logo")
|
![front](./media/front-thumb.png "The front of the controller with the logo")
|
||||||
![inside](./media/inside.jpg "the inside of an assembled controller")
|
![inside](./media/inside.jpg "the inside of an assembled controller")
|
||||||
![left_side](./media/left_side.jpg "The left side of the controller")
|
![left_side](./media/left_side.jpg "The left side of the controller")
|
||||||
![right_side](./media/right_side.jpg "The right side of the controller")
|
![right_side](./media/right_side.jpg "The right side of the controller")
|
||||||
|
@ -11,23 +11,23 @@ disqusId: "17"
|
|||||||
socialImage: "./media/wiring1.jpg"
|
socialImage: "./media/wiring1.jpg"
|
||||||
---
|
---
|
||||||
|
|
||||||
In the 3rd part of my TekTree project I'll show you guys how to wire everything. This time I even used separate colours for the power,ground and signal wires. So no more complaining ! ^\_^ All in all I think the result looks absolutely wicked. Even without the arduino case which has yet to come in the mail. (and probably won't fit)
|
In the 3rd part of my TekTree project I'll show you guys how to wire everything. This time I even used separate colours for the power, ground and signal wires. So no more complaining! ^\_^ All in all I think the result looks absolutely wicked. Even without the Arduino case which has yet to come in the mail. (and probably won't fit)
|
||||||
|
|
||||||
## Wiring part 1 - schematics
|
## Wiring part 1 - schematics
|
||||||
|
|
||||||
Before I started to jam wires in every nook and cranny I could find I had to come up with a plan. Most of that plan has been put into a "Fritzing" sketch which can be found below and on [Github](https://github.com/Mastermindzh/TekTree). The only thing I couldn't figure out how to model on fritzing is the actual christmas tree and the power cord for the arduino.
|
Before I started to jam wires in every nook and cranny I could find I had to come up with a plan. Most of that plan has been put into a "Fritzing" sketch which can be found below and on [Github](https://github.com/Mastermindzh/TekTree). The only thing I couldn't figure out how to model on fritzing is the actual Christmas tree and the power cord for the Arduino.
|
||||||
|
|
||||||
The arduino will get power from a regular adaptor. The only modification I did to the adapter is putting a button on one of the wires. And the only reason I did that is because I'm too lazy to unplug the TekTree when I want to turn it off :)
|
The Arduino will get power from a regular adaptor. The only modification I made to the adapter was putting a button on one of the wires. The only reason I did that is because I'm too lazy to unplug the TekTree when I want to turn it off :)
|
||||||
|
|
||||||
![Wiring of the back of the Tektree. You can see a lot of jumper wires sticking out and connecting to LEDs](./media/wiring1.jpg)
|
![Wiring of the back of the Tektree. You can see a lot of jumper wires sticking out and connecting to LEDs](./media/wiring1.jpg)
|
||||||
|
|
||||||
## Why so many wires?
|
## Why so many wires?
|
||||||
|
|
||||||
I want the project to be "manageable" for everyone. To do this I kept the wiring as simple as possible. Every LED has 2 prongs, 1 goes to ground 1 goes to the arduino. Simple. Same goes for the potentiometers, 3 legs, 1 power 1 ground 1 signal. The only led's I did bundle together (in terms of wiring) is the star. I did this to create a single star instead of multiple led's.
|
I want the project to be "manageable" for everyone. To do this I kept the wiring as simple as possible. Every LED has 2 prongs, 1 goes to ground 1 goes to the Arduino. Simple. Same goes for the potentiometers, 3 legs, 1 power 1 ground 1 signal. The only leds I did bundle together (in terms of wiring) is the star. I did this to create a single star instead of multiple led's.
|
||||||
|
|
||||||
## Well you could've made it way prettier... and
|
## Well you could've made it way prettier... and
|
||||||
|
|
||||||
Well yes, as all of us know I'm perfectly capable of designing a [refined build](/images/blogs/han4pi/Front_thumb.png). I didn't want to go with a pcb this time however because that would make the barrier to entry way higher on this project. And that is something I definitely **don't** want.
|
Well yes, as all of us know I'm perfectly capable of designing a [refined build](/images/blogs/han4pi/front.png). I didn't want to go with a pcb this time however because that would make the barrier to entry way higher on this project. And that is something I definitely **don't** want.
|
||||||
|
|
||||||
I also didn't "group" all my ground wires together. (led -> led -> led -> board) This would've made the project a lot neater but it wouldn't be anywhere near as service friendly. (which was kinda the idea...)
|
I also didn't "group" all my ground wires together. (led -> led -> led -> board) This would've made the project a lot neater but it wouldn't be anywhere near as service friendly. (which was kinda the idea...)
|
||||||
|
|
||||||
|
BIN
content/posts/2015/tektree-part-3-wiring/media/front.png
Normal file
BIN
content/posts/2015/tektree-part-3-wiring/media/front.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 280 KiB |
@ -171,7 +171,7 @@ export default {
|
|||||||
stripQueryString: true,
|
stripQueryString: true,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
// remove the old serviceworker if it is available.
|
// remove the old service worker if it is available.
|
||||||
"gatsby-plugin-remove-serviceworker",
|
"gatsby-plugin-remove-serviceworker",
|
||||||
"gatsby-plugin-image",
|
"gatsby-plugin-image",
|
||||||
"gatsby-plugin-catch-links",
|
"gatsby-plugin-catch-links",
|
||||||
|
@ -11,6 +11,7 @@ interface Props {
|
|||||||
socialImage?: string;
|
socialImage?: string;
|
||||||
children: React.ReactNode;
|
children: React.ReactNode;
|
||||||
noIndex?: boolean;
|
noIndex?: boolean;
|
||||||
|
slug?: string;
|
||||||
}
|
}
|
||||||
|
|
||||||
const Layout: React.FC<Props> = ({
|
const Layout: React.FC<Props> = ({
|
||||||
@ -19,6 +20,7 @@ const Layout: React.FC<Props> = ({
|
|||||||
description,
|
description,
|
||||||
socialImage = "",
|
socialImage = "",
|
||||||
noIndex = false,
|
noIndex = false,
|
||||||
|
slug,
|
||||||
}: Props) => {
|
}: Props) => {
|
||||||
const { author, url } = useSiteMetadata();
|
const { author, url } = useSiteMetadata();
|
||||||
const metaImage = socialImage || author.photo;
|
const metaImage = socialImage || author.photo;
|
||||||
@ -33,6 +35,7 @@ const Layout: React.FC<Props> = ({
|
|||||||
<meta property="og:description" content={description} />
|
<meta property="og:description" content={description} />
|
||||||
<meta property="og:site_name" content={title} />
|
<meta property="og:site_name" content={title} />
|
||||||
<meta property="og:image" content={metaImageUrl} />
|
<meta property="og:image" content={metaImageUrl} />
|
||||||
|
{slug && <meta property="og:url" content={`${url}${slug}`} />}
|
||||||
<meta name="twitter:card" content="summary" />
|
<meta name="twitter:card" content="summary" />
|
||||||
<meta name="twitter:title" content={title} />
|
<meta name="twitter:title" content={title} />
|
||||||
<meta name="twitter:description" content={description} />
|
<meta name="twitter:description" content={description} />
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
import React, { useEffect, useRef } from "react";
|
import React, { useEffect, useRef } from "react";
|
||||||
|
|
||||||
import * as styles from "./Page.module.scss";
|
|
||||||
import type { Nullable } from "@/types";
|
import type { Nullable } from "@/types";
|
||||||
|
import { Helmet } from "react-helmet";
|
||||||
|
import * as styles from "./Page.module.scss";
|
||||||
|
|
||||||
interface Props {
|
interface Props {
|
||||||
title?: string;
|
title?: string;
|
||||||
@ -19,12 +19,17 @@ const Page: React.FC<Props> = ({ title, children }: Props) => {
|
|||||||
}, []);
|
}, []);
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div ref={pageRef} className={styles.page}>
|
<>
|
||||||
<div className={styles.inner}>
|
<Helmet>
|
||||||
{title && <h1 className={styles.title}>{title}</h1>}
|
<meta property="og:type" content="website" />
|
||||||
<div className={styles.body}>{children}</div>
|
</Helmet>
|
||||||
|
<div ref={pageRef} className={styles.page}>
|
||||||
|
<div className={styles.inner}>
|
||||||
|
{title && <h1 className={styles.title}>{title}</h1>}
|
||||||
|
<div className={styles.body}>{children}</div>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</>
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -13,7 +13,7 @@ const CategoriesTemplate: React.FC = () => {
|
|||||||
const categories = useCategoriesList();
|
const categories = useCategoriesList();
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Layout title={`Categories - ${title}`} description={subtitle}>
|
<Layout title={`Categories - ${title}`} description={subtitle} slug="/categories/">
|
||||||
<Sidebar />
|
<Sidebar />
|
||||||
<Page title="Categories">
|
<Page title="Categories">
|
||||||
<ul>
|
<ul>
|
||||||
|
@ -28,7 +28,7 @@ const CategoryTemplate: React.FC<Props> = ({ data, pageContext }: Props) => {
|
|||||||
currentPage > 0 ? `${group} - Page ${currentPage} - ${siteTitle}` : `${group} - ${siteTitle}`;
|
currentPage > 0 ? `${group} - Page ${currentPage} - ${siteTitle}` : `${group} - ${siteTitle}`;
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Layout title={pageTitle} description={siteSubtitle}>
|
<Layout title={pageTitle} description={siteSubtitle} slug={`/category/${group}/`}>
|
||||||
<Sidebar />
|
<Sidebar />
|
||||||
<Page title={group}>
|
<Page title={group}>
|
||||||
<Feed edges={edges} />
|
<Feed edges={edges} />
|
||||||
|
@ -26,7 +26,7 @@ const IndexTemplate: React.FC<Props> = ({ data, pageContext }: Props) => {
|
|||||||
const pageTitle = currentPage > 0 ? `Posts - Page ${currentPage} - ${siteTitle}` : siteTitle;
|
const pageTitle = currentPage > 0 ? `Posts - Page ${currentPage} - ${siteTitle}` : siteTitle;
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Layout title={pageTitle} description={siteSubtitle}>
|
<Layout title={pageTitle} description={siteSubtitle} slug="">
|
||||||
<Sidebar isIndex />
|
<Sidebar isIndex />
|
||||||
<Page>
|
<Page>
|
||||||
<Feed edges={edges} />
|
<Feed edges={edges} />
|
||||||
|
@ -10,7 +10,7 @@ const NotFoundTemplate: React.FC = () => {
|
|||||||
const { title, subtitle } = useSiteMetadata();
|
const { title, subtitle } = useSiteMetadata();
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Layout title={`Not Found - ${title}`} description={subtitle}>
|
<Layout title={`Not Found - ${title}`} description={subtitle} slug="/404.html">
|
||||||
<Sidebar />
|
<Sidebar />
|
||||||
<Page title="Oh no! page be lost">
|
<Page title="Oh no! page be lost">
|
||||||
<p>
|
<p>
|
||||||
|
@ -26,6 +26,7 @@ const PageTemplate: React.FC<Props> = ({ data }: Props) => {
|
|||||||
title={`${title} - ${siteTitle}`}
|
title={`${title} - ${siteTitle}`}
|
||||||
description={metaDescription}
|
description={metaDescription}
|
||||||
socialImage={socialImage?.publicURL}
|
socialImage={socialImage?.publicURL}
|
||||||
|
slug={data.markdownRemark.fields.slug}
|
||||||
>
|
>
|
||||||
<Sidebar />
|
<Sidebar />
|
||||||
<Page title={title}>
|
<Page title={title}>
|
||||||
@ -40,6 +41,9 @@ export const query = graphql`
|
|||||||
markdownRemark(fields: { slug: { eq: $slug } }) {
|
markdownRemark(fields: { slug: { eq: $slug } }) {
|
||||||
id
|
id
|
||||||
html
|
html
|
||||||
|
fields {
|
||||||
|
slug
|
||||||
|
}
|
||||||
frontmatter {
|
frontmatter {
|
||||||
title
|
title
|
||||||
date
|
date
|
||||||
|
@ -24,6 +24,7 @@ const PostTemplate: React.FC<Props> = ({ data }: Props) => {
|
|||||||
title={`${title} - ${siteTitle}`}
|
title={`${title} - ${siteTitle}`}
|
||||||
description={metaDescription}
|
description={metaDescription}
|
||||||
socialImage={socialImage?.publicURL}
|
socialImage={socialImage?.publicURL}
|
||||||
|
slug={data.markdownRemark.fields.slug}
|
||||||
>
|
>
|
||||||
<Post post={data.markdownRemark} />
|
<Post post={data.markdownRemark} />
|
||||||
</Layout>
|
</Layout>
|
||||||
|
@ -28,7 +28,7 @@ const TagTemplate: React.FC<Props> = ({ data, pageContext }: Props) => {
|
|||||||
currentPage > 0 ? `${group} - Page ${currentPage} - ${siteTitle}` : `${group} - ${siteTitle}`;
|
currentPage > 0 ? `${group} - Page ${currentPage} - ${siteTitle}` : `${group} - ${siteTitle}`;
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Layout title={pageTitle} description={siteSubtitle}>
|
<Layout title={pageTitle} description={siteSubtitle} slug={`/tag/${group}/`}>
|
||||||
<Sidebar />
|
<Sidebar />
|
||||||
<Page title={group}>
|
<Page title={group}>
|
||||||
<Feed edges={edges} />
|
<Feed edges={edges} />
|
||||||
|
@ -13,7 +13,7 @@ const TagsTemplate: React.FC = () => {
|
|||||||
const tags = useTagsList();
|
const tags = useTagsList();
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Layout title={`Tags - ${title}`} description={subtitle}>
|
<Layout title={`Tags - ${title}`} description={subtitle} slug="/tags/">
|
||||||
<Sidebar />
|
<Sidebar />
|
||||||
<Page title="Tags">
|
<Page title="Tags">
|
||||||
<ul>
|
<ul>
|
||||||
|
Loading…
Reference in New Issue
Block a user