diff --git a/client/components/new-post/drag-and-drop/index.tsx b/client/components/new-post/drag-and-drop/index.tsx index 770d99c3..eaaab5b6 100644 --- a/client/components/new-post/drag-and-drop/index.tsx +++ b/client/components/new-post/drag-and-drop/index.tsx @@ -3,7 +3,7 @@ import { useCallback, useEffect } from 'react' import { useDropzone } from 'react-dropzone' import styles from './drag-and-drop.module.css' import { Document } from '../' -import generateUUID from '../../../lib/generate-uuid' +import generateUUID from '@lib/generate-uuid' import { XCircle } from '@geist-ui/icons' const allowedFileTypes = [ 'application/json', diff --git a/client/components/new-post/index.tsx b/client/components/new-post/index.tsx index e26b47d6..203839c9 100644 --- a/client/components/new-post/index.tsx +++ b/client/components/new-post/index.tsx @@ -1,7 +1,7 @@ import { Button, ButtonDropdown, useToasts } from '@geist-ui/core' import { useRouter } from 'next/router'; import { useCallback, useState } from 'react' -import generateUUID from '../../lib/generate-uuid'; +import generateUUID from '@lib/generate-uuid'; import Document from '../document'; import FileDropzone from './drag-and-drop'; import styles from './post.module.css' diff --git a/client/components/new-post/title/index.tsx b/client/components/new-post/title/index.tsx index da733bda..3ad765ab 100644 --- a/client/components/new-post/title/index.tsx +++ b/client/components/new-post/title/index.tsx @@ -1,6 +1,6 @@ import { Text, Input } from '@geist-ui/core' import { memo } from 'react' -import ShiftBy from '../../shift-by' +import ShiftBy from '@components/shift-by' import styles from '../post.module.css' const titlePlaceholders = [ diff --git a/client/components/post-list/list-item.tsx b/client/components/post-list/list-item.tsx index 121eda95..3e9e8d26 100644 --- a/client/components/post-list/list-item.tsx +++ b/client/components/post-list/list-item.tsx @@ -1,7 +1,7 @@ import { Card, Spacer, Grid, Divider, Link, Text, Input, Tooltip } from "@geist-ui/core" import NextLink from "next/link" import { useEffect, useMemo, useState } from "react" -import timeAgo from "../../lib/time-ago" +import timeAgo from "@lib/time-ago" import ShiftBy from "../shift-by" import VisibilityBadge from "../visibility-badge" diff --git a/client/components/preview/react-markdown-preview.tsx b/client/components/preview/react-markdown-preview.tsx index de6b5883..f1113370 100644 --- a/client/components/preview/react-markdown-preview.tsx +++ b/client/components/preview/react-markdown-preview.tsx @@ -6,7 +6,7 @@ import { PrismAsyncLight as SyntaxHighlighter } from 'react-syntax-highlighter'; import a11yEmoji from '@fec/remark-a11y-emoji'; import styles from './preview.module.css' import { vscDarkPlus as dark, vs as light } from 'react-syntax-highlighter/dist/cjs/styles/prism' -import useSharedState from "../../lib/hooks/use-shared-state"; +import useSharedState from "@lib/hooks/use-shared-state"; type Props = { content: string | undefined diff --git a/client/pages/_app.tsx b/client/pages/_app.tsx index 1adcb5a8..91888263 100644 --- a/client/pages/_app.tsx +++ b/client/pages/_app.tsx @@ -1,8 +1,8 @@ -import '../styles/globals.css' +import '@styles/globals.css' import { GeistProvider, CssBaseline, useTheme } from '@geist-ui/core' import { useEffect, useMemo, useState } from 'react' import type { AppProps as NextAppProps } from "next/app"; -import useSharedState from '../lib/hooks/use-shared-state'; +import useSharedState from '@lib/hooks/use-shared-state'; import 'react-loading-skeleton/dist/skeleton.css' import { SkeletonTheme } from 'react-loading-skeleton'; diff --git a/client/pages/index.tsx b/client/pages/index.tsx index 6ff94f4b..9d59334f 100644 --- a/client/pages/index.tsx +++ b/client/pages/index.tsx @@ -1,12 +1,12 @@ -import styles from '../styles/Home.module.css' +import styles from '@styles/Home.module.css' import { Page, Spacer, Text } from '@geist-ui/core' -import Header from '../components/header' +import Header from '@components/header' import { ThemeProps } from './_app' -import Document from '../components/document' +import Document from '@components/document' import Image from 'next/image' -import ShiftBy from '../components/shift-by' -import PageSeo from 'components/page-seo' +import ShiftBy from '@components/shift-by' +import PageSeo from '@components/page-seo' export function getStaticProps() { const introDoc = process.env.WELCOME_CONTENT diff --git a/client/pages/mine.tsx b/client/pages/mine.tsx index c258b17e..b273d548 100644 --- a/client/pages/mine.tsx +++ b/client/pages/mine.tsx @@ -1,8 +1,8 @@ -import styles from '../styles/Home.module.css' +import styles from '@styles/Home.module.css' import { Page } from '@geist-ui/core' -import Header from '../components/header' -import MyPosts from '../components/my-posts' +import Header from '@components/header' +import MyPosts from '@components/my-posts' const Home = ({ theme, changeTheme }: { theme: "light" | "dark", changeTheme: () => void }) => { return ( diff --git a/client/pages/new.tsx b/client/pages/new.tsx index 56dc4c47..9c66928b 100644 --- a/client/pages/new.tsx +++ b/client/pages/new.tsx @@ -1,11 +1,11 @@ -import styles from '../styles/Home.module.css' -import NewPost from '../components/new-post' +import styles from '@styles/Home.module.css' +import NewPost from '@components/new-post' import { Page } from '@geist-ui/core' -import useSignedIn from '../lib/hooks/use-signed-in' -import Header from '../components/header' +import useSignedIn from '@lib/hooks/use-signed-in' +import Header from '@components/header' import { ThemeProps } from './_app' import { useRouter } from 'next/router' -import PageSeo from 'components/page-seo' +import PageSeo from '@components/page-seo' const Home = ({ theme, changeTheme }: ThemeProps) => { const router = useRouter() diff --git a/client/pages/signin.tsx b/client/pages/signin.tsx index 4b4e4845..defc7d5b 100644 --- a/client/pages/signin.tsx +++ b/client/pages/signin.tsx @@ -1,7 +1,7 @@ import { Page } from "@geist-ui/core"; -import PageSeo from "components/page-seo"; -import Auth from "../components/auth"; -import Header from "../components/header"; +import PageSeo from "@components/page-seo"; +import Auth from "@components/auth"; +import Header from "@components/header"; import { ThemeProps } from "./_app"; const SignIn = ({ theme, changeTheme }: ThemeProps) => ( diff --git a/client/pages/signup.tsx b/client/pages/signup.tsx index e57c12c4..3628ef6d 100644 --- a/client/pages/signup.tsx +++ b/client/pages/signup.tsx @@ -1,7 +1,7 @@ import { Page } from "@geist-ui/core"; -import Auth from "components/auth"; -import Header from "components/header"; -import PageSeo from 'components/page-seo'; +import Auth from "@components/auth"; +import Header from "@components/header"; +import PageSeo from '@components/page-seo'; import { ThemeProps } from "./_app"; const SignUp = ({ theme, changeTheme }: ThemeProps) => ( diff --git a/client/tsconfig.json b/client/tsconfig.json index 38f94f59..759858c9 100644 --- a/client/tsconfig.json +++ b/client/tsconfig.json @@ -14,7 +14,12 @@ "isolatedModules": true, "jsx": "preserve", "incremental": true, - "baseUrl": "./" + "baseUrl": ".", + "paths": { + "@components/*": ["components/*"], + "@lib/*": ["lib/*"], + "@styles/*": ["styles/*"] + } }, "include": ["next-env.d.ts", "**/*.ts", "**/*.tsx"], "exclude": ["node_modules"]