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) 2.72 kB
import*as e from"react";import{ObjectUtils as r,classNames as t,IconUtils as n}from"primereact/utils";function o(){return o=Object.assign?Object.assign.bind():function(e){for(var r=1;r<arguments.length;r++){var t=arguments[r];for(var n in t)Object.prototype.hasOwnProperty.call(t,n)&&(e[n]=t[n])}return e},o.apply(this,arguments)}function l(e){if(Array.isArray(e))return e}function a(e,r){var t=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=t){var n,o,l,a,i=[],c=!0,u=!1;try{if(l=(t=t.call(e)).next,0===r){if(Object(t)!==t)return;c=!1}else for(;!(c=(n=l.call(t)).done)&&(i.push(n.value),i.length!==r);c=!0);}catch(e){u=!0,o=e}finally{try{if(!c&&null!=t.return&&(a=t.return(),Object(a)!==a))return}finally{if(u)throw o}}return i}}function i(e,r){(null==r||r>e.length)&&(r=e.length);for(var t=0,n=new Array(r);t<r;t++)n[t]=e[t];return n}function c(e,r){if(e){if("string"==typeof e)return i(e,r);var t=Object.prototype.toString.call(e).slice(8,-1);return"Object"===t&&e.constructor&&(t=e.constructor.name),"Map"===t||"Set"===t?Array.from(e):"Arguments"===t||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t)?i(e,r):void 0}}function u(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}var p={defaultProps:{__TYPE:"Chip",label:null,icon:null,image:null,removable:!1,removeIcon:"pi pi-times-circle",className:null,style:null,template:null,imageAlt:"chip",onImageError:null,onRemove:null,children:void 0},getProps:function(e){return r.getMergedProps(e,p.defaultProps)},getOtherProps:function(e){return r.getDiffProps(e,p.defaultProps)}},s=e.memo(e.forwardRef((function(i,s){var m,f,g,y,h,v=p.getProps(i),b=e.useRef(null),d=e.useState(!0),I=(f=2,l(m=d)||a(m,f)||c(m,f)||u()),P=I[0],E=I[1],O=function(e){13===e.keyCode&&S(e)},S=function(e){E(!1),v.onRemove&&v.onRemove(e)},j=function(){var r=[];return v.image?r.push(e.createElement("img",{key:"image",src:v.image,alt:v.imageAlt,onError:v.onImageError})):v.icon&&r.push(n.getJSXIcon(v.icon,{key:"icon",className:"p-chip-icon"},{props:v})),v.label&&r.push(e.createElement("span",{key:"label",className:"p-chip-text"},v.label)),v.removable&&r.push(n.getJSXIcon(v.removeIcon,{key:"removeIcon",tabIndex:0,className:"p-chip-remove-icon",onClick:S,onKeyDown:O},{props:v})),r};return e.useImperativeHandle(s,(function(){return{props:v,getElement:function(){return b.current}}})),P&&(g=p.getOtherProps(v),y=t("p-chip p-component",{"p-chip-image":null!=v.image},v.className),h=v.template?r.getJSXElement(v.template,v):j(),e.createElement("div",o({ref:b,className:y,style:v.style},g),h))})));s.displayName="Chip";export{s as Chip};