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.5 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)({}).hasOwnProperty.call(n,r)&&(e[r]=n[r])}return e},f.apply(null,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)||!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:t+""}function g(e,t,n){return(t=v(t))in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function d(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 I(e,t){(null==t||t>e.length)&&(t=e.length);for(var n=0,r=Array(t);n<t;n++)r[n]=e[n];return r}function O(e,t){if(e){if("string"==typeof e)return I(e,t);var n={}.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)?I(e,t):void 0}}function h(){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 P(e,t){return d(e)||b(e,t)||O(e,t)||h()}var w=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})}},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 j(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 E(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?j(Object(n),!0).forEach((function(t){g(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):j(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}var S=e.memo(e.forwardRef((function(n,m){var y=o(),v=e.useContext(t),g=w.getProps(n,v),d=P(e.useState(-1),2),b=d[0],I=d[1],O=P(e.useState(!0),2),h=O[0],j=e.useRef(null),S=w.setMetaData({props:g}),D=S.ptm,x=S.cx;r(w.css.styles,S.isUnstyled,{name:"rating"});var A=function(e,t){return D(t,{context:{active:e<=g.value}})},N=!g.disabled&&!g.readOnly,k=N?0:null,C=function(e,t){N&&g.onChange&&g.onChange({originalEvent:e,value:t,stopPropagation:function(){null==e||e.stopPropagation()},preventDefault:function(){null==e||e.preventDefault()},target:{name:g.name,id:g.id,value:t}}),I(t),e.preventDefault()},R=function(e){N&&g.onChange&&g.onChange({originalEvent:e,value:null,stopPropagation:function(){null==e||e.stopPropagation()},preventDefault:function(){null==e||e.preventDefault()},target:{name:g.name,id:g.id,value:null}}),e.preventDefault()},F=function(e,t){switch(e.key){case"Enter":case"Space":C(e,t),e.preventDefault();break;case"ArrowLeft":case"ArrowUp":e.preventDefault(),C(e,g.value-1<1?g.stars:g.value-1);break;case"ArrowRight":case"ArrowDown":e.preventDefault(),C(e,g.value+1>g.stars?1:g.value+1)}},T=function(e,t){I(t)},U=function(e){"Enter"===e.key&&R(e)};e.useImperativeHandle(m,(function(){return{props:g,getElement:function(){return j.current}}}));var J=s.isNotEmpty(g.tooltip),K=y({ref:j,id:g.id,className:u(g.className,x("root")),style:g.style},w.getOtherProps(g),D("root")),M=function(){if(g.cancel){var t=y({className:x("cancelIcon")},D("cancelIcon")),n=p.getJSXIcon(g.cancelIcon||e.createElement(a,t),E(E({},t),g.cancelIconProps),{props:g}),r=y({className:x("cancelItem"),onClick:R,tabIndex:k,onKeyDown:U},D("cancelItem"));return e.createElement("div",r,n)}return null}(),V=Array.from({length:g.stars},(function(e,t){return t+1})).map((function(t){var n=t<=g.value,r=y({className:x("onIcon")},A(g.value,"onIcon")),o=y({className:x("onIcon")},A(g.value,"offIcon")),a=p.getJSXIcon((n?{type:g.onIcon||e.createElement(l,r)}:{type:g.offIcon||e.createElement(i,o)}).type,E({},n?r:o),{props:g}),c=y({className:x("item",{active:n,focusedOptionIndex:b,isFocusVisibleItem:h,value:t}),"data-p-focused":t===b,tabIndex:k,onClick:function(e){return C(e,t)},onKeyDown:function(e){return F(e,t)},onFocus:function(e){return T(0,t)},onBlur:function(e){I(-1)}},A(g.value,"item"));return e.createElement("div",f({},c,{key:t}),a)}));return e.createElement(e.Fragment,null,e.createElement("div",K,M,V),J&&e.createElement(c,f({target:j,content:g.tooltip,pt:D("tooltip")},g.tooltipOptions)))})));S.displayName="Rating";export{S as Rating};