type lint fix
This commit is contained in:
parent
59721edcd4
commit
e58b955496
43
src/components/Seo/index.tsx
Normal file
43
src/components/Seo/index.tsx
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
import React, { FC } from "react"
|
||||||
|
import PropTypes from "prop-types"
|
||||||
|
import { useStaticQuery, graphql } from "gatsby"
|
||||||
|
|
||||||
|
interface seoType {
|
||||||
|
description: string,
|
||||||
|
title : string,
|
||||||
|
children: React.ReactNode;
|
||||||
|
}
|
||||||
|
|
||||||
|
const SEO: FC<seoType> = (props) => {
|
||||||
|
const { site } = useStaticQuery(
|
||||||
|
graphql`
|
||||||
|
query {
|
||||||
|
site {
|
||||||
|
siteMetadata {
|
||||||
|
title
|
||||||
|
description
|
||||||
|
author
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
`
|
||||||
|
)
|
||||||
|
|
||||||
|
const metaDescription = props.description || site.siteMetadata.description
|
||||||
|
|
||||||
|
return (
|
||||||
|
<>
|
||||||
|
<html lang="en" />
|
||||||
|
<title>{props.title}</title>
|
||||||
|
<meta name="description" content={metaDescription} />
|
||||||
|
<meta property="og:title" content={props.title} />
|
||||||
|
<meta property="og:description" content={metaDescription} />
|
||||||
|
<meta property="og:type" content="website" />
|
||||||
|
<meta name="twitter:creator" content={site.siteMetadata.author} />
|
||||||
|
<link href="https://fonts.googleapis.com/css?family=Open+Sans" rel="stylesheet"/>
|
||||||
|
{props.children}
|
||||||
|
</>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
export default SEO
|
@ -1,36 +1,31 @@
|
|||||||
import React from "react";
|
import React from "react";
|
||||||
import { graphql, Script } from "gatsby";
|
import { graphql, HeadProps, PageProps, Script } from "gatsby";
|
||||||
import config from '../../../data/site-config';
|
import config from '../../../data/site-config';
|
||||||
import Base from "../../components/Base";
|
import Base from "../../components/Base";
|
||||||
import SEO from "../../components/seo";
|
import SEO from "../../components/Seo";
|
||||||
|
import Comment from "../../components/Comment"
|
||||||
import { MDXProvider } from '@mdx-js/react';
|
import { MDXProvider } from '@mdx-js/react';
|
||||||
import './styles.scss';
|
import './styles.scss';
|
||||||
import './isso.css';
|
|
||||||
|
|
||||||
const Comment = ({post_id}) => {
|
type queryLayoutProps = {
|
||||||
return (
|
mdx: {
|
||||||
<>
|
frontmatter: {
|
||||||
<Script data-isso="//comments.nochill.in/"
|
title: string,
|
||||||
src="//comments.nochill.in/js/embed.min.js"
|
date: string,
|
||||||
data-isso-css="false"
|
last_update: string
|
||||||
id={post_id}
|
}
|
||||||
/>
|
}
|
||||||
|
children: any
|
||||||
<section id="isso-thread">
|
|
||||||
<noscript>Javascript needs to be activated to view comments.</noscript>
|
|
||||||
</section>
|
|
||||||
</>
|
|
||||||
)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const Layout = ({ data, children }) => {
|
const Layout = ({ data, children }: PageProps<queryLayoutProps>) => {
|
||||||
|
|
||||||
|
|
||||||
const post = data.mdx.frontmatter;
|
const post = data.mdx.frontmatter;
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Base>
|
<Base>
|
||||||
<div className="post template">
|
<div className="post template">
|
||||||
<SEO title={`${post.title} | ${config.siteTitle}`} />
|
|
||||||
<div className="post page">
|
<div className="post page">
|
||||||
<div className="article figure">
|
<div className="article figure">
|
||||||
<div className="HeaderContainer">
|
<div className="HeaderContainer">
|
||||||
@ -70,3 +65,13 @@ query($id: String) {
|
|||||||
`;
|
`;
|
||||||
|
|
||||||
export default Layout;
|
export default Layout;
|
||||||
|
|
||||||
|
export const Head = (props: HeadProps<queryLayoutProps>) => {
|
||||||
|
return (
|
||||||
|
<SEO
|
||||||
|
title={`${props.data.mdx.frontmatter.title} | ${config.siteTitle}`}
|
||||||
|
description=""
|
||||||
|
children=""
|
||||||
|
/>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
@ -1,340 +0,0 @@
|
|||||||
/* ========================================================================== */
|
|
||||||
/* Generic styling */
|
|
||||||
/* ========================================================================== */
|
|
||||||
#isso-thread * {
|
|
||||||
/* Reset */
|
|
||||||
-webkit-box-sizing: border-box;
|
|
||||||
-moz-box-sizing: border-box;
|
|
||||||
box-sizing: border-box;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* ========================================================================== */
|
|
||||||
/* Thread heading area */
|
|
||||||
/* ========================================================================== */
|
|
||||||
#isso-thread {
|
|
||||||
padding: 0 0 50px 0;
|
|
||||||
margin: 40px 0 0 0;
|
|
||||||
}
|
|
||||||
h4.isso-thread-heading {
|
|
||||||
color: #fff;
|
|
||||||
font-weight: bold;
|
|
||||||
}
|
|
||||||
.isso-feedlink {
|
|
||||||
float: right;
|
|
||||||
padding-left: 1em;
|
|
||||||
}
|
|
||||||
.isso-feedlink a {
|
|
||||||
font-size: 0.8em;
|
|
||||||
vertical-align: bottom;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* ========================================================================== */
|
|
||||||
/* Comments */
|
|
||||||
/* ========================================================================== */
|
|
||||||
|
|
||||||
.isso-comment {
|
|
||||||
max-width: 68em;
|
|
||||||
margin: 0 auto;
|
|
||||||
}
|
|
||||||
.isso-preview .isso-comment {
|
|
||||||
padding-top: 0;
|
|
||||||
margin: 0;
|
|
||||||
}
|
|
||||||
.isso-comment:not(:first-of-type),
|
|
||||||
.isso-follow-up .isso-comment {
|
|
||||||
border-top: 1px solid rgba(0, 0, 0, 0.1);
|
|
||||||
margin-bottom: 0.5em;
|
|
||||||
}
|
|
||||||
.isso-avatar {
|
|
||||||
display: block;
|
|
||||||
float: left;
|
|
||||||
margin: 0.95em 0.95em 0;
|
|
||||||
}
|
|
||||||
.isso-avatar svg {
|
|
||||||
max-width: 48px;
|
|
||||||
max-height: 48px;
|
|
||||||
width: 100%;
|
|
||||||
height: 100%;
|
|
||||||
border: 1px solid rgba(0, 0, 0, 0.2);
|
|
||||||
border-radius: 3px;
|
|
||||||
box-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
|
|
||||||
}
|
|
||||||
.isso-text-wrapper {
|
|
||||||
display: block;
|
|
||||||
padding: 0.95em;
|
|
||||||
}
|
|
||||||
.isso-follow-up {
|
|
||||||
padding-left: calc(7% + 20px);
|
|
||||||
}
|
|
||||||
.isso-comment-footer {
|
|
||||||
font-size: 0.95em;
|
|
||||||
}
|
|
||||||
.isso-comment-header {
|
|
||||||
font-size: 0.85em;
|
|
||||||
}
|
|
||||||
.isso-comment-header a {
|
|
||||||
text-decoration: none;
|
|
||||||
}
|
|
||||||
/* Only for comment header, spacer between up-/downvote should have no padding */
|
|
||||||
.isso-comment-header .isso-spacer {
|
|
||||||
padding: 0 6px;
|
|
||||||
}
|
|
||||||
.isso-spacer,
|
|
||||||
.isso-permalink,
|
|
||||||
.isso-note,
|
|
||||||
.isso-parent {
|
|
||||||
color: gray;
|
|
||||||
font-weight: normal;
|
|
||||||
text-shadow: none;
|
|
||||||
}
|
|
||||||
.isso-spacer:hover,
|
|
||||||
.isso-permalink:hover,
|
|
||||||
.isso-note:hover,
|
|
||||||
.isso-parent:hover {
|
|
||||||
color: #606060;
|
|
||||||
}
|
|
||||||
.isso-note {
|
|
||||||
float: right;
|
|
||||||
}
|
|
||||||
.isso-author {
|
|
||||||
font-weight: bold;
|
|
||||||
color: #cbcbcb;
|
|
||||||
}
|
|
||||||
.isso-page-author-suffix {
|
|
||||||
font-weight: bold;
|
|
||||||
color: #2c2c2c;
|
|
||||||
}
|
|
||||||
.isso-textarea,
|
|
||||||
.isso-preview {
|
|
||||||
margin-top: 0.2em;
|
|
||||||
width: 100%;
|
|
||||||
border: 1px solid #f0f0f0;
|
|
||||||
border-radius: 2px;
|
|
||||||
box-shadow: 0 0 2px #888;
|
|
||||||
}
|
|
||||||
.isso-text {
|
|
||||||
color: #fff;
|
|
||||||
word-break: break-word;
|
|
||||||
}
|
|
||||||
.isso-text p {
|
|
||||||
margin-top: 0.2em;
|
|
||||||
}
|
|
||||||
.isso-text p:last-child {
|
|
||||||
margin-bottom: 0.2em;
|
|
||||||
}
|
|
||||||
.isso-text h1,
|
|
||||||
.isso-text h2,
|
|
||||||
.isso-text h3,
|
|
||||||
.isso-text h4,
|
|
||||||
.isso-text h5,
|
|
||||||
.isso-text h6 {
|
|
||||||
font-size: 130%;
|
|
||||||
font-weight: bold;
|
|
||||||
}
|
|
||||||
.isso-text pre {
|
|
||||||
background: #eee;
|
|
||||||
border: 1px solid #ddd;
|
|
||||||
padding: 10px 15px;
|
|
||||||
color: #4d4d4c;
|
|
||||||
overflow: auto;
|
|
||||||
line-height: 1.5em;
|
|
||||||
}
|
|
||||||
.isso-text :not(pre) > code {
|
|
||||||
padding: .2em .4em;
|
|
||||||
margin: 0;
|
|
||||||
font-size: 85%;
|
|
||||||
background-color: #eeeeee;
|
|
||||||
border-radius: 6px;
|
|
||||||
}
|
|
||||||
.isso-comment-footer {
|
|
||||||
font-size: 0.80em;
|
|
||||||
color: gray;
|
|
||||||
clear: left;
|
|
||||||
}
|
|
||||||
.isso-feedlink,
|
|
||||||
.isso-comment-footer a {
|
|
||||||
font-weight: bold;
|
|
||||||
text-decoration: none;
|
|
||||||
}
|
|
||||||
.isso-feedlink:hover,
|
|
||||||
.isso-comment-footer a:hover {
|
|
||||||
color: #fff;
|
|
||||||
text-shadow: #aaaaaa 0 0 1px;
|
|
||||||
}
|
|
||||||
.isso-comment-footer > a {
|
|
||||||
position: relative;
|
|
||||||
top: .2em;
|
|
||||||
}
|
|
||||||
.isso-comment-footer > a + a {
|
|
||||||
padding-left: 1em;
|
|
||||||
}
|
|
||||||
.isso-comment-footer .isso-votes {
|
|
||||||
color: gray;
|
|
||||||
}
|
|
||||||
.isso-upvote svg,
|
|
||||||
.isso-downvote svg {
|
|
||||||
position: relative;
|
|
||||||
top: .2em;
|
|
||||||
}
|
|
||||||
/* Reply postbox under existing comment */
|
|
||||||
.isso-comment .isso-postbox {
|
|
||||||
margin-top: 0.8em;
|
|
||||||
}
|
|
||||||
.isso-comment.isso-no-votes > * > .isso-comment-footer .isso-votes {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* ========================================================================== */
|
|
||||||
/* Postbox */
|
|
||||||
/* ========================================================================== */
|
|
||||||
.isso-postbox {
|
|
||||||
max-width: 68em;
|
|
||||||
margin: 0 auto 2em;
|
|
||||||
clear: right;
|
|
||||||
}
|
|
||||||
.isso-form-wrapper {
|
|
||||||
display: block;
|
|
||||||
padding: 0;
|
|
||||||
}
|
|
||||||
.isso-textarea,
|
|
||||||
.isso-preview {
|
|
||||||
margin: 0 0 .3em;
|
|
||||||
padding: .4em .8em;
|
|
||||||
border-radius: 3px;
|
|
||||||
background-color: #282828;
|
|
||||||
border: 1px solid rgba(0, 0, 0, 0.2);
|
|
||||||
box-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
|
|
||||||
}
|
|
||||||
.isso-textarea {
|
|
||||||
color: #fff;
|
|
||||||
outline: 0;
|
|
||||||
width: 100%;
|
|
||||||
resize: none;
|
|
||||||
}
|
|
||||||
.isso-form-wrapper input[type=checkbox] {
|
|
||||||
vertical-align: middle;
|
|
||||||
position: relative;
|
|
||||||
bottom: 1px;
|
|
||||||
margin-left: 0;
|
|
||||||
}
|
|
||||||
.isso-notification-section {
|
|
||||||
font-size: 0.90em;
|
|
||||||
padding-top: .3em;
|
|
||||||
display: none;
|
|
||||||
padding-bottom: 10px;
|
|
||||||
}
|
|
||||||
.isso-auth-section {
|
|
||||||
display: block;
|
|
||||||
}
|
|
||||||
.isso-textarea:focus,
|
|
||||||
.isso-input-wrapper input:focus,
|
|
||||||
.isso-auth-section input:focus {
|
|
||||||
outline: 2px solid #3584e4;
|
|
||||||
}
|
|
||||||
.isso-input-wrapper {
|
|
||||||
display: inline-block;
|
|
||||||
position: relative;
|
|
||||||
margin: 0 1% 0 0;
|
|
||||||
color: #282828;
|
|
||||||
}
|
|
||||||
.isso-input-wrapper input {
|
|
||||||
display: block;
|
|
||||||
padding: .3em 10px;
|
|
||||||
max-width: 100%;
|
|
||||||
border-radius: 3px;
|
|
||||||
background-color: #282828;
|
|
||||||
line-height: 1.4em;
|
|
||||||
border: 1px solid rgba(0, 0, 0, 0.2);
|
|
||||||
box-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
|
|
||||||
color: #fff;
|
|
||||||
}
|
|
||||||
.isso-input-wrapper label {
|
|
||||||
display: block;
|
|
||||||
line-height: 1.4em;
|
|
||||||
height: 1.4em;
|
|
||||||
color: #fff !important;
|
|
||||||
}
|
|
||||||
label {
|
|
||||||
color: #fff;
|
|
||||||
}
|
|
||||||
.isso-post-action {
|
|
||||||
display: block;
|
|
||||||
float: right;
|
|
||||||
margin: 1.4em 0 0 5px;
|
|
||||||
}
|
|
||||||
.isso-post-action > input {
|
|
||||||
padding: calc(.3em - 1px);
|
|
||||||
border-radius: 2px;
|
|
||||||
border: 1px solid #ccc;
|
|
||||||
background-color: #ddd;
|
|
||||||
cursor: pointer;
|
|
||||||
outline: 0;
|
|
||||||
line-height: 1.4em;
|
|
||||||
box-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
|
|
||||||
}
|
|
||||||
.isso-post-action > input:hover {
|
|
||||||
background-color: #ccc;
|
|
||||||
}
|
|
||||||
.isso-post-action > input:active {
|
|
||||||
background-color: #bbb;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* ========================================================================== */
|
|
||||||
/* Postbox (preview mode) */
|
|
||||||
/* ========================================================================== */
|
|
||||||
.isso-preview,
|
|
||||||
.isso-post-action input[name="edit"],
|
|
||||||
.isso-postbox.isso-preview-mode > .isso-form-wrapper input[name="preview"],
|
|
||||||
.isso-postbox.isso-preview-mode > .isso-form-wrapper .isso-textarea {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
.isso-postbox.isso-preview-mode > .isso-form-wrapper .isso-preview {
|
|
||||||
display: block;
|
|
||||||
}
|
|
||||||
.isso-postbox.isso-preview-mode > .isso-form-wrapper input[name="edit"] {
|
|
||||||
display: inline;
|
|
||||||
}
|
|
||||||
.isso-preview {
|
|
||||||
background-color: #f8f8f8;
|
|
||||||
background: repeating-linear-gradient(
|
|
||||||
-45deg,
|
|
||||||
#f8f8f8,
|
|
||||||
#f8f8f8 10px,
|
|
||||||
#fff 10px,
|
|
||||||
#fff 20px
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* ========================================================================== */
|
|
||||||
/* Animations */
|
|
||||||
/* ========================================================================== */
|
|
||||||
|
|
||||||
/* "target" means the comment that's being linked to, for example:
|
|
||||||
* https://example.com/blog/example/#isso-15
|
|
||||||
*/
|
|
||||||
.isso-target {
|
|
||||||
animation: isso-target-fade 5s ease-out;
|
|
||||||
}
|
|
||||||
@keyframes isso-target-fade {
|
|
||||||
0% { background-color: #eee5a1; }
|
|
||||||
/* This color should be changed when used on a dark background,
|
|
||||||
* maybe #3f3c1c for example
|
|
||||||
*/
|
|
||||||
}
|
|
||||||
|
|
||||||
/* ========================================================================== */
|
|
||||||
/* Media queries */
|
|
||||||
/* ========================================================================== */
|
|
||||||
@media screen and (max-width:600px) {
|
|
||||||
.isso-input-wrapper {
|
|
||||||
display: block;
|
|
||||||
max-width: 100%;
|
|
||||||
margin: 0 0 .3em;
|
|
||||||
}
|
|
||||||
.isso-input-wrapper input {
|
|
||||||
width: 100%;
|
|
||||||
}
|
|
||||||
.isso-post-action {
|
|
||||||
margin-top: 0;
|
|
||||||
}
|
|
||||||
}
|
|
@ -3,13 +3,12 @@ import { GatsbyImage, getImage } from "gatsby-plugin-image";
|
|||||||
import { useStaticQuery, graphql } from "gatsby"
|
import { useStaticQuery, graphql } from "gatsby"
|
||||||
|
|
||||||
import Base from "../../components/Base"
|
import Base from "../../components/Base"
|
||||||
import SEO from "../../components/seo"
|
import SEO from "../../components/Seo";
|
||||||
|
|
||||||
import "./styles.scss";
|
import "./styles.scss";
|
||||||
|
|
||||||
const AboutPage = () => (
|
const AboutPage = () => (
|
||||||
<Base>
|
<Base>
|
||||||
<SEO title="About" />
|
|
||||||
<div style={{ color: '#eeeeee'}}>
|
<div style={{ color: '#eeeeee'}}>
|
||||||
<h4>Who are you ?</h4>
|
<h4>Who are you ?</h4>
|
||||||
<p>nc</p>
|
<p>nc</p>
|
||||||
@ -31,6 +30,15 @@ const AboutPage = () => (
|
|||||||
</Base>
|
</Base>
|
||||||
)
|
)
|
||||||
|
|
||||||
|
export const Head = () => {
|
||||||
|
return (
|
||||||
|
<SEO title="About"
|
||||||
|
children=""
|
||||||
|
description=""
|
||||||
|
/>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
const Image = () => {
|
const Image = () => {
|
||||||
const data = useStaticQuery(graphql`
|
const data = useStaticQuery(graphql`
|
||||||
query {
|
query {
|
||||||
|
@ -2,11 +2,31 @@ import React, { useEffect } from "react"
|
|||||||
import { graphql } from "gatsby"
|
import { graphql } from "gatsby"
|
||||||
|
|
||||||
import Base from '../components/Base'
|
import Base from '../components/Base'
|
||||||
import SEO from "../components/seo"
|
import SEO from "../components/Seo"
|
||||||
import PostList from "../components/PostList"
|
import PostList from "../components/PostList"
|
||||||
import init, { greet } from "snake_game"
|
import init, { greet } from "snake_game"
|
||||||
|
|
||||||
const IndexPage = (props) => {
|
type articleListType = {
|
||||||
|
data: {
|
||||||
|
allMdx: {
|
||||||
|
edges: [articleType]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
type articleType = {
|
||||||
|
node: {
|
||||||
|
excerpt: string,
|
||||||
|
frontmatter: {
|
||||||
|
archive: boolean,
|
||||||
|
date: string,
|
||||||
|
slug: string,
|
||||||
|
title: string
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const IndexPage = (props: articleListType) => {
|
||||||
const postEdges = props.data.allMdx.edges;
|
const postEdges = props.data.allMdx.edges;
|
||||||
|
|
||||||
const initWasm = () => {
|
const initWasm = () => {
|
||||||
@ -22,13 +42,19 @@ const IndexPage = (props) => {
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<Base>
|
<Base>
|
||||||
<SEO title="Home" />
|
|
||||||
<PostList postEdges={postEdges}/>
|
<PostList postEdges={postEdges}/>
|
||||||
</Base>
|
</Base>
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
export default IndexPage
|
export default IndexPage;
|
||||||
|
|
||||||
|
export const Head = () => {
|
||||||
|
<SEO title="Home"
|
||||||
|
children=""
|
||||||
|
description=""
|
||||||
|
/>
|
||||||
|
}
|
||||||
|
|
||||||
export const pageQuery = graphql`
|
export const pageQuery = graphql`
|
||||||
query IndexQuery {
|
query IndexQuery {
|
||||||
|
Loading…
Reference in New Issue
Block a user