Yamada UIにスターをあげる

スター
Yamada UIYamada UIv1.6.3

Rating

Ratingは、ユーザーが評価を行うために使用させるコンポーネントです。

ソース@yamada-ui/rating

インポート

import { Rating } from "@yamada-ui/react"
Copied!

使い方

編集可能な例

<Rating />
Copied!

サイズを変更する

編集可能な例

<VStack>
  <Rating size="xs" defaultValue={3} />
  <Rating size="sm" defaultValue={3} />
  <Rating size="md" defaultValue={3} />
  <Rating size="lg" defaultValue={3} />
  <Rating size="xl" defaultValue={3} />
</VStack>
Copied!

カラースキームを変更する

編集可能な例

<VStack>
  <Rating colorScheme="purple" defaultValue={3} />
  <Rating colorScheme="pink" defaultValue={3} />
</VStack>
Copied!

デフォルトの値を設定する

デフォルトの値を設定する場合は、defaultValueに数値を設定します。

編集可能な例

<Rating defaultValue={3} />
Copied!

アイテム数を変更する

アイテム数を変更する場合は、itemsに数値を設定します。

編集可能な例

<VStack>
  <Rating items={4} />
  <Rating items={5} />
  <Rating items={6} />
</VStack>
Copied!

小数点を許容する

小数点を許容する場合は、fractionsに数値を設定します。

例えば、0.25を許容したい場合は、4を設定します。

編集可能な例

<VStack>
  <Rating fractions={2} defaultValue={1.5} />
  <Rating fractions={3} defaultValue={2.33} />
  <Rating fractions={4} defaultValue={3.75} />
</VStack>
Copied!

色を変更する

色を変更する場合は、colorに文字列または関数を設定します。colorは、アイテムの数値を提供します。

編集可能な例

const getColor = (value: number) => {
  switch (value) {
    case 1:
      return "red.500"

    case 2:
      return "orange.500"

    case 3:
      return "yellow.500"

    case 4:
      return "green.500"

    case 5:
      return "blue.500"

    default:
      return undefined
  }
}

return (
  <VStack>
    <Rating color="green.500" defaultValue={3} />
    <Rating color={getColor} defaultValue={3} />
  </VStack>
)
Copied!

アイコンをカスタマイズする

アイコンをカスタマイズする場合は、emptyIconfilledIconRectNodeまたは関数を設定します。emptyIconfilledIconは、アイテムの数値を提供します。

  • emptyIcon: 選択されていないアイコンに使われます。
  • filledIcon: 選択されているアイコンに使われます。

編集可能な例

const getColor = (value: number) => {
  switch (value) {
    case 1:
      return "red.500"

    case 2:
      return "orange.500"

    case 3:
      return "yellow.500"

    case 4:
      return "green.500"

    case 5:
      return "blue.500"

    default:
      return undefined
  }
}

const getIcon = (value: number) => {
  switch (value) {
    case 1:
      return <Angry />

    case 2:
      return <Frown />

    case 3:
      return <Smile />

    case 4:
      return <Laugh />

    case 5:
      return <SmilePlus />

    default:
      return null
  }
}

return (
  <VStack>
    <Rating defaultValue={3} emptyIcon={<Ghost />} filledIcon={<Ghost />} />

    <Rating
      gap="xs"
      color={getColor}
      emptyIcon={getIcon}
      filledIcon={getIcon}
    />
  </VStack>
)
Copied!

無効化する

無効化する場合は、isDisabledtrueに設定します。

編集可能な例

<VStack>
  <Rating isDisabled defaultValue={3} />

  <FormControl isDisabled label="How satisfied are you with Yamada UI?">
    <Rating defaultValue={3} />
  </FormControl>
</VStack>
Copied!

読み取り専用にする

読み取り専用にする場合は、isReadOnlytrueに設定します。

編集可能な例

<VStack>
  <Rating isReadOnly defaultValue={3} />

  <FormControl isReadOnly label="How satisfied are you with Yamada UI?">
    <Rating defaultValue={3} />
  </FormControl>
</VStack>
Copied!

制御する

編集可能な例

const [value, onChange] = useState<number>(3)

return <Rating value={value} onChange={onChange} />
Copied!

React Hook Formを使う

編集可能な例

type Data = { rating: boolean }

const {
  control,
  handleSubmit,
  watch,
  formState: { errors },
} = useForm<Data>()

const onSubmit: SubmitHandler<Data> = (data) => console.log("submit:", data)

console.log("watch:", watch())

return (
  <VStack as="form" onSubmit={handleSubmit(onSubmit)}>
    <FormControl
      isInvalid={!!errors.rating}
      label="How satisfied are you with Yamada UI?"
      errorMessage={errors.rating ? errors.rating.message : undefined}
    >
      <Controller
        name="rating"
        control={control}
        render={({ field }) => <Rating {...field} />}
      />
    </FormControl>

    <Button type="submit" alignSelf="flex-end">
      Submit
    </Button>
  </VStack>
)
Copied!

GitHubでこのページを編集する

EditableSegmentedControl