Skip to content

Commit

Permalink
Merge pull request #261 from MovieReviewComment/feature/issue-232/imp…
Browse files Browse the repository at this point in the history
…lement-review-write-page

[#232] Implement review write page
  • Loading branch information
2wheeh authored Mar 12, 2024
2 parents ff71df7 + 552c8d8 commit 1fa3d7a
Show file tree
Hide file tree
Showing 4 changed files with 66 additions and 6 deletions.
57 changes: 56 additions & 1 deletion ui/src/app/(board)/review/write/page.tsx
Original file line number Diff line number Diff line change
@@ -1,3 +1,58 @@
import dynamic from 'next/dynamic';
import Link from 'next/link';

import { UserSelfChip } from '@/components/auth/client/user-self-chip';
import Text from '@/components/common/server/text';
import { BoardHeader } from '@/components/common/server/board-header';
import Time from '@/components/common/server/time';
import { CreateReviewButton } from '@/components/review/client/create-review-button';
import ReviewTitle from '@/components/review/client/review-title';

import { EditorRefProvider } from '@/context/editor/editor-ref-context';
import { ReviewProvider } from '@/context/review/review-context';

const Editor = dynamic(() => import('@/editor'), {
ssr: false,
loading: () => <div className="mx-auto my-5 h-[9.4rem] w-full"></div>,
});

function EditorHeader() {
return (
<BoardHeader>
<Link href="/review" className="rounded-full border bg-white px-2 py-1">
<Text>목록으로</Text>
</Link>
<CreateReviewButton />
</BoardHeader>
);
}

export default function Page() {
return <>write review</>;
return (
<EditorRefProvider>
<ReviewProvider>
<main className="container mx-auto flex max-w-5xl flex-col items-center">
<EditorHeader />

<section className="w-full p-4">
<div className="my-2 flex items-center gap-1">
<Text size="sm" weight="bold">
by
</Text>
<UserSelfChip />
</div>

<Time dateStr={new Date().toISOString()} />

<div className="flex w-full flex-col gap-4 pt-4">
<ReviewTitle placeholder="Title" />
<ReviewTitle isMovieName placeholder="Movie" />
</div>

<Editor namespace="review-editor" isNew />
</section>
</main>
</ReviewProvider>
</EditorRefProvider>
);
}
5 changes: 4 additions & 1 deletion ui/src/app/layout.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ import { Metadata } from 'next';
import '@/styles/globals.css';
import { notoSansKr } from '@/styles/fonts';
import { AuthProvider } from '@/context/auth/auth-context';
import { ToastProvider } from '@/context/common/toast-context';

export const metadata: Metadata = {
title: 'Home',
Expand All @@ -18,7 +19,9 @@ export default function RootLayout({
return (
<html lang="en">
<body className={`${notoSansKr.className} antialiased`}>
<AuthProvider>{children}</AuthProvider>
<ToastProvider>
<AuthProvider>{children}</AuthProvider>
</ToastProvider>
</body>
</html>
);
Expand Down
2 changes: 1 addition & 1 deletion ui/src/editor/editor.stories.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ export default meta;
type Story = StoryObj<typeof meta>;

export const Default: Story = {
args: {},
args: { namespace: 'test', isNew: true },

decorators: [
(Story) => (
Expand Down
8 changes: 5 additions & 3 deletions ui/src/editor/index.tsx
Original file line number Diff line number Diff line change
@@ -1,20 +1,22 @@
'use client';

import { LexicalComposer, type InitialConfigType } from '@lexical/react/LexicalComposer';

import { Plugins } from '@/editor/plugins';
import nodes from '@/editor/nodes';
import theme from '@/editor/theme';
import '@/styles/editor.css';

// This has to be rendered on client side only (no ssr!)
export default function Editor() {
export default function Editor({ namespace, isNew }: { namespace: string; isNew: boolean }) {
const initialConfig: InitialConfigType = {
nodes: [...nodes],
namespace: 'review-editor',
namespace,
onError: (error: Error) => {
throw error;
},
theme: theme,
theme,
editable: isNew,
};

return (
Expand Down

0 comments on commit 1fa3d7a

Please sign in to comment.