-
Notifications
You must be signed in to change notification settings - Fork 64
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
>⚠️ THIS PR DEPENDS ON [PR#2635](#2635)⚠️ ## What's the purpose of this pull request? This pull request adds the RatingField component, which will initially be used in the modal for adding reviews to a product. ## How it works? This PR creates a new molecule component called `RatingField`. In addition to the "input" fields for the actionable rating, it can also receive an `id`, `label`, and `error` via props to be displayed in the form. The component uses the `Rating` component with the `actionable` view, passing the `onChange` handler to it. ## How to test it? <!--- Describe the steps with bullet points. Is there any external link that can be used to better test it or an example? ---> ### Starters Deploy Preview <!--- Add a link to a deploy preview from `starter.store` with this branch being used. ---> <!--- Tip: You can get an installable version of this branch from the CodeSandbox generated when this PR is created. ---> [Preview](https://starter-git-feat-rating-field-vtex.vercel.app//review-and-ratings-playground) ## References [JIRA TASK: SFS-2078](https://vtex-dev.atlassian.net/browse/SFS-2078) [JIRA TASK: SFS-2077](https://vtex-dev.atlassian.net/browse/SFS-2077) [Figma](https://www.figma.com/design/YXU6IX2htN2yg7udpCumZv/Reviews-%26-Ratings?node-id=131-49445&t=iOanfcOwmDa4bolf-4) data:image/s3,"s3://crabby-images/763a0/763a002222a6dd95be7311f836dbb43f36e631cb" alt="image" data:image/s3,"s3://crabby-images/41b0a/41b0ae7b8a0d7a6476742601a65270a88b98bb3d" alt="image" --------- Co-authored-by: Fanny Chien <fanny.chien@vtex.com> Co-authored-by: Fanny Chien <fannychienn@gmail.com>
- Loading branch information
1 parent
d1e33c6
commit f6ab024
Showing
6 changed files
with
125 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
71 changes: 71 additions & 0 deletions
71
packages/components/src/molecules/RatingField/RatingField.tsx
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,71 @@ | ||
import React from 'react' | ||
import type { MutableRefObject } from 'react' | ||
import { Label, Rating, type RatingProps } from '../..' | ||
|
||
interface DefaultProps { | ||
/** | ||
* ID to find this component in testing tools (e.g.: cypress, testing library, and jest). | ||
*/ | ||
testId?: string | ||
/** | ||
* ID to identify input and corresponding label. | ||
*/ | ||
id: string | ||
/** | ||
* The text displayed to identify the input rating. | ||
*/ | ||
label: string | ||
/** | ||
* The error message displayed when an error occurs. | ||
*/ | ||
error?: string | ||
/** | ||
* Component's ref. | ||
*/ | ||
ratingRef?: MutableRefObject<HTMLUListElement | null> | ||
} | ||
|
||
export type RatingFieldProps = DefaultProps & RatingProps | ||
|
||
const RatingField = ({ | ||
id, | ||
label, | ||
error, | ||
disabled, | ||
length = 5, | ||
value = 0, | ||
onChange, | ||
ratingRef, | ||
testId = 'fs-rating-field', | ||
...otherProps | ||
}: RatingFieldProps) => { | ||
const shouldDisplayError = !disabled && error && error !== '' | ||
|
||
return ( | ||
<div | ||
data-fs-rating-field | ||
data-fs-rating-field-error={shouldDisplayError} | ||
data-fs-rating-field-disabled={disabled} | ||
data-testid={testId} | ||
> | ||
<Label data-fs-rating-field-label htmlFor={id}> | ||
{label} | ||
</Label> | ||
<Rating | ||
id={id} | ||
data-fs-rating-field-input | ||
ref={ratingRef} | ||
length={length} | ||
value={value} | ||
onChange={onChange} | ||
disabled={disabled} | ||
{...otherProps} | ||
/> | ||
{shouldDisplayError && ( | ||
<span data-fs-rating-field-error-message>{error}</span> | ||
)} | ||
</div> | ||
) | ||
} | ||
|
||
export default RatingField |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
export { default } from './RatingField' | ||
export type { RatingFieldProps } from './RatingField' |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
44 changes: 44 additions & 0 deletions
44
packages/ui/src/components/molecules/RatingField/styles.scss
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,44 @@ | ||
[data-fs-rating-field] { | ||
// -------------------------------------------------------- | ||
// Design Tokens for Rating Field | ||
// -------------------------------------------------------- | ||
|
||
// Label | ||
--fs-rating-field-label-color : var(--fs-color-text-light); | ||
--fs-rating-field-label-size : var(--fs-text-size-2); | ||
--fs-rating-field-label-line-height : var(--fs-text-size-4); | ||
|
||
// Error | ||
--fs-rating-field-error-message-size : var(--fs-text-size-legend); | ||
--fs-rating-field-error-message-line-height : 1.1; | ||
--fs-rating-field-error-message-color : var(--fs-color-danger-text); | ||
|
||
// -------------------------------------------------------- | ||
// Structural Styles | ||
// -------------------------------------------------------- | ||
display: flex; | ||
flex-direction: column; | ||
|
||
[data-fs-rating-field-label] { | ||
margin-bottom: var(--fs-spacing-0); | ||
font-size: var(--fs-rating-field-label-size); | ||
line-height: var(--fs-rating-field-label-line-height); | ||
color: var(--fs-rating-field-label-color); | ||
} | ||
|
||
[data-fs-rating-field-error-message] { | ||
margin-top: var(--fs-spacing-0); | ||
font-size: var(--fs-rating-field-error-message-size); | ||
line-height: var(--fs-rating-field-error-message-line-height); | ||
color: var(--fs-rating-field-error-message-color); | ||
} | ||
|
||
// -------------------------------------------------------- | ||
// Variants Styles | ||
// -------------------------------------------------------- | ||
&[data-fs-rating-field-error="true"] { | ||
[data-fs-rating-item="empty"] [data-fs-icon] { | ||
color: var(--fs-rating-field-error-message-color); | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters