From 2d1ff993b2c0a43226617906d09377d435105136 Mon Sep 17 00:00:00 2001 From: Travis Fischer Date: Fri, 5 Feb 2021 21:00:44 -0500 Subject: [PATCH] changes specific to transitivebullsh.it --- components/HeroHeader.tsx | 135 +++++++++++++++++++++++++++++ components/NotionPage.tsx | 70 +++++++++++---- components/PageHead.tsx | 1 + lib/types.ts | 2 + package.json | 6 ++ pages/[pageId].tsx | 2 +- pages/_app.tsx | 3 +- pages/_document.tsx | 14 ++- pages/index.tsx | 2 +- pages/robots.txt.tsx | 7 +- pages/tags/[tagName].tsx | 139 ++++++++++++++++++++++++++++++ pnpm-lock.yaml | 112 ++++++++++++++++++++++++ public/android-chrome-192x192.png | Bin 0 -> 27024 bytes public/android-chrome-512x512.png | Bin 0 -> 157472 bytes public/apple-touch-icon.png | Bin 0 -> 24101 bytes public/favicon-128x128.png | Bin 2964 -> 0 bytes public/favicon-16x16.png | Bin 0 -> 548 bytes public/favicon-192x192.png | Bin 4812 -> 0 bytes public/favicon-32x32.png | Bin 0 -> 1582 bytes public/favicon-96x96.png | Bin 0 -> 5320 bytes public/favicon.ico | Bin 15086 -> 4616 bytes public/favicon.png | Bin 608 -> 0 bytes public/manifest.json | 29 +++++-- public/page-cover.jpg | Bin 0 -> 8049 bytes public/page-icon.png | Bin 0 -> 160477 bytes site.config.ts | 45 +++++----- styles/notion.css | 80 ++++++++++++++++- 27 files changed, 593 insertions(+), 54 deletions(-) create mode 100644 components/HeroHeader.tsx create mode 100644 pages/tags/[tagName].tsx create mode 100644 public/android-chrome-192x192.png create mode 100644 public/android-chrome-512x512.png create mode 100644 public/apple-touch-icon.png delete mode 100644 public/favicon-128x128.png create mode 100644 public/favicon-16x16.png delete mode 100644 public/favicon-192x192.png create mode 100644 public/favicon-32x32.png create mode 100644 public/favicon-96x96.png delete mode 100644 public/favicon.png create mode 100644 public/page-cover.jpg create mode 100644 public/page-icon.png diff --git a/components/HeroHeader.tsx b/components/HeroHeader.tsx new file mode 100644 index 0000000000..3ee28b68e3 --- /dev/null +++ b/components/HeroHeader.tsx @@ -0,0 +1,135 @@ +import raf from 'raf' +import random from 'random' +import React, { Component } from 'react' +import FluidAnimation from 'react-fluid-animation' + +const exp = random.exponential() +const numSplatsPerEpoch = 1 +const minSplatRadius = 0.01 +const maxSplatRadius = 0.03 + +export class HeroHeader extends Component<{ + className?: string +}> { + _time: number = Date.now() + _direction: number + _tickRaf: any + _timeout: any + _animation: any + + componentDidMount() { + this._time = Date.now() + this._direction = 1 + this._reset() + this._tick() + } + + componentWillUnmount() { + if (this._tickRaf) { + raf.cancel(this._tickRaf) + this._tickRaf = null + } + + if (this._timeout) { + clearTimeout(this._timeout) + this._timeout = null + } + } + + render() { + return ( + + ) + } + + _animationRef = (ref) => { + this._animation = ref + this._reset() + } + + _reset() { + if (this._animation) { + this._animation.config.splatRadius = random.float( + minSplatRadius, + maxSplatRadius + ) + this._animation.addRandomSplats(random.int(100, 180)) + } + } + + _tick = () => { + this._tickRaf = null + this._timeout = null + + let scale = 1.0 + + if (this._animation) { + const w = this._animation.width + const h = this._animation.height + + // adjust the intensity scale depending on the canvas width, so it's less + // intense on smaller screens + const s = Math.max(0.1, Math.min(1, w / 1200)) + scale = Math.pow(s, 1.2) + + this._animation.config.splatRadius = random.float( + minSplatRadius * scale, + maxSplatRadius * scale + ) + + const splats = [] + for (let i = 0; i < numSplatsPerEpoch; ++i) { + const color = [random.float(10), random.float(10), random.float(10)] + + const w0 = w / 3.0 + const w1 = (w * 2.0) / 3.0 + + const h0 = h / 3.0 + const h1 = (h * 2.0) / 3.0 + + // eslint-disable-next-line no-constant-condition + while (true) { + const x = random.float(w) + const y = random.float(h) + + // favor uniformly distributed samples within the center-ish of the canvas + if (x > w0 && x < w1 && y > h0 && y < h1) { + continue + } + + const dx = random.float(-1, 1) * random.float(200, 3000) * scale + const dy = random.float(-1, 1) * random.float(200, 3000) * scale + const splat = { x, y, dx, dy, color } + splats.push(splat) + break + } + + // old version which generated samples along a circle + // const t = random.float(2 * Math.PI) + // const cos = Math.cos(t) + // const sin = Math.sin(t) + // const x = w / 2 + r * cos + // const y = h / 2 + r * sin + yOffset + // const k = random.float() > 0.98 ? random.float(3, 10) : 1 + // const dx = k * random.float(-1, 1) * random.float(50, 300) * cos + // const dy = k * random.float(-1, 1) * random.float(50, 300) * sin + // const splat = { x, y, dx, dy, color } + // splats.push(splat) + } + + this._animation.addSplats(splats) + } + + // using an exponential distribution here allows us to favor bursts of activity + // but also allow for more occasional pauses + const dampenedScale = Math.pow(scale, 0.2) + const timeout = (exp() * 100) / dampenedScale + + this._timeout = setTimeout(() => { + this._tickRaf = raf(this._tick) + }, timeout) + } +} diff --git a/components/NotionPage.tsx b/components/NotionPage.tsx index 47a655dd9a..57724528c3 100644 --- a/components/NotionPage.tsx +++ b/components/NotionPage.tsx @@ -4,7 +4,13 @@ import Image from 'next/legacy/image' import Link from 'next/link' import { useRouter } from 'next/router' import { type PageBlock } from 'notion-types' -import { formatDate, getBlockTitle, getPageProperty } from 'notion-utils' +import { + formatDate, + getBlockTitle, + getPageProperty, + normalizeTitle, + parsePageId +} from 'notion-utils' import * as React from 'react' import BodyClassName from 'react-body-classname' import { type NotionComponents, NotionRenderer } from 'react-notion-x' @@ -76,15 +82,6 @@ const Collection = dynamic(() => (m) => m.Collection ) ) -const Equation = dynamic(() => - import('react-notion-x/build/third-party/equation').then((m) => m.Equation) -) -const Pdf = dynamic( - () => import('react-notion-x/build/third-party/pdf').then((m) => m.Pdf), - { - ssr: false - } -) const Modal = dynamic( () => import('react-notion-x/build/third-party/modal').then((m) => { @@ -141,11 +138,35 @@ const propertyTextValue = ( return defaultFn() } +const propertySelectValue = ( + { schema, value, key, pageHeader }, + defaultFn: () => React.ReactNode +) => { + value = normalizeTitle(value) + + if (pageHeader && schema.type === 'multi_select' && value) { + return ( + + {defaultFn()} + + ) + } + + return defaultFn() +} + +const HeroHeader = dynamic<{ className?: string }>( + () => import('./HeroHeader').then((m) => m.HeroHeader), + { ssr: false } +) + export function NotionPage({ site, recordMap, error, - pageId + pageId, + tagsPage, + propertyToFilterName }: types.PageProps) { const router = useRouter() const lite = useSearchParam('lite') @@ -156,14 +177,13 @@ export function NotionPage({ nextLink: Link, Code, Collection, - Equation, - Pdf, Modal, Tweet, Header: NotionPageHeader, propertyLastEditedTimeValue, propertyTextValue, - propertyDateValue + propertyDateValue, + propertySelectValue }), [] ) @@ -188,6 +208,8 @@ export function NotionPage({ // parsePageId(block?.id) === parsePageId(site?.rootNotionPageId) const isBlogPost = block?.type === 'page' && block?.parent_table === 'collection' + const isBioPage = + parsePageId(block?.id) === parsePageId('8d0062776d0c4afca96eb1ace93a7538') const showTableOfContents = !!isBlogPost const minTableOfContentsItems = 3 @@ -201,6 +223,16 @@ export function NotionPage({ const footer = React.useMemo(() =>