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.84 kB
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react"),t=require("primereact/api"),n=require("primereact/componentbase"),r=require("primereact/hooks"),o=require("primereact/icons/ban"),a=require("primereact/icons/star"),l=require("primereact/icons/starfill"),i=require("primereact/tooltip"),c=require("primereact/utils");function u(e){if(e&&e.__esModule)return e;var t=Object.create(null);return e&&Object.keys(e).forEach((function(n){if("default"!==n){var r=Object.getOwnPropertyDescriptor(e,n);Object.defineProperty(t,n,r.get?r:{enumerable:!0,get:function(){return e[n]}})}})),t.default=e,Object.freeze(t)}var s=u(e);function p(){return p=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},p.apply(null,arguments)}function f(e){return f="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},f(e)}function m(e,t){if("object"!=f(e)||!e)return e;var n=e[Symbol.toPrimitive];if(void 0!==n){var r=n.call(e,t||"default");if("object"!=f(r))return r;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}function y(e){var t=m(e,"string");return"symbol"==f(t)?t:t+""}function v(e,t,n){return(t=y(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 g(e,t){var n=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=n){var r,o,a,l,i=[],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)&&(i.push(r.value),i.length!==t);c=!0);}catch(e){u=!0,o=e}finally{try{if(!c&&null!=n.return&&(l=n.return(),Object(l)!==l))return}finally{if(u)throw o}}return i}}function b(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 b(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)?b(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 P(e,t){return d(e)||g(e,t)||O(e,t)||I()}var h=n.ComponentBase.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 c.classNames("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 c.classNames("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 w(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){v(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=s.memo(s.forwardRef((function(e,u){var f=r.useMergeProps(),m=s.useContext(t.PrimeReactContext),y=h.getProps(e,m),v=P(s.useState(-1),2),d=v[0],g=v[1],b=P(s.useState(!0),2),O=b[0],I=s.useRef(null),j=h.setMetaData({props:y}),S=j.ptm,E=j.cx;n.useHandleStyle(h.css.styles,j.isUnstyled,{name:"rating"});var D=function(e,t){return S(t,{context:{active:e<=y.value}})},x=!y.disabled&&!y.readOnly,N=x?0:null,A=function(e,t){x&&y.onChange&&y.onChange({originalEvent:e,value:t,stopPropagation:function(){null==e||e.stopPropagation()},preventDefault:function(){null==e||e.preventDefault()},target:{name:y.name,id:y.id,value:t}}),g(t),e.preventDefault()},C=function(e){x&&y.onChange&&y.onChange({originalEvent:e,value:null,stopPropagation:function(){null==e||e.stopPropagation()},preventDefault:function(){null==e||e.preventDefault()},target:{name:y.name,id:y.id,value:null}}),e.preventDefault()},k=function(e,t){switch(e.key){case"Enter":case"Space":A(e,t),e.preventDefault();break;case"ArrowLeft":case"ArrowUp":e.preventDefault(),A(e,y.value-1<1?y.stars:y.value-1);break;case"ArrowRight":case"ArrowDown":e.preventDefault(),A(e,y.value+1>y.stars?1:y.value+1)}},q=function(e,t){g(t)},R=function(e){"Enter"===e.key&&C(e)};s.useImperativeHandle(u,(function(){return{props:y,getElement:function(){return I.current}}}));var U=c.ObjectUtils.isNotEmpty(y.tooltip),_=f({ref:I,id:y.id,className:c.classNames(y.className,E("root")),style:y.style},h.getOtherProps(y),S("root")),F=function(){if(y.cancel){var e=f({className:E("cancelIcon")},S("cancelIcon")),t=c.IconUtils.getJSXIcon(y.cancelIcon||s.createElement(o.BanIcon,e),w(w({},e),y.cancelIconProps),{props:y}),n=f({className:E("cancelItem"),onClick:C,tabIndex:N,onKeyDown:R},S("cancelItem"));return s.createElement("div",n,t)}return null}(),M=Array.from({length:y.stars},(function(e,t){return t+1})).map((function(e){var t=e<=y.value,n=f({className:E("onIcon")},D(y.value,"onIcon")),r=f({className:E("onIcon")},D(y.value,"offIcon")),o=c.IconUtils.getJSXIcon((t?{type:y.onIcon||s.createElement(l.StarFillIcon,n)}:{type:y.offIcon||s.createElement(a.StarIcon,r)}).type,w({},t?n:r),{props:y}),i=f({className:E("item",{active:t,focusedOptionIndex:d,isFocusVisibleItem:O,value:e}),"data-p-focused":e===d,tabIndex:N,onClick:function(t){return A(t,e)},onKeyDown:function(t){return k(t,e)},onFocus:function(t){return q(0,e)},onBlur:function(e){g(-1)}},D(y.value,"item"));return s.createElement("div",p({},i,{key:e}),o)}));return s.createElement(s.Fragment,null,s.createElement("div",_,F,M),U&&s.createElement(i.Tooltip,p({target:I,content:y.tooltip,pt:S("tooltip")},y.tooltipOptions)))})));S.displayName="Rating",exports.Rating=S;