diff --git a/.github/CODEOWNERS b/.github/CODEOWNERS index d96a5b1e..0ba764b9 100644 --- a/.github/CODEOWNERS +++ b/.github/CODEOWNERS @@ -1 +1 @@ -* @ghdtjgus76 @eugene028 @hamo-o @SeieunYoo \ No newline at end of file +* @eugene028 @hamo-o @SeieunYoo @soulchicken \ No newline at end of file diff --git a/apps/wow-docs/app/component/page.tsx b/apps/wow-docs/app/component/page.tsx index 3f9ab728..ebc4728c 100644 --- a/apps/wow-docs/app/component/page.tsx +++ b/apps/wow-docs/app/component/page.tsx @@ -1,5 +1,66 @@ +import Space from "@components/Space"; +import Title from "@components/Text/Title"; +import { componentItems } from "@constants/pageData"; +import { css } from "@styled-system/css"; +import { Grid } from "@styled-system/jsx"; +import type { Metadata } from "next"; +import Image from "next/image"; +import Link from "next/link"; + +export const metadata: Metadata = { + title: "Component", + description: "와우 디자인 시스템의 component 입니다.", +}; + const ComponentPage = () => { - return
component
; + return ( + <> + + <Space height={68} /> + <Grid gap="22px" gridTemplateColumns="repeat(3, 1fr)"> + {componentItems.map((item) => ( + <Link className={containerStyle} href={item.href} key={item.imageAlt}> + <Image + alt={item.imageAlt} + className={imageStyle} + height={200} + src={item.imageSrc} + width={314} + /> + <Title + className={titleStyle} + main={item.title} + padding="20px" + sub={item.description} + variant="component" + /> + </Link> + ))} + </Grid> + <Space height={127} /> + </> + ); }; export default ComponentPage; + +const containerStyle = css({ + display: "flex", + flexDirection: "column", +}); + +const titleStyle = css({ + borderRadius: "0 0 8px 8px", + border: "1px solid", + borderColor: "outline", + borderTop: "none", + flex: "auto", +}); + +const imageStyle = css({ + width: "100%", +}); diff --git a/apps/wow-docs/app/constants/routePath.ts b/apps/wow-docs/app/constants/routePath.ts deleted file mode 100644 index 35261338..00000000 --- a/apps/wow-docs/app/constants/routePath.ts +++ /dev/null @@ -1,5 +0,0 @@ -export const routePath = { - overview: "/overview", - foundation: "/foundation", - component: "/component", -}; diff --git a/apps/wow-docs/app/foundation/graphic/page.tsx b/apps/wow-docs/app/foundation/graphic/page.tsx new file mode 100644 index 00000000..ecb25e8c --- /dev/null +++ b/apps/wow-docs/app/foundation/graphic/page.tsx @@ -0,0 +1,97 @@ +import Card from "@components/Card"; +import Space from "@components/Space"; +import Text from "@components/Text"; +import Title from "@components/Text/Title"; +import { css } from "@styled-system/css"; +import { Flex } from "@styled-system/jsx"; +import Image from "next/image"; +import type { Metadata } from "next/types"; +import Divider from "wowds-ui/Divider"; + +export const metadata: Metadata = { + title: "Graphic", + description: "와우 디자인 시스템의 Graphic 입니다.", +}; + +const graphicExampleItems = [ + { + imageAlt: "graphic-example-1", + imageSrc: "/graphic/graphic-example-1.png", + }, + { + imageAlt: "graphic-example-2", + imageSrc: "/graphic/graphic-example-2.png", + }, + { + imageAlt: "graphic-example-3", + imageSrc: "/graphic/graphic-example-3.png", + }, + { + imageAlt: "graphic-example-4", + imageSrc: "/graphic/graphic-example-4.png", + }, +]; +const GraphicPage = () => { + return ( + <> + <Title + main="Graphic" + sub="그래픽 이미지를 통해 와우 디자인 시스템의 브랜드 아이덴티티를 일관되게 전달합니다." + variant="header" + /> + <Space height={68} /> + <Text as="h2" typo="display2WebPage"> + Theme + </Text> + <Space height={4} /> + <Text as="h2" color="sub" typo="body1"> + GDSC의 메인 색상을 활용하여 매트하고 깔끔한 조형들을 활용해요. <br /> + 언제든지 테마에 어울리는 그래픽을 제작하여 응용할 수 있어요. + </Text> + <Space height={40} /> + <Card> + <Image + alt={graphicExampleItems[0]?.imageAlt as string} + className={imageStyle} + height={572} + src={graphicExampleItems[0]?.imageSrc as string} + width={908} + /> + </Card> + <Space height={40} /> + <Divider /> + <Space height={40} /> + <Text as="h2" typo="display2WebPage"> + Example + </Text> + <Space height={40} /> + <div className={containerStyle}> + <Flex flexDirection="column" gap="40px"> + {graphicExampleItems.slice(1).map((item) => ( + <Image + alt={item.imageAlt} + className={imageStyle} + height={572} + key={item.imageAlt} + src={item.imageSrc} + width={908} + /> + ))} + </Flex> + </div> + <Space height={80} /> + </> + ); +}; + +export default GraphicPage; + +const containerStyle = css({ + backgroundColor: "backgroundAlternative", + borderRadius: "sm", + padding: "32px 40px", +}); + +const imageStyle = css({ + width: "100%", +}); diff --git a/apps/wow-docs/app/foundation/page.tsx b/apps/wow-docs/app/foundation/page.tsx index 54e295a9..eb2367ff 100644 --- a/apps/wow-docs/app/foundation/page.tsx +++ b/apps/wow-docs/app/foundation/page.tsx @@ -1,5 +1,57 @@ +import Space from "@components/Space"; +import Title from "@components/Text/Title"; +import { foundationItems } from "@constants/pageData"; +import { css } from "@styled-system/css"; +import { Flex, Grid } from "@styled-system/jsx"; +import type { Metadata } from "next"; +import Image from "next/image"; +import Link from "next/link"; + +export const metadata: Metadata = { + title: "Foundation", + description: "와우 디자인 시스템의 foundation 입니다.", +}; + const FoundationPage = () => { - return <div>f</div>; + return ( + <> + <Title + main="Foundation" + sub="파운데이션은 가장 기초적인 디자인 요소로, 일관된 디자인을 위해 다음의 규칙에 맞게 사용합니다" + variant="header" + /> + <Space height={68} /> + <Grid gap="22px" gridTemplateColumns="repeat(2, 1fr)"> + {foundationItems.map((item) => ( + <Link className={containerStyle} href={item.href} key={item.imageAlt}> + <Flex> + <Title + justifyContent="end" + main={item.title} + padding="20px" + sub={item.description} + variant="component" + /> + + <Image + alt={item.imageAlt} + height={200} + src={item.imageSrc} + width={200} + /> + </Flex> + </Link> + ))} + </Grid> + <Space height={127} /> + </> + ); }; export default FoundationPage; + +const containerStyle = css({ + borderRadius: "8px", + border: "1px solid", + borderColor: "outline", +}); diff --git a/apps/wow-docs/app/globals.css b/apps/wow-docs/app/globals.css index 70922bc7..a8fce23c 100644 --- a/apps/wow-docs/app/globals.css +++ b/apps/wow-docs/app/globals.css @@ -96,3 +96,12 @@ body { flex-direction: row; min-height: 100vh; } + +::-webkit-scrollbar { + width: 6px; + height: 6px; +} +::-webkit-scrollbar-thumb { + background-color: #c1c1c1; + border-radius: 10px; +} diff --git a/apps/wow-docs/app/layout.tsx b/apps/wow-docs/app/layout.tsx index 6c1c4964..bdb343e5 100644 --- a/apps/wow-docs/app/layout.tsx +++ b/apps/wow-docs/app/layout.tsx @@ -1,12 +1,43 @@ import "@/globals.css"; -import Sidebar from "@components/Sidebar"; +import Navbar from "@components/Navbar/Navbar"; import { styled } from "@styled-system/jsx"; import type { Metadata } from "next"; export const metadata: Metadata = { - title: "와우 디자인 시스템", + title: { default: "와우 디자인 시스템", template: "%s | 와우 디자인 시스템" }, description: "GDSC Hongik 디자인 시스템", + verification: { + google: process.env.NEXT_PUBLIC_GOOGLE_CONSOLE_KEY, + other: { + "naver-site-verification": + process.env.NEXT_PUBLIC_NAVER_CONSOLE_KEY ?? "", + }, + }, + openGraph: { + title: "와우 디자인 시스템", + description: "GDSC Hongik 디자인 시스템", + images: ["/images/og-image.png"], + siteName: "와우 디자인 시스템", + type: "website", + }, + twitter: { + card: "summary_large_image", + title: "와우 디자인 시스템", + description: "GDSC Hongik 디자인 시스템", + images: ["/images/og-image.png"], + }, + icons: { + icon: "/images/logo.svg", + apple: "/images/logo.svg", + other: [ + { + rel: "icon", + type: "image/svg+xml", + url: "/images/logo.svg", + }, + ], + }, }; const RootLayout = ({ @@ -17,9 +48,10 @@ const RootLayout = ({ return ( <html lang="en"> <body> - <Sidebar /> + <Navbar /> <styled.main height="100vh" + marginLeft="250px" padding="70px 102px 0 101px" position="relative" width="100vw" diff --git a/apps/wow-docs/app/overview/page.tsx b/apps/wow-docs/app/overview/page.tsx index 4eea568f..2e0d80f4 100644 --- a/apps/wow-docs/app/overview/page.tsx +++ b/apps/wow-docs/app/overview/page.tsx @@ -26,12 +26,12 @@ const OverviewPage = () => { 활용되는 가이드라인으로 구성함으로써 편의성과 확장성을 가지고 있어요. </Text> <Space height={60} /> - <Link className={linkTextStyle} href={routePath.foundation}> + <Link className={linkTextStyle} href={routePath.foundation.base}> Foundation <RightArrow /> </Link> <Space height={42} /> - <Link className={linkTextStyle} href={routePath.component}> + <Link className={linkTextStyle} href={routePath.component.base}> Component <RightArrow /> </Link> diff --git a/apps/wow-docs/app/robots.ts b/apps/wow-docs/app/robots.ts new file mode 100644 index 00000000..ab1e0bcd --- /dev/null +++ b/apps/wow-docs/app/robots.ts @@ -0,0 +1,13 @@ +import { PRDOUCTION_URL } from "@constants/routePath"; +import type { MetadataRoute } from "next"; + +export default function robots(): MetadataRoute.Robots { + return { + rules: { + userAgent: "*", + allow: "/", + }, + sitemap: `${PRDOUCTION_URL}/sitemap.xml`, + host: `${PRDOUCTION_URL}`, + }; +} diff --git a/apps/wow-docs/app/sitemap.ts b/apps/wow-docs/app/sitemap.ts new file mode 100644 index 00000000..2a6600c3 --- /dev/null +++ b/apps/wow-docs/app/sitemap.ts @@ -0,0 +1,27 @@ +import { PRDOUCTION_URL, routePath } from "@constants/routePath"; +import type { MetadataRoute } from "next"; + +export default function sitemap(): MetadataRoute.Sitemap { + const foundationRoutes = Object.values(routePath.foundation).map((path) => ({ + url: `${PRDOUCTION_URL}${path}`, + lastModified: new Date().toISOString().split("T")[0], + })); + + const componentRoutes = Object.values(routePath.component).map((path) => ({ + url: `${PRDOUCTION_URL}${path}`, + lastModified: new Date().toISOString().split("T")[0], + })); + + return [ + { + url: `${PRDOUCTION_URL}`, + lastModified: new Date().toISOString().split("T")[0], + }, + { + url: `${PRDOUCTION_URL}${routePath.overview}`, + lastModified: new Date().toISOString().split("T")[0], + }, + ...foundationRoutes, + ...componentRoutes, + ]; +} diff --git a/apps/wow-docs/components/Card.tsx b/apps/wow-docs/components/Card.tsx new file mode 100644 index 00000000..87c34364 --- /dev/null +++ b/apps/wow-docs/components/Card.tsx @@ -0,0 +1,15 @@ +import { css } from "@styled-system/css"; +import type { PropsWithChildren } from "react"; + +interface CardProps extends PropsWithChildren {} +const Card = ({ children }: CardProps) => { + return <div className={containerStyle}>{children}</div>; +}; + +export default Card; + +const containerStyle = css({ + backgroundColor: "backgroundAlternative", + borderRadius: "sm", + padding: "32px 40px", +}); diff --git a/apps/wow-docs/components/NavItem.tsx b/apps/wow-docs/components/Navbar/NavItem.tsx similarity index 97% rename from apps/wow-docs/components/NavItem.tsx rename to apps/wow-docs/components/Navbar/NavItem.tsx index 8e2ac0c3..d05e7d31 100644 --- a/apps/wow-docs/components/NavItem.tsx +++ b/apps/wow-docs/components/Navbar/NavItem.tsx @@ -70,7 +70,7 @@ const NavItem = ({ href, icon: Icon, alt, label, children }: NavItemProps) => { : "inactive", })} > - <Text as="div" style={{ padding: "11px 36px" }} typo="body1"> + <Text as="div" style={{ paddingLeft: "22px" }} typo="body1"> {child.label} </Text> </Link> diff --git a/apps/wow-docs/components/Sidebar.tsx b/apps/wow-docs/components/Navbar/Navbar.tsx similarity index 61% rename from apps/wow-docs/components/Sidebar.tsx rename to apps/wow-docs/components/Navbar/Navbar.tsx index e647347b..40512fd2 100644 --- a/apps/wow-docs/components/Sidebar.tsx +++ b/apps/wow-docs/components/Navbar/Navbar.tsx @@ -1,29 +1,35 @@ "use client"; -import NavItem from "@components/NavItem"; +import NavItem from "@components/Navbar/NavItem"; import Space from "@components/Space"; +import { routePath } from "@constants/routePath"; import { css } from "@styled-system/css"; import { navMenu } from "constants/navMenu"; +import Link from "next/link"; import type { CSSProperties } from "react"; import { GdscLogo } from "wowds-icons"; /** - * @description Sidebar 컴포넌트는 탭을 통해 페이지 내비게이션을 제공하는 컴포넌트입니다. + * @description Navbar 컴포넌트는 탭을 통해 페이지 네비게이션을 제공하는 컴포넌트입니다. */ -export interface SidebarProps { +export interface NavbarProps { style?: CSSProperties; } -const Sidebar = ({ style }: SidebarProps) => { +const Navbar = ({ style }: NavbarProps) => { return ( <aside aria-label="navigation bar" - className={sidebarContainerStyle} + className={navbarContainerStyle} style={style} > <Space height={54} /> - <GdscLogo /> - <div className={titleTextStyle}>Wow Design System</div> + <div className={headerStyle}> + <Link href={routePath.overview}> + <GdscLogo /> + </Link> + <div className={titleTextStyle}>Wow Design System</div> + </div> <Space height={49} /> <nav aria-label="nav menu" @@ -47,16 +53,25 @@ const Sidebar = ({ style }: SidebarProps) => { ); }; -export default Sidebar; +export default Navbar; -const sidebarContainerStyle = css({ +const navbarContainerStyle = css({ width: "250px", minWidth: "250px", height: "100%", - paddingLeft: "20px", flexShrink: 0, + position: "fixed", + borderRight: "1px solid", + borderColor: "outline", + overflowX: "scroll", }); +const headerStyle = css({ + paddingLeft: "20px", + display: "flex", + flexDirection: "column", + gap: "8px", +}); const titleTextStyle = css({ color: "textBlack", fontFamily: "Product-Sans", @@ -70,6 +85,5 @@ const navContainerStyle = css({ padding: "8px 0px", display: "flex", flexDirection: "column", - minHeight: "calc(100vh - 98px)", justifyContent: "space-between", }); diff --git a/apps/wow-docs/components/Text/Title.tsx b/apps/wow-docs/components/Text/Title.tsx index f606ac1c..4b85c06f 100644 --- a/apps/wow-docs/components/Text/Title.tsx +++ b/apps/wow-docs/components/Text/Title.tsx @@ -1,16 +1,23 @@ import Text from "@components/Text"; +import type { FlexProps } from "@styled-system/jsx"; import { Flex } from "@styled-system/jsx"; +import type { ReactNode } from "react"; -interface TitleProps { +interface TitleProps extends FlexProps { variant: "header" | "component"; main: string; - sub: string; + sub: ReactNode; } -const Title = ({ variant, main, sub }: TitleProps) => { +const Title = ({ variant, main, sub, ...rest }: TitleProps) => { const isHeader = variant === "header"; return ( - <Flex display="flex" flexDirection="column" gap={isHeader ? "sm" : "xxs"}> + <Flex + display="flex" + flexDirection="column" + gap={isHeader ? "sm" : "xxs"} + {...rest} + > <Text as={isHeader ? "h1" : "h3"} typo={isHeader ? "displayWebPage" : "headingWebPage"} diff --git a/apps/wow-docs/constants/navMenu.ts b/apps/wow-docs/constants/navMenu.ts index fb45c5e1..56757e78 100644 --- a/apps/wow-docs/constants/navMenu.ts +++ b/apps/wow-docs/constants/navMenu.ts @@ -1,53 +1,56 @@ import { Folder, Home } from "wowds-icons"; + +import { componentPaths, foundationPaths, routePath } from "./routePath"; // routePath를 가져온다고 가정 + export const navMenu = [ { - href: "/overview", + href: routePath.overview, icon: Home, alt: "home icon", label: "Overview", }, { - href: "/foundation", + href: routePath.foundation.base, icon: Folder, alt: "folder icon", label: "Foundation", children: [ - { href: "/color", label: "Color" }, - { href: "/typography", label: "Typography" }, - { href: "/grid", label: "Grid" }, - { href: "/spacing", label: "Spacing" }, - { href: "/icon", label: "Icon" }, - { href: "/graphic", label: "Graphic" }, + { href: `/${foundationPaths.color}`, label: "Color" }, + { href: `/${foundationPaths.typography}`, label: "Typography" }, + { href: `/${foundationPaths.grid}`, label: "Grid" }, + { href: `/${foundationPaths.spacing}`, label: "Spacing" }, + { href: `/${foundationPaths.icon}`, label: "Icon" }, + { href: `/${foundationPaths.graphic}`, label: "Graphic" }, ], }, { - href: "/component", + href: routePath.component.base, icon: Folder, alt: "folder icon", label: "Component", children: [ - { label: "Avatar", href: "/avatar" }, - { label: "Box", href: "/box" }, - { label: "Button", href: "/button" }, - { label: "Checkbox", href: "/checkbox" }, - { label: "Chip", href: "/chip" }, - { label: "Divider", href: "/divider" }, - { label: "DropDown", href: "/dropdown" }, - { label: "Header", href: "/header" }, - { label: "MultiGroup", href: "/multigroup" }, - { label: "Pagination", href: "/pagination" }, - { label: "Picker", href: "/picker" }, - { label: "RadioGroup", href: "/radiogroup" }, - { label: "SearchBar", href: "/searchbar" }, - { label: "Spinner", href: "/spinner" }, - { label: "Stepper", href: "/stepper" }, - { label: "Switch", href: "/switch" }, - { label: "Table", href: "/table" }, - { label: "Tabs", href: "/tabs" }, - { label: "Tag", href: "/tag" }, - { label: "TextButton", href: "/textbutton" }, - { label: "TextField", href: "/textfield" }, - { label: "Toast", href: "/toast" }, + { label: "ActionSheet", href: `/${componentPaths.actionsheet}` }, + { label: "Avatar", href: `/${componentPaths.avatar}` }, + { label: "Box", href: `/${componentPaths.box}` }, + { label: "Button", href: `/${componentPaths.button}` }, + { label: "Checkbox", href: `/${componentPaths.checkbox}` }, + { label: "Chip", href: `/${componentPaths.chip}` }, + { label: "Divider", href: `/${componentPaths.divider}` }, + { label: "DropDown", href: `/${componentPaths.dropdown}` }, + { label: "Header", href: `/${componentPaths.header}` }, + { label: "Pagination", href: `/${componentPaths.pagination}` }, + { label: "Picker", href: `/${componentPaths.picker}` }, + { label: "RadioButton", href: `/${componentPaths.radiobutton}` }, + { label: "SearchBar", href: `/${componentPaths.searchBar}` }, + { label: "Spinner", href: `/${componentPaths.spinner}` }, + { label: "Stepper", href: `/${componentPaths.stepper}` }, + { label: "Switch", href: `/${componentPaths.switch}` }, + { label: "Table", href: `/${componentPaths.table}` }, + { label: "Tabs", href: `/${componentPaths.tabs}` }, + { label: "Tag", href: `/${componentPaths.tag}` }, + { label: "TextButton", href: `/${componentPaths.textButton}` }, + { label: "TextField", href: `/${componentPaths.textField}` }, + { label: "Toast", href: `/${componentPaths.toast}` }, ], }, ]; diff --git a/apps/wow-docs/constants/pageData.ts b/apps/wow-docs/constants/pageData.ts new file mode 100644 index 00000000..5762aeba --- /dev/null +++ b/apps/wow-docs/constants/pageData.ts @@ -0,0 +1,198 @@ +import { routePath } from "@constants/routePath"; + +export const foundationItems = [ + { + title: "Color", + description: + "컬러는 사용자가 브랜드 아이덴티티와 기능을 인지하는 것을 돕는 시각적 요소입니다.", + imageAlt: "foundation-color", + imageSrc: "/foundation/foundation-color.png", + href: routePath.foundation.color, + }, + { + title: "Typography", + description: + "타이포그래피는 가독성과 명료성에 영향을 주며, 화면 내 요소들 간 위계를 만듭니다.", + imageAlt: "foundation-typography", + imageSrc: "/foundation/foundation-typography.png", + href: routePath.foundation.typography, + }, + { + title: "Grid", + description: + "그리드는 페이지의 일관성과 시각적 질서를 유지하기 위해 사용합니다.", + imageAlt: "foundation-grid", + imageSrc: "/foundation/foundation-grid.png", + href: routePath.foundation.grid, + }, + { + title: "Icon", + description: + "아이콘은 간결한 표현을 통해 쉽고 빠르게 정보를 전달하는 것을 목표로 합니다.", + imageAlt: "foundation-icon", + imageSrc: "/foundation/foundation-icon.png", + href: routePath.foundation.icon, + }, + { + title: "Spacing", + description: + "스페이싱은 일관된 간격으로 요소를 배치해 일관된 UI를 만드는 것을 목표로 합니다.", + imageAlt: "foundation-spacing", + imageSrc: "/foundation/foundation-spacing.png", + href: routePath.foundation.spacing, + }, + { + title: "Graphic", + description: + "그래픽 이미지를 통해 와우 디자인 시스템의 브랜드 아이덴티티를 일관되게 전달합니다.", + imageAlt: "foundation-graphic", + imageSrc: "/foundation/foundation-graphic.png", + href: routePath.foundation.graphic, + }, +]; + +export const componentItems = [ + { + title: "Action Sheet", + description: + "사용자가 수행할 작업에 대한 정보와, 관련 기능을 선택할 수 있는 선택지를 제공하는 컴포넌트입니다.", + imageAlt: "action-sheet", + imageSrc: "/component/actionsheet.png", + href: routePath.component.actionsheet, + }, + { + title: "Avatar", + description: "유저의 프로필 사진을 표현하는 컴포넌트입니다.", + imageAlt: "avatar", + imageSrc: "/component/avatar.png", + href: routePath.component.avatar, + }, + { + title: "Box", + description: "내부 요소로 연관성 있는 정보들을 담는 컴포넌트입니다.", + imageAlt: "box", + imageSrc: "/component/box.png", + href: routePath.component.box, + }, + { + title: "Button", + description: "사용자가 설정한 동작을 수행하기 위해 누르는 컴포넌트입니다.", + imageAlt: "button", + imageSrc: "/component/button.png", + href: routePath.component.button, + }, + { + title: "Checkbox", + description: + "사용자가 선택할 수 있는 여러 개의 항목 중 한 개 이상의 값을 선택할 때 사용하는 컴포넌트입니다.", + imageAlt: "checkbox", + imageSrc: "/component/checkbox.png", + href: routePath.component.checkbox, + }, + { + title: "Chip", + description: + "사용자가 정보를 선택할 때 또는 필터링할 때 사용하는 컴포넌트입니다.", + imageAlt: "chip", + imageSrc: "/component/chip.png", + href: routePath.component.chip, + }, + { + title: "Divider", + description: "UI 요소 간의 구간을 나누는 컴포넌트입니다.", + imageAlt: "divider", + imageSrc: "/component/divider.png", + href: routePath.component.divider, + }, + { + title: "Dropdown", + description: + "사용자가 선택할 수 있는 여러 항목 목록을 제공하는 컴포넌트입니다.", + imageAlt: "dropdown", + imageSrc: "/component/dropdown.png", + href: routePath.component.dropdown, + }, + { + title: "Header", + description: "화면의 최상단 영역에 대한 컴포넌트입니다.", + imageAlt: "header", + imageSrc: "/component/header.png", + href: routePath.component.header, + }, + { + title: "Radio Button", + description: + "사용자가 선택할 수 있는 항목 중 하나만 선택할 수 있는 컴포넌트입니다.", + imageAlt: "radio-button", + imageSrc: "/component/radiobutton.png", + href: routePath.component.radiobutton, + }, + { + title: "Search Bar", + description: + "원하는 정보를 검색할 때, 키워드를 입력할 때 사용하는 컴포넌트입니다.", + imageAlt: "search-bar", + imageSrc: "/component/searchbar.png", + href: routePath.component.searchBar, + }, + { + title: "Switch", + description: "사용자가 선택 옵션을 켜고 끌 수 있는 컴포넌트입니다.", + imageAlt: "switch", + imageSrc: "/component/switch.png", + href: routePath.component.switch, + }, + { + title: "Tabs", + description: "버튼을 눌러 섹션을 전환할 수 있는 컴포넌트입니다.", + imageAlt: "tabs", + imageSrc: "/component/tabbar.png", + href: routePath.component.tabs, + }, + { + title: "Table", + description: + "데이터를 표 형식으로 표현하고 싶을 때 사용하는 컴포넌트입니다.", + imageAlt: "table", + imageSrc: "/component/table.png", + href: routePath.component.table, + }, + { + title: "Tag", + description: "콘텐츠를 분류할 때 사용하는 컴포넌트입니다.", + imageAlt: "tag", + imageSrc: "/component/tag.png", + href: routePath.component.tag, + }, + { + title: "Toast", + description: + "사용자가 요청한 작업의 결과에 대해 빠르게 피드백을 주는 컴포넌트입니다.", + imageAlt: "toast", + imageSrc: "/component/toast.png", + href: routePath.component.toast, + }, + { + title: "Pagination", + description: + "많은 콘텐츠를 여러 화면에 나누고 번호를 매겨 여러 페이지로 이동 가능하게 하는 컴포넌트입니다.", + imageAlt: "pagination", + imageSrc: "/component/pagination.png", + href: routePath.component.pagination, + }, + { + title: "Picker", + description: "사용자가 시간 날짜를 선택할 때 사용하는 컴포넌트입니다.", + imageAlt: "pagination", + imageSrc: "/component/picker.png", + href: routePath.component.picker, + }, + { + title: "Stepper", + description: + "사용자에게 작업이 어느 정도 진행되었는지 보여줄 때 사용하는 컴포넌트입니다.", + imageAlt: "stepper", + imageSrc: "/component/stepper.png", + href: routePath.component.stepper, + }, +]; diff --git a/apps/wow-docs/constants/routePath.ts b/apps/wow-docs/constants/routePath.ts index 35261338..cb009c4d 100644 --- a/apps/wow-docs/constants/routePath.ts +++ b/apps/wow-docs/constants/routePath.ts @@ -1,5 +1,99 @@ -export const routePath = { - overview: "/overview", - foundation: "/foundation", +export const PRDOUCTION_URL = "https://wow-design-system-wow-docs.vercel.app"; + +export const basePaths = { component: "/component", + foundation: "/foundation", +}; + +export const foundationPaths = { + color: "color", + typography: "typography", + grid: "grid", + spacing: "spacing", + icon: "icon", + graphic: "graphic", +}; + +export const componentPaths = { + actionsheet: "actionsheet", + avatar: "avatar", + box: "box", + button: "button", + checkbox: "checkbox", + chip: "chip", + divider: "divider", + dropdown: "dropdown", + header: "header", + pagination: "pagination", + picker: "picker", + radiobutton: "radiobutton", + searchBar: "searchbar", + spinner: "spinner", + stepper: "stepper", + switch: "switch", + table: "table", + tabs: "tabs", + tag: "tag", + textButton: "textbutton", + textField: "textfield", + toast: "toast", +}; +type RoutePath = { + overview: string; + foundation: { + base: string; + color: string; + typography: string; + grid: string; + spacing: string; + icon: string; + graphic: string; + }; + component: { + base: string; + actionsheet: string; + avatar: string; + box: string; + button: string; + checkbox: string; + chip: string; + divider: string; + dropdown: string; + header: string; + pagination: string; + picker: string; + radiobutton: string; + searchBar: string; + spinner: string; + stepper: string; + switch: string; + table: string; + tabs: string; + tag: string; + textButton: string; + textField: string; + toast: string; + }; +}; + +export const routePath: RoutePath = { + overview: "/overview", + foundation: { + base: basePaths.foundation, + ...(Object.fromEntries( + Object.entries(foundationPaths).map(([key, value]) => [ + key, + `${basePaths.foundation}/${value}`, + ]) + ) as Record<keyof typeof foundationPaths, string>), + }, + component: { + base: basePaths.component, + ...(Object.fromEntries( + Object.entries(componentPaths).map(([key, value]) => [ + key, + `${basePaths.component}/${value}`, + ]) + ) as Record<keyof typeof componentPaths, string>), + }, }; diff --git a/apps/wow-docs/public/component/actionsheet.png b/apps/wow-docs/public/component/actionsheet.png new file mode 100644 index 00000000..575931e7 Binary files /dev/null and b/apps/wow-docs/public/component/actionsheet.png differ diff --git a/apps/wow-docs/public/component/avatar.png b/apps/wow-docs/public/component/avatar.png new file mode 100644 index 00000000..c4987348 Binary files /dev/null and b/apps/wow-docs/public/component/avatar.png differ diff --git a/apps/wow-docs/public/component/box.png b/apps/wow-docs/public/component/box.png new file mode 100644 index 00000000..2a4a2875 Binary files /dev/null and b/apps/wow-docs/public/component/box.png differ diff --git a/apps/wow-docs/public/component/button.png b/apps/wow-docs/public/component/button.png new file mode 100644 index 00000000..90c3c001 Binary files /dev/null and b/apps/wow-docs/public/component/button.png differ diff --git a/apps/wow-docs/public/component/checkbox.png b/apps/wow-docs/public/component/checkbox.png new file mode 100644 index 00000000..920ec06f Binary files /dev/null and b/apps/wow-docs/public/component/checkbox.png differ diff --git a/apps/wow-docs/public/component/chip.png b/apps/wow-docs/public/component/chip.png new file mode 100644 index 00000000..0e719880 Binary files /dev/null and b/apps/wow-docs/public/component/chip.png differ diff --git a/apps/wow-docs/public/component/divider.png b/apps/wow-docs/public/component/divider.png new file mode 100644 index 00000000..2a731186 Binary files /dev/null and b/apps/wow-docs/public/component/divider.png differ diff --git a/apps/wow-docs/public/component/dropdown.png b/apps/wow-docs/public/component/dropdown.png new file mode 100644 index 00000000..bcd55cc2 Binary files /dev/null and b/apps/wow-docs/public/component/dropdown.png differ diff --git a/apps/wow-docs/public/component/header.png b/apps/wow-docs/public/component/header.png new file mode 100644 index 00000000..ffb34a7d Binary files /dev/null and b/apps/wow-docs/public/component/header.png differ diff --git a/apps/wow-docs/public/component/pagination.png b/apps/wow-docs/public/component/pagination.png new file mode 100644 index 00000000..03534a0f Binary files /dev/null and b/apps/wow-docs/public/component/pagination.png differ diff --git a/apps/wow-docs/public/component/picker.png b/apps/wow-docs/public/component/picker.png new file mode 100644 index 00000000..c32018c1 Binary files /dev/null and b/apps/wow-docs/public/component/picker.png differ diff --git a/apps/wow-docs/public/component/radiobutton.png b/apps/wow-docs/public/component/radiobutton.png new file mode 100644 index 00000000..a79c9d04 Binary files /dev/null and b/apps/wow-docs/public/component/radiobutton.png differ diff --git a/apps/wow-docs/public/component/searchbar.png b/apps/wow-docs/public/component/searchbar.png new file mode 100644 index 00000000..d902b439 Binary files /dev/null and b/apps/wow-docs/public/component/searchbar.png differ diff --git a/apps/wow-docs/public/component/stepper.png b/apps/wow-docs/public/component/stepper.png new file mode 100644 index 00000000..b14025b8 Binary files /dev/null and b/apps/wow-docs/public/component/stepper.png differ diff --git a/apps/wow-docs/public/component/switch.png b/apps/wow-docs/public/component/switch.png new file mode 100644 index 00000000..07371f04 Binary files /dev/null and b/apps/wow-docs/public/component/switch.png differ diff --git a/apps/wow-docs/public/component/tabbar.png b/apps/wow-docs/public/component/tabbar.png new file mode 100644 index 00000000..cff23157 Binary files /dev/null and b/apps/wow-docs/public/component/tabbar.png differ diff --git a/apps/wow-docs/public/component/table.png b/apps/wow-docs/public/component/table.png new file mode 100644 index 00000000..f3ff0cc2 Binary files /dev/null and b/apps/wow-docs/public/component/table.png differ diff --git a/apps/wow-docs/public/component/tag.png b/apps/wow-docs/public/component/tag.png new file mode 100644 index 00000000..bbb8b77d Binary files /dev/null and b/apps/wow-docs/public/component/tag.png differ diff --git a/apps/wow-docs/public/component/toast.png b/apps/wow-docs/public/component/toast.png new file mode 100644 index 00000000..89132d34 Binary files /dev/null and b/apps/wow-docs/public/component/toast.png differ diff --git a/apps/wow-docs/public/foundation/foundation-color.png b/apps/wow-docs/public/foundation/foundation-color.png new file mode 100644 index 00000000..32aeb635 Binary files /dev/null and b/apps/wow-docs/public/foundation/foundation-color.png differ diff --git a/apps/wow-docs/public/foundation/foundation-graphic.png b/apps/wow-docs/public/foundation/foundation-graphic.png new file mode 100644 index 00000000..77a7e34f Binary files /dev/null and b/apps/wow-docs/public/foundation/foundation-graphic.png differ diff --git a/apps/wow-docs/public/foundation/foundation-grid.png b/apps/wow-docs/public/foundation/foundation-grid.png new file mode 100644 index 00000000..9eddeca4 Binary files /dev/null and b/apps/wow-docs/public/foundation/foundation-grid.png differ diff --git a/apps/wow-docs/public/foundation/foundation-icon.png b/apps/wow-docs/public/foundation/foundation-icon.png new file mode 100644 index 00000000..bce15e86 Binary files /dev/null and b/apps/wow-docs/public/foundation/foundation-icon.png differ diff --git a/apps/wow-docs/public/foundation/foundation-spacing.png b/apps/wow-docs/public/foundation/foundation-spacing.png new file mode 100644 index 00000000..2f1d2e4d Binary files /dev/null and b/apps/wow-docs/public/foundation/foundation-spacing.png differ diff --git a/apps/wow-docs/public/foundation/foundation-typography.png b/apps/wow-docs/public/foundation/foundation-typography.png new file mode 100644 index 00000000..89af2e25 Binary files /dev/null and b/apps/wow-docs/public/foundation/foundation-typography.png differ diff --git a/apps/wow-docs/public/graphic/graphic-example-1.png b/apps/wow-docs/public/graphic/graphic-example-1.png new file mode 100644 index 00000000..328d385f Binary files /dev/null and b/apps/wow-docs/public/graphic/graphic-example-1.png differ diff --git a/apps/wow-docs/public/graphic/graphic-example-2.png b/apps/wow-docs/public/graphic/graphic-example-2.png new file mode 100644 index 00000000..2ee2a23b Binary files /dev/null and b/apps/wow-docs/public/graphic/graphic-example-2.png differ diff --git a/apps/wow-docs/public/graphic/graphic-example-3.png b/apps/wow-docs/public/graphic/graphic-example-3.png new file mode 100644 index 00000000..84a3a4d3 Binary files /dev/null and b/apps/wow-docs/public/graphic/graphic-example-3.png differ diff --git a/apps/wow-docs/public/graphic/graphic-example-4.png b/apps/wow-docs/public/graphic/graphic-example-4.png new file mode 100644 index 00000000..8b6b607c Binary files /dev/null and b/apps/wow-docs/public/graphic/graphic-example-4.png differ diff --git a/apps/wow-docs/public/images/logo.svg b/apps/wow-docs/public/images/logo.svg new file mode 100644 index 00000000..ec01e061 --- /dev/null +++ b/apps/wow-docs/public/images/logo.svg @@ -0,0 +1,9 @@ +<svg width="42" height="21" viewBox="0 0 42 21" fill="none" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"> +<rect width="42" height="20.5333" fill="url(#pattern0_657_9715)"/> +<defs> +<pattern id="pattern0_657_9715" patternContentUnits="objectBoundingBox" width="1" height="1"> +<use xlink:href="#image0_657_9715" transform="matrix(0.0010101 0 0 0.00206612 -0.00505054 0)"/> +</pattern> +<image id="image0_657_9715" width="1000" height="484" xlink:href=""/> +</defs> +</svg> diff --git a/apps/wow-docs/public/images/og-image.png b/apps/wow-docs/public/images/og-image.png new file mode 100644 index 00000000..fc096020 Binary files /dev/null and b/apps/wow-docs/public/images/og-image.png differ diff --git a/packages/wow-tokens/src/typography.ts b/packages/wow-tokens/src/typography.ts index b55d509e..c435ac69 100644 --- a/packages/wow-tokens/src/typography.ts +++ b/packages/wow-tokens/src/typography.ts @@ -151,12 +151,12 @@ export const headingWebPage = { fontFamily: "Product-Sans", fontSize: "1.5rem", lineHeight: "160%", - fontWeight: 400, + fontWeight: 700, }; export const heading2WebPage = { fontFamily: "Product-Sans", fontSize: "1.25rem", lineHeight: "160%", - fontWeight: 400, + fontWeight: 700, };