UNPKG

primereact

Version:

PrimeReact is an open source UI library for React featuring a rich set of 90+ components, a theme designer, various theme alternatives such as Material, Bootstrap, Tailwind, premium templates and professional support. In addition, it integrates with Prime

2 lines (1 loc) 6.49 kB
import*as e from"react";import{PrimeReactContext as t}from"primereact/api";import{ComponentBase as n,useHandleStyle as r}from"primereact/componentbase";import{useMergeProps as o}from"primereact/hooks";import{BanIcon as a}from"primereact/icons/ban";import{StarIcon as i}from"primereact/icons/star";import{StarFillIcon as l}from"primereact/icons/starfill";import{Tooltip as c}from"primereact/tooltip";import{classNames as u,ObjectUtils as s,IconUtils as p}from"primereact/utils";function f(){return f=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var r in n)Object.prototype.hasOwnProperty.call(n,r)&&(e[r]=n[r])}return e},f.apply(this,arguments)}function m(e){return m="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},m(e)}function y(e,t){if("object"!==m(e)||null===e)return e;var n=e[Symbol.toPrimitive];if(void 0!==n){var r=n.call(e,t||"default");if("object"!==m(r))return r;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}function v(e){var t=y(e,"string");return"symbol"===m(t)?t:String(t)}function g(e){if(Array.isArray(e))return e}function b(e,t){var n=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=n){var r,o,a,i,l=[],c=!0,u=!1;try{if(a=(n=n.call(e)).next,0===t){if(Object(n)!==n)return;c=!1}else for(;!(c=(r=a.call(n)).done)&&(l.push(r.value),l.length!==t);c=!0);}catch(e){u=!0,o=e}finally{try{if(!c&&null!=n.return&&(i=n.return(),Object(i)!==i))return}finally{if(u)throw o}}return l}}function d(e,t){(null==t||t>e.length)&&(t=e.length);for(var n=0,r=new Array(t);n<t;n++)r[n]=e[n];return r}function O(e,t){if(e){if("string"==typeof e)return d(e,t);var n=Object.prototype.toString.call(e).slice(8,-1);return"Object"===n&&e.constructor&&(n=e.constructor.name),"Map"===n||"Set"===n?Array.from(e):"Arguments"===n||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)?d(e,t):void 0}}function I(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function h(e,t){return g(e)||b(e,t)||O(e,t)||I()}var P=n.extend({defaultProps:{__TYPE:"Rating",id:null,value:null,disabled:!1,readOnly:!1,stars:5,cancel:!0,style:null,className:null,tooltip:null,tooltipOptions:null,onChange:null,onIcon:null,offIcon:null,cancelIcon:null,cancelIconProps:null,onIconProps:null,offIconProps:null,children:void 0},css:{classes:{onIcon:"p-rating-icon",item:function(e){return u("p-rating-item",{"p-rating-item-active":e.active},{"p-focus":e.value===e.focusedOptionIndex&&e.isFocusVisibleItem})},cancelIcon:"p-rating-icon p-rating-cancel",cancelItem:"p-rating-item p-rating-cancel-item",root:function(e){var t=e.props;return u("p-rating",{"p-disabled":t.disabled,"p-readonly":t.readOnly},t.className)}},styles:"\n@layer primereact {\n .p-rating {\n display: flex;\n align-items: center;\n }\n \n .p-rating-item {\n display: inline-flex;\n align-items: center;\n cursor: pointer;\n }\n \n .p-rating.p-readonly .p-rating-item {\n cursor: default;\n }\n}\n"}});function w(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}function j(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?w(Object(n),!0).forEach((function(t){var r,o,a;r=e,a=n[t],(o=v(o=t))in r?Object.defineProperty(r,o,{value:a,enumerable:!0,configurable:!0,writable:!0}):r[o]=a})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):w(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}var S=e.memo(e.forwardRef((function(n,u){var m=o(),y=e.useContext(t),v=P.getProps(n,y),g=h(e.useState(-1),2),b=g[0],d=g[1],O=h(e.useState(!0),2),I=O[0],w=e.useRef(null),S=P.setMetaData({props:v}),E=S.ptm,D=S.cx;r(P.css.styles,S.isUnstyled,{name:"rating"});var x=function(e,t){return E(t,{context:{active:e<=v.value}})},A=!v.disabled&&!v.readOnly,N=A?0:null,k=function(e,t){A&&v.onChange&&v.onChange({originalEvent:e,value:t,stopPropagation:function(){e.stopPropagation()},preventDefault:function(){e.preventDefault()},target:{name:v.name,id:v.id,value:t}}),d(t),e.preventDefault()},C=function(e){A&&v.onChange&&v.onChange({originalEvent:e,value:null,stopPropagation:function(){e.stopPropagation()},preventDefault:function(){e.preventDefault()},target:{name:v.name,id:v.id,value:null}}),e.preventDefault()},R=function(e,t){switch(e.key){case"Enter":case"Space":k(e,t),e.preventDefault();break;case"ArrowLeft":case"ArrowUp":e.preventDefault(),k(e,v.value-1<1?v.stars:v.value-1);break;case"ArrowRight":case"ArrowDown":e.preventDefault(),k(e,v.value+1>v.stars?1:v.value+1)}},F=function(e,t){d(t)},T=function(e){"Enter"===e.key&&C(e)};e.useImperativeHandle(u,(function(){return{props:v,getElement:function(){return w.current}}}));var U=s.isNotEmpty(v.tooltip),J=m({ref:w,id:v.id,className:D("root"),style:v.style},P.getOtherProps(v),E("root")),K=function(){if(v.cancel){var t=m({className:D("cancelIcon")},E("cancelIcon")),n=p.getJSXIcon(v.cancelIcon||e.createElement(a,t),j(j({},t),v.cancelIconProps),{props:v}),r=m({className:D("cancelItem"),onClick:C,tabIndex:N,onKeyDown:T},E("cancelItem"));return e.createElement("div",r,n)}return null}(),M=Array.from({length:v.stars},(function(e,t){return t+1})).map((function(t){var n=t<=v.value,r=m({className:D("onIcon")},x(v.value,"onIcon")),o=m({className:D("onIcon")},x(v.value,"offIcon")),a=p.getJSXIcon((n?{type:v.onIcon||e.createElement(l,r)}:{type:v.offIcon||e.createElement(i,o)}).type,j({},n?r:o),{props:v}),c=m({key:t,className:D("item",{active:n,focusedOptionIndex:b,isFocusVisibleItem:I,value:t}),"data-p-focused":t===b,tabIndex:N,onClick:function(e){return k(e,t)},onKeyDown:function(e){return R(e,t)},onFocus:function(e){return F(0,t)},onBlur:function(e){d(-1)}},x(v.value,"item"));return e.createElement("div",f({key:t},c),a)}));return e.createElement(e.Fragment,null,e.createElement("div",J,K,M),U&&e.createElement(c,f({target:w,content:v.tooltip,pt:E("tooltip")},v.tooltipOptions)))})));S.displayName="Rating";export{S as Rating};