mirror of
https://github.com/kremalicious/blog.git
synced 2024-11-15 09:35:21 +01:00
restructure template components
This commit is contained in:
parent
80334bc05b
commit
d53b95ee80
@ -38,5 +38,9 @@ module.exports = {
|
||||
darkModeConfig: {
|
||||
classNameDark: 'dark',
|
||||
classNameLight: 'light'
|
||||
},
|
||||
ad: {
|
||||
title: 'Ledger Nano X: Keep your crypto secure, everywhere.',
|
||||
link: 'https://shop.ledger.com/pages/ledger-nano-x?r=3176d705002a'
|
||||
}
|
||||
}
|
||||
|
@ -1,5 +1,5 @@
|
||||
const path = require('path')
|
||||
const postsTemplate = path.resolve('src/templates/Posts.tsx')
|
||||
const postsTemplate = path.resolve('src/components/templates/Posts.tsx')
|
||||
const { itemsPerPage } = require('../config')
|
||||
|
||||
const redirects = [
|
||||
@ -24,7 +24,7 @@ function getPaginationData(i, numPages, slug) {
|
||||
}
|
||||
|
||||
exports.generatePostPages = (createPage, posts) => {
|
||||
const postTemplate = path.resolve('src/templates/Post.tsx')
|
||||
const postTemplate = path.resolve('src/components/templates/Post/index.tsx')
|
||||
|
||||
// Create Post pages
|
||||
posts.forEach(post => {
|
||||
|
@ -33,7 +33,11 @@
|
||||
"rss": "/feed.xml",
|
||||
"jsonfeed": "/feed.json",
|
||||
"itemsPerPage": 20,
|
||||
"repoContentPath": "https://github.com/kremalicious/blog/tree/master/content"
|
||||
"repoContentPath": "https://github.com/kremalicious/blog/tree/master/content",
|
||||
"ad": {
|
||||
"title": "",
|
||||
"link": ""
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
4
src/@types/Site.d.ts
vendored
4
src/@types/Site.d.ts
vendored
@ -30,4 +30,8 @@ export interface Site {
|
||||
classNameDark: string
|
||||
classNameLight: string
|
||||
}
|
||||
ad: {
|
||||
title: string
|
||||
link: string
|
||||
}
|
||||
}
|
||||
|
21
src/components/atoms/Ad.module.scss
Normal file
21
src/components/atoms/Ad.module.scss
Normal file
@ -0,0 +1,21 @@
|
||||
@import 'variables';
|
||||
|
||||
.ad {
|
||||
font-style: italic;
|
||||
display: block;
|
||||
text-align: center;
|
||||
position: relative;
|
||||
margin-top: $spacer * 3;
|
||||
margin-bottom: $spacer;
|
||||
|
||||
&::before {
|
||||
content: 'AFFILIATE';
|
||||
font-size: $font-size-mini;
|
||||
position: absolute;
|
||||
width: 100%;
|
||||
left: 0;
|
||||
top: 100%;
|
||||
color: $text-color-light;
|
||||
text-align: center;
|
||||
}
|
||||
}
|
29
src/components/atoms/Ad.tsx
Normal file
29
src/components/atoms/Ad.tsx
Normal file
@ -0,0 +1,29 @@
|
||||
import React from 'react'
|
||||
import styles from './Ad.module.scss'
|
||||
import { useSiteMetadata } from '../../hooks/use-site-metadata'
|
||||
|
||||
interface WindowWithMatomo extends Window {
|
||||
_paq?: any
|
||||
}
|
||||
|
||||
export default function Ad() {
|
||||
const { ad } = useSiteMetadata()
|
||||
|
||||
function handleClick(e: React.MouseEvent) {
|
||||
e.preventDefault()
|
||||
const { _paq } = window as WindowWithMatomo
|
||||
_paq && _paq.push(['trackEvent', 'Ad Interaction', 'click'])
|
||||
|
||||
window.open(ad.link)
|
||||
}
|
||||
|
||||
return (
|
||||
<a
|
||||
className={styles.ad}
|
||||
href={ad.link}
|
||||
onClick={(e: React.MouseEvent) => handleClick(e)}
|
||||
>
|
||||
{ad.title}
|
||||
</a>
|
||||
)
|
||||
}
|
@ -1,6 +1,6 @@
|
||||
@import 'variables';
|
||||
|
||||
.pageTitle {
|
||||
composes: archivetitle from '../templates/Posts.module.scss';
|
||||
composes: archivetitle from './Posts.module.scss';
|
||||
margin-bottom: $spacer * 2;
|
||||
}
|
@ -1,7 +1,7 @@
|
||||
import React from 'react'
|
||||
import { Helmet } from 'react-helmet'
|
||||
import { Post } from '../@types/Post'
|
||||
import SEO from '../components/atoms/SEO'
|
||||
import { Post } from '../../@types/Post'
|
||||
import SEO from '../atoms/SEO'
|
||||
import styles from './Page.module.scss'
|
||||
|
||||
export default function Page({
|
@ -4,7 +4,8 @@
|
||||
.actions {
|
||||
@include breakoutviewport;
|
||||
|
||||
margin-top: $spacer * 3;
|
||||
margin-top: $spacer * 2;
|
||||
margin-bottom: $spacer * 2;
|
||||
background: rgba(#fff, 0.5);
|
||||
padding-top: $spacer;
|
||||
padding-bottom: $spacer;
|
@ -1,10 +1,10 @@
|
||||
import React from 'react'
|
||||
import { render } from '@testing-library/react'
|
||||
|
||||
import Post from './Post'
|
||||
import post from '../../jest/__fixtures__/post.json'
|
||||
import postWithMore from '../../jest/__fixtures__/postWithMore.json'
|
||||
import link from '../../jest/__fixtures__/link.json'
|
||||
import Post from '.'
|
||||
import post from '../../../../jest/__fixtures__/post.json'
|
||||
import postWithMore from '../../../../jest/__fixtures__/postWithMore.json'
|
||||
import link from '../../../../jest/__fixtures__/link.json'
|
||||
|
||||
describe('Post', () => {
|
||||
const pageContext = {
|
@ -1,19 +1,20 @@
|
||||
import React from 'react'
|
||||
import { Helmet } from 'react-helmet'
|
||||
import { graphql } from 'gatsby'
|
||||
import { Post as PostMetadata } from '../@types/Post'
|
||||
import Exif from '../components/atoms/Exif'
|
||||
import SEO from '../components/atoms/SEO'
|
||||
import RelatedPosts from '../components/molecules/RelatedPosts'
|
||||
import PostTitle from '../components/organisms/Post/Title'
|
||||
import PostLead from '../components/organisms/Post/Lead'
|
||||
import PostContent from '../components/organisms/Post/Content'
|
||||
import PostActions from '../components/organisms/Post/Actions'
|
||||
import PostLinkActions from '../components/organisms/Post/LinkActions'
|
||||
import PostMeta from '../components/organisms/Post/Meta'
|
||||
import PrevNext from '../components/organisms/Post/PrevNext'
|
||||
import styles from './Post.module.scss'
|
||||
import { Image } from '../components/atoms/Image'
|
||||
import { Post as PostMetadata } from '../../../@types/Post'
|
||||
import Exif from '../../atoms/Exif'
|
||||
import SEO from '../../atoms/SEO'
|
||||
import RelatedPosts from '../../molecules/RelatedPosts'
|
||||
import PostTitle from './Title'
|
||||
import PostLead from './Lead'
|
||||
import PostContent from './Content'
|
||||
import PostActions from './Actions'
|
||||
import PostLinkActions from './LinkActions'
|
||||
import PostMeta from './Meta'
|
||||
import PostAd from '../../atoms/Ad'
|
||||
import PrevNext from './PrevNext'
|
||||
import styles from './index.module.scss'
|
||||
import { Image } from '../../atoms/Image'
|
||||
|
||||
export default function Post({
|
||||
data,
|
||||
@ -58,8 +59,9 @@ export default function Post({
|
||||
{type !== 'photo' && <PostContent post={post} />}
|
||||
|
||||
{type === 'link' && <PostLinkActions slug={slug} linkurl={linkurl} />}
|
||||
<PostActions slug={slug} githubLink={githubLink} />
|
||||
<PostMeta post={post} />
|
||||
<PostActions slug={slug} githubLink={githubLink} />
|
||||
<PostAd />
|
||||
</article>
|
||||
|
||||
<RelatedPosts photos={type === 'photo'} tags={tags} />
|
@ -3,7 +3,7 @@ import { render } from '@testing-library/react'
|
||||
import { createHistory, createMemorySource } from '@reach/router'
|
||||
|
||||
import Posts from './Posts'
|
||||
import data from '../../jest/__fixtures__/posts.json'
|
||||
import data from '../../../jest/__fixtures__/posts.json'
|
||||
|
||||
describe('Post', () => {
|
||||
const history = createHistory(createMemorySource('/photos'))
|
@ -1,16 +1,16 @@
|
||||
import React from 'react'
|
||||
import { Link, graphql } from 'gatsby'
|
||||
import { Post } from '../@types/Post'
|
||||
import Pagination from '../components/molecules/Pagination'
|
||||
import Featured from '../components/molecules/Featured'
|
||||
import PostTitle from '../components/organisms/Post/Title'
|
||||
import PostLead from '../components/organisms/Post/Lead'
|
||||
import PostContent from '../components/organisms/Post/Content'
|
||||
import PostMore from '../components/organisms/Post/More'
|
||||
import PostLinkActions from '../components/organisms/Post/LinkActions'
|
||||
import SEO from '../components/atoms/SEO'
|
||||
import { Post } from '../../@types/Post'
|
||||
import Pagination from '../molecules/Pagination'
|
||||
import Featured from '../molecules/Featured'
|
||||
import PostTitle from './Post/Title'
|
||||
import PostLead from './Post/Lead'
|
||||
import PostContent from './Post/Content'
|
||||
import PostMore from './Post/More'
|
||||
import PostLinkActions from './Post/LinkActions'
|
||||
import SEO from '../atoms/SEO'
|
||||
import styles from './Posts.module.scss'
|
||||
import { Image } from '../components/atoms/Image'
|
||||
import { Image } from '../atoms/Image'
|
||||
|
||||
export default function Posts({
|
||||
data,
|
@ -32,6 +32,10 @@ const query = graphql`
|
||||
classNameDark
|
||||
classNameLight
|
||||
}
|
||||
ad {
|
||||
title
|
||||
link
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -1,6 +1,6 @@
|
||||
import React from 'react'
|
||||
import { Link } from 'gatsby'
|
||||
import Page from '../templates/Page'
|
||||
import Page from '../components/templates/Page'
|
||||
import styles from './404.module.scss'
|
||||
|
||||
const page = {
|
||||
|
@ -1,6 +1,6 @@
|
||||
import React from 'react'
|
||||
import { graphql, Link } from 'gatsby'
|
||||
import Page from '../templates/Page'
|
||||
import Page from '../components/templates/Page'
|
||||
import { Post } from '../@types/Post'
|
||||
import { Image } from '../components/atoms/Image'
|
||||
import styles from './photos.module.scss'
|
||||
|
@ -1,6 +1,6 @@
|
||||
import React from 'react'
|
||||
import { graphql } from 'gatsby'
|
||||
import Page from '../templates/Page'
|
||||
import Page from '../components/templates/Page'
|
||||
import Tag from '../components/atoms/Tag'
|
||||
import styles from './tags.module.scss'
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user