Browse Source

feat: use fathom, meta improvements

fix/enable-imgix
Thomas Osmonson 5 years ago
committed by Thomas Osmonson
parent
commit
9d5f7c0a80
  1. 18
      .github/workflows/main.yml
  2. 3
      next.config.js
  3. BIN
      public/images/og_image.png
  4. 7
      src/common/hooks/use-fathom.ts
  5. 2
      src/common/utils/index.ts
  6. 8
      src/components/app-wrapper.tsx
  7. 19
      src/components/mdx/markdown-wrapper.tsx
  8. 2
      src/components/mdx/md-contents.tsx
  9. 29
      src/components/meta-head.tsx
  10. 10
      src/components/page-top.tsx

18
.github/workflows/main.yml

@ -7,31 +7,13 @@ jobs:
steps: steps:
- name: Checkout - name: Checkout
uses: actions/checkout@v2 uses: actions/checkout@v2
- name: Set Node Version - name: Set Node Version
uses: actions/setup-node@v1.4.2 uses: actions/setup-node@v1.4.2
with: with:
node-version: 14 node-version: 14
- name: Get yarn cache directory path
id: yarn-cache-dir-path
run: echo "::set-output name=dir::$(yarn cache dir)"
- name: Check Cache
uses: actions/cache@v2
id: yarn-cache
with:
path: ${{ steps.yarn-cache-dir-path.outputs.dir }}
key: ${{ runner.os }}-yarn-${{ hashFiles('**/yarn.lock') }}
restore-keys: |
${{ runner.os }}-yarn-
- name: Install deps - name: Install deps
run: yarn --frozen-lockfile run: yarn --frozen-lockfile
if: steps.yarn-cache.outputs.cache-hit != 'true'
- name: Lint - name: Lint
run: yarn lint run: yarn lint
- name: Typecheck - name: Typecheck
run: yarn typecheck run: yarn typecheck

3
next.config.js

@ -321,6 +321,9 @@ module.exports = withFonts(
jsconfigPaths: true, jsconfigPaths: true,
trailingSlash: true, trailingSlash: true,
}, },
env: {
FATHOM_ID: 'EPNTIXUM',
},
redirects, redirects,
pageExtensions: ['js', 'ts', 'tsx', 'md', 'mdx'], pageExtensions: ['js', 'ts', 'tsx', 'md', 'mdx'],
webpack: (config, options) => { webpack: (config, options) => {

BIN
public/images/og_image.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.2 KiB

7
src/common/hooks/use-fathom.ts

@ -2,23 +2,20 @@ import { useEffect } from 'react';
import { useRouter } from 'next/router'; import { useRouter } from 'next/router';
import * as Fathom from 'fathom-client'; import * as Fathom from 'fathom-client';
// eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types
export const useFathom = () => { export const useFathom = () => {
const router = useRouter(); const router = useRouter();
useEffect(() => { useEffect(() => {
// Initialize Fathom when the app loads
Fathom.load(process.env.FATHOM_ID, { Fathom.load(process.env.FATHOM_ID, {
includedDomains: ['blockstack.design'], excludedDomains: ['localhost'],
}); });
function onRouteChangeComplete() { function onRouteChangeComplete() {
Fathom.trackPageview(); Fathom.trackPageview();
} }
// Record a page view when route changes
router.events.on('routeChangeComplete', onRouteChangeComplete); router.events.on('routeChangeComplete', onRouteChangeComplete);
// Un assign event listener
return () => { return () => {
router.events.off('routeChangeComplete', onRouteChangeComplete); router.events.off('routeChangeComplete', onRouteChangeComplete);
}; };

2
src/common/utils/index.ts

@ -18,6 +18,8 @@ export const slugify = (string: string): string =>
.replace(/^-+/, '') // Trim - from start of text .replace(/^-+/, '') // Trim - from start of text
.replace(/-+$/, ''); // Trim - from end of text .replace(/-+$/, ''); // Trim - from end of text
export const capitalize = ([s, ...tring]: string): string => [s.toUpperCase(), ...tring].join('');
export const border = ( export const border = (
width = 1, width = 1,
style: Property.BorderStyle = 'solid', style: Property.BorderStyle = 'solid',

8
src/components/app-wrapper.tsx

@ -7,8 +7,11 @@ import { ProgressBar } from '@components/progress-bar';
import { BaseLayout } from '@components/layouts/base-layout'; import { BaseLayout } from '@components/layouts/base-layout';
import { ColorModes } from '@components/color-modes/styles'; import { ColorModes } from '@components/color-modes/styles';
import { Meta } from '@components/meta-head'; import { Meta } from '@components/meta-head';
import { useFathom } from '@common/hooks/use-fathom';
export const AppWrapper: React.FC<any> = ({ children, isHome }) => ( export const AppWrapper: React.FC<any> = ({ children, isHome }) => {
useFathom();
return (
<> <>
<Meta /> <Meta />
<MdxOverrides /> <MdxOverrides />
@ -20,4 +23,5 @@ export const AppWrapper: React.FC<any> = ({ children, isHome }) => (
</AppStateProvider> </AppStateProvider>
</MDXProvider> </MDXProvider>
</> </>
); );
};

19
src/components/mdx/markdown-wrapper.tsx

@ -1,8 +1,9 @@
import React from 'react'; import React from 'react';
import { MDContents } from '@components/mdx/md-contents'; import { MDContents } from '@components/mdx/md-contents';
import Head from 'next/head'; import Head from 'next/head';
import { getTitle } from '@common/utils'; import { capitalize, getTitle } from '@common/utils';
import { PageTop } from '@components/page-top'; import { PageTop } from '@components/page-top';
import { MetaLabels } from '@components/meta-head';
const defaultFrontmatter = { const defaultFrontmatter = {
headings: [], headings: [],
@ -14,12 +15,28 @@ export const MDWrapper: React.FC<any> = React.memo(
({ frontmatter = defaultFrontmatter, dynamicHeadings = [], ...props }) => { ({ frontmatter = defaultFrontmatter, dynamicHeadings = [], ...props }) => {
const { headings, description } = frontmatter; const { headings, description } = frontmatter;
const labels = [
frontmatter.experience
? {
label: 'Experience',
data: capitalize(frontmatter.experience),
}
: undefined,
frontmatter.duration
? {
label: 'Duration',
data: frontmatter.duration,
}
: undefined,
].filter(item => item);
return ( return (
<> <>
<Head> <Head>
<title>{getTitle(frontmatter)} | Blockstack</title> <title>{getTitle(frontmatter)} | Blockstack</title>
<meta name="description" content={description} /> <meta name="description" content={description} />
</Head> </Head>
<MetaLabels labels={labels} />
<MDContents <MDContents
pageTop={() => <PageTop {...frontmatter} />} pageTop={() => <PageTop {...frontmatter} />}
headings={[...headings, ...dynamicHeadings]} headings={[...headings, ...dynamicHeadings]}

2
src/components/mdx/md-contents.tsx

@ -265,7 +265,7 @@ export const MDContents: React.FC<any> = ({ pageTop: PageTop = null, headings, c
display={['none', 'none', 'none', 'block']} display={['none', 'none', 'none', 'block']}
> >
<Box position="sticky" top={0} pt={space('extra-loose')}> <Box position="sticky" top={0} pt={space('extra-loose')}>
<Search mb={space('extra-loose')} /> {/*<Search mb={space('extra-loose')} />*/}
{headings?.length ? <TableOfContents limit={2} headings={headings} /> : null} {headings?.length ? <TableOfContents limit={2} headings={headings} /> : null}
</Box> </Box>
</Box> </Box>

29
src/components/meta-head.tsx

@ -3,11 +3,38 @@ import React from 'react';
import Head from 'next/head'; import Head from 'next/head';
import { useFaviconName } from '@common/hooks/use-favicon'; import { useFaviconName } from '@common/hooks/use-favicon';
export const Meta: React.FC<any> = props => { export const MetaLabels = ({ labels }: any) => {
return labels?.length ? (
<Head>
{labels.map(({ label, data }, key: number) => (
<React.Fragment key={key}>
<meta
name={`twitter:label${key + 1}`}
// @ts-ignore
content={label}
/>
<meta
name={`twitter:data${key + 1}`}
// @ts-ignore
content={data}
/>
</React.Fragment>
))}
</Head>
) : null;
};
export const Meta: React.FC<any> = () => {
const filename = useFaviconName(); const filename = useFaviconName();
return ( return (
<Head> <Head>
<link rel="icon" type="image/svg+xml" href={`/${filename}`} /> <link rel="icon" type="image/svg+xml" href={`/${filename}`} />
<meta property="og:image" content="/images/og_image.png" />
<meta property="og:type" content="website" />
<meta property="og:site_name" content="Blockstack Docs" />
<meta name="twitter:card" content="summary_large_image" />
<meta name="twitter:site" content="@blockstack" />
<meta name="twitter:creator" content="@blockstack" />
</Head> </Head>
); );
}; };

10
src/components/page-top.tsx

@ -30,11 +30,11 @@ export const PageTop: React.FC<PageTopProps> = React.memo(
headings, headings,
})} })}
</H1> </H1>
{isHome ? ( {/*{isHome ? (*/}
<Box width="100%" maxWidth="208px"> {/* <Box width="100%" maxWidth="208px">*/}
<Search /> {/* <Search />*/}
</Box> {/* </Box>*/}
) : null} {/*) : null}*/}
</Flex> </Flex>
{description ? ( {description ? (
<Box mt="40px !important"> <Box mt="40px !important">

Loading…
Cancel
Save