Socket
Socket
Sign inDemoInstall

react-star-rate

Package Overview
Dependencies
46
Maintainers
1
Versions
5
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

    react-star-rate

Lightweight, customizable star ratings component for React


Version published
Weekly downloads
916
decreased by-35.27%
Maintainers
1
Install size
240 kB
Created
Weekly downloads
 

Readme

Source

React Star Rate

NPM Version minzipped size Build Status

Lightweight, customizable star ratings component for React.

Created by Raymon Zhang
React Star Rate

Features

  • 🔩 Easily Customizable
  • 🕊 Lightweight - less than 4kb including styles
  • Accessible

Table of contents

Example

You can visit the example here:
View on CodeSandbox

Installation

With yarn
yarn add react-star-rate
With NPM
npm install react-star-rate

Getting Started

You can add React Stars Rating to your project using the <StarsRating /> component.

import { useState } from 'react';

import StarsRating from 'react-star-rate';

const App = () => {
  const [value, setValue] = useState(0);
  return (
    <div>
      <StarsRating
        value={value}
        onChange={value => {
          setValue(value);
        }}
      />
    </div>
  );
};

Props

NameTypeDefaultDescription
allowClearbooleantrueAllow the value to be reset when clicked again
allowHalfbooleantrueAllow half of the star to be selected
autoFocusboolean-Automatically focus the element
classNamePrefixstring"react-star-rate"The components will have classNames with the given prefix
countnumber5Number of stars
defaultValuenumber0The default value of the stars. Should be the same as the default useState value
directionstring"ltr"The direction of the selected stars. Either "ltr" or "rtl"
disabledbooleanfalseDisable the rating element
onBlurfunction-Will be triggered on blur
onChangefunction(value) => {}Will be triggered on change of value
onFocusfunction-Will be triggered on focus
onHoverChangefunction(value) => {}Will be triggered on hover
styleobject{}Custom styles. See styling
symbolstring"★"The symbol to be displayed
tabIndexnumber0The tab index of the stars container
valuenumber-Controlled value of the component

Styling

Style Object

Each component inside the StarsRating component is keyed and ships with default styles. You can apply custom styles by accessing the key on the style prop.

Style Keys
  • style.style - The main wrapper ul element.
  • style.full - Styles for when the star is fully active.
    • style.full.star - The wrapper li element every star.
    • style.full.first - The first half star, on top.
    • style.full.second - The second full star, in the background.
  • style.half - Styles for when the star is half active.
    • style.half.star - The wrapper li element every star.
    • style.half.first - The first half star, on top.
    • style.half.second - The second full star, in the background.
  • style.zero - Styles for when the star is not active.
    • style.zero.star - The wrapper li element every star.
    • style.zero.first - The first half star, on top.
    • style.zero.second - The second full star, in the background.
  • style.hover - Styles for when the element is hovered over. You can use access of the keys listed above in the hover object.

With CSS

You can also apply custom styles using CSS Stylesheets. The classnames are determined with the classNamePrefix prop (defaults to "react-star-rate").

Classnames
  • ${classNamePrefix} - The main ul element.
  • ${classNamePrefix}--ltr | - ${classNamePrefix}--rtl - If the rating component is from left-to-right or right-to-left respectively.
  • ${classNamePrefix}__star - The star li element.
  • ${classNamePrefix}__star--zero | ${classNamePrefix}__star--half | ${classNamePrefix}__star--full - When the star is inactive, half, or completely full.
  • ${classNamePrefix}__star__first - The first half star, on top.
  • ${classNamePrefix}__star__second - The second full star, in the background.

License

MIT Licensed. Copyright (c) 2021-present, Raymon Zhang.

Keywords

FAQs

Last updated on 26 May 2021

Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc