66 lines
1.6 KiB
JavaScript
66 lines
1.6 KiB
JavaScript
import BaseStyle from 'primevue/base/style';
|
|
|
|
const theme = ({ dt }) => `
|
|
.p-rating {
|
|
position: relative;
|
|
display: flex;
|
|
align-items: center;
|
|
gap: 0.25rem;
|
|
}
|
|
|
|
.p-rating-option {
|
|
display: inline-flex;
|
|
align-items: center;
|
|
cursor: pointer;
|
|
outline-color: transparent;
|
|
border-radius: 50%;
|
|
cursor: pointer;
|
|
}
|
|
|
|
.p-rating-option.p-focus-visible {
|
|
outline: ${dt('focus.ring.width')} ${dt('focus.ring.style')} ${dt('focus.ring.color')};
|
|
outline-offset: ${dt('focus.ring.offset')};
|
|
}
|
|
|
|
.p-rating-icon {
|
|
color: ${dt('rating.icon.color')};
|
|
transition: background-color ${dt('transition.duration')}, color ${dt('transition.duration')}, border-color ${dt('transition.duration')}, outline-color ${dt('transition.duration')};
|
|
font-size: 1rem;
|
|
width: 1rem;
|
|
height: 1rem;
|
|
}
|
|
|
|
.p-rating:not(.p-disabled):not(.p-readonly) .p-rating-option:hover .p-rating-icon {
|
|
color: ${dt('rating.icon.hover.color')};
|
|
}
|
|
|
|
.p-rating-option-active .p-rating-icon {
|
|
color: ${dt('rating.icon.active.color')};
|
|
}
|
|
`;
|
|
|
|
const classes = {
|
|
root: ({ props }) => [
|
|
'p-rating',
|
|
{
|
|
'p-readonly': props.readonly,
|
|
'p-disabled': props.disabled
|
|
}
|
|
],
|
|
option: ({ instance, props, value }) => [
|
|
'p-rating-option',
|
|
{
|
|
'p-rating-option-active': value <= props.modelValue,
|
|
'p-focus-visible': value === instance.focusedOptionIndex && instance.isFocusVisibleItem
|
|
}
|
|
],
|
|
onIcon: 'p-rating-icon p-rating-on-icon',
|
|
offIcon: 'p-rating-icon p-rating-off-icon'
|
|
};
|
|
|
|
export default BaseStyle.extend({
|
|
name: 'rating',
|
|
theme,
|
|
classes
|
|
});
|