18
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

ARISE analyticsAdvent Calendar 2023

Day 5

Yamada UI:多機能かつ柔軟なUIコンポーネントライブラリを触ってみた

Posted at

はじめに

みなさんは、どのReactのUIコンポーネントライブラリを使っていますか?
Material-UI(MUI)、Chakra UI、Boostrap等々、様々だと思います。

今回はYamada UIという多機能かつ柔軟性が高いUIコンポーネントライブラリを紹介します。

Yamada UIとは

公式の説明を日本語訳したものを以下に載せます。

Yamada UIは、最先端のWebアプリケーションやWebサイトの開発を効率化するReact UIコンポーネントライブラリです。他のReact UIコンポーネントライブラリでは一般的にサポートされていないカラーモードやアニメーションなどの様々な機能を取り入れ、複雑なユーザーインターフェイスを構築するために簡単に組み合わせることができる多様なコンポーネントを提供しています。

「かゆいところに手の届く多機能性」と「カスタマイズが容易であるという柔軟性」の二つを兼ね備えたライブラリであるという所感です。

Yamada UIの使い方

使い方はChakura UIなどのコンポーネントライブラリと同様です。
まずパッケージを追加します。

$ pnpm add @yamada-ui/react
# or
$ yarn add @yamada-ui/react
# or
$ npm install @yamada-ui/react

そしてUIProviderという高位コンポーネント(Higher-Order Component、HOC)を設定すれば、使えるようになります。

import { UIProvider } from "@yamada-ui/react"

const App = ({ children }) => {
  return <UIProvider>{children}</UIProvider>
}

export default App

Yamada UIの詳細

全ては紹介できないので、基本的な使い方と特に印象的だった部分をかいつまんで紹介します

テーマ

UIProviderthemeでテーマを設定できます。

import { UIProvider, extendTheme } from "@yamada-ui/react"

const customTheme = extendTheme({
  spaces: {
    xs: "1rem",
    sm: "1.25rem",
    md: "1.5rem",
    normal: "2rem",
    lg: "2.5rem",
    xl: "3rem",
  },
})()

const App = () => {
  return (
    <UIProvider theme={customTheme}>
      <YourApplication />
    </UIProvider>
    )
}

ローディング

ローディングは、スクリーンローディング(2)ページローディング(3)バックエンドローディングの3つがサポートされています。

const { screen, page, background } = useLoading()

//isLoading、start、update、finishメソッドがある。使い方:screen.start()とscreen.finish()

通知

通知はボタンと組み合わせて以下のように使います。

const notice = useNotice()


return (
  <Button
    onClick={() =>
      notice({
        title: "Notification",
        description: "This is description.",
      })
    }
  >
    Show notification
  </Button>
)

コンポーネント

variant, size, colorSchemeで以下のようにカスタマイズできます。

 2023-12-05 11.27.09.png

レスポンシブ

breakpointsが設定されているため、レスポンシブを簡単に実装できます。
ここではbgの色がレスポンシブに応じて変わります。

<Box
  bg={{ base: "primary", "2xl": "secondary", xl: "warning", lg: "danger" }}
>
  This is Box
</Box>
export const breakpoints = {
  sm: "30em", // 480px
  md: "48em", // 768px
  lg: "61em", // 976px
  xl: "80em", // 1280px
  "2xl": "90em", // 1440px
}

カラーモード

カラーモードはchangeColorModeで変更できます。
現在のカラーモードはcolorModeで確認でき、toggleColorModeで変更できます。

const { colorMode, changeColorMode, toggleColorMode } = useColorMode()

return (
    <Wrap/>
        <Button onClick={() => changeColorMode("light")}>Light Mode</Button>
        <Button onClick={toggleColorMode}>
          Switch to {colorMode === "light" ? "Dark" : "Light"} Mode
        </Button>
    </Wrap>
)

カレンダー

カレンダーは以下のように使います。

$ pnpm add @yamada-ui/calendar
import { Calendar } from "@yamada-ui/calendar"

<Calendar />

 2023-12-05 11.40.13.png

カルーセル

スライドを埋め込みたい場合は、以下のようにCarouselを使います。

<Carousel>
  <CarouselSlide as={Center} bg="primary">
    1
  </CarouselSlide>
  <CarouselSlide as={Center} bg="secondary">
    2
  </CarouselSlide>
  <CarouselSlide as={Center} bg="warning">
    3
  </CarouselSlide>
  <CarouselSlide as={Center} bg="danger">
    4
  </CarouselSlide>
</Carousel>

 2023-12-05 11.43.08.png

テーブル

テーブルはNativeTablePagingTableがあります。
以下のようなソート機能付き&ページ機能付きの表を簡単に作ることができます。

const columns = useMemo<Column<Data>[]>(
  () => [
    {
      header: "First Name",
      accessorKey: "firstName",
    },
    {
      header: "Last Name",
      accessorKey: "lastName",
    },
    {
      header: "Age",
      accessorKey: "age",
    },
    {
      header: "Email",
      accessorKey: "email",
    },
  ],
  [],
)
return <PagingTable columns={columns} data={data} />

 2023-12-05 11.46.04.png

リオーダー

順番変更可能な要素を簡単に作ることができます。

import { Reorder, ReorderItem} from "@yamada-ui/react"

<Reorder>
  <ReorderItem label="ギニュー">ギニュー</ReorderItem>
  <ReorderItem label="リクーム">リクーム</ReorderItem>
  <ReorderItem label="バータ">バータ</ReorderItem>
</Reorder>

スクロール

スクロールについてはScrollAreaを使えば簡単に実装できます。

<ScrollArea h="xs" innerProps={{ as: VStack, gap: "md" }}>
  <Text>
    セルゲームより約7年後高校生に成長した悟飯が天下一武道会に出場することを知った悟空は自らも出場するために占いババの力によって1日だけこの世に戻る天下一武道会の最中悟空たちは界王よりもさらに高位の存在である界王神から恐ろしい力を持つ魔人ブウの封印が解かれようとしていることを知らされる復活した魔人ブウにより悟飯やベジータが倒され悟空はあの世に帰ったため地球の命運は悟空の次男孫悟天と少年トランクスの幼い二人に託される
    一方魔人ブウは様々な人間との出会いからより邪悪で強力な魔人へと変貌悟天とトランクスがフュージョン融合)」して誕生した戦士ゴテンクスや潜在能力を解放しパワーアップを遂げて帰ってきた悟飯らが応戦するが戦士たちを次々と吸収し姿を変えていく魔人ブウに苦戦を強いられる危機に陥った悟飯らを救うため現世に舞い戻った悟空とベジータは界王神界で真の姿となった魔人ブウとの最終決戦に臨むドラゴンボールの協力もあり地球ナメック星あの世の人々のエネルギーによって作り上げられた超特大の元気玉によって魔人ブウは完全に消滅する
    それから10年後悟空は孫のパンと共に天下一武道会に久しぶりに出場し魔人ブウの生まれ変わりである少年ウーブと出会う悟空はウーブと共に見果てぬ強さを追い求めて修行に旅立ち物語は幕を閉じる
  </Text>
</ScrollArea>

さらにスクロールの制御も以下のように簡単に実装できます。

const ref = useRef<HTMLDivElement>(null)

const scrollToTop = () => {
  if (!ref.current) return

  ref.current.scrollTo({ top: 0, behavior: "smooth" })
}

//スクロールのトップに移動
<Button onClick={scrollToTop}>Scroll to top</Button>

おわりに

いかがだったでしょうか。まだまだ全て紹介できていないですが、便利さは伝わったと思います。

Yamada UIは参考記事は少ないというデメリットはあるものの、ドキュメントがわかりやすいので、導入しやすいと思います。個人開発で使ってみてはいかがでしょうか。

最後にGitHubのリンクのcodesandboxを添付して、記事を締めくくります。

18
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
18
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?