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) • 5.17 kB
JavaScript
import*as e from"react";import t,{localeOption as n}from"primereact/api";import{CSSTransition as r}from"primereact/csstransition";import{useUnmountEffect as a}from"primereact/hooks";import{Portal as i}from"primereact/portal";import{ObjectUtils as o,ZIndexUtils as l,classNames as c,DomHandler as u}from"primereact/utils";function s(){return s=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},s.apply(this,arguments)}function m(e){if(Array.isArray(e))return e}function p(e,t){var n=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=n){var r,a,i,o,l=[],c=!0,u=!1;try{if(i=(n=n.call(e)).next,0===t){if(Object(n)!==n)return;c=!1}else for(;!(c=(r=i.call(n)).done)&&(l.push(r.value),l.length!==t);c=!0);}catch(e){u=!0,a=e}finally{try{if(!c&&null!=n.return&&(o=n.return(),Object(o)!==o))return}finally{if(u)throw a}}return l}}function f(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 d(e,t){if(e){if("string"==typeof e)return f(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)?f(e,t):void 0}}function g(){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 y(e,t){return m(e)||p(e,t)||d(e,t)||g()}var E={defaultProps:{__TYPE:"Image",alt:null,className:null,downloadable:!1,height:null,imageClassName:null,imageStyle:null,onError:null,onHide:null,onShow:null,preview:!1,src:null,template:null,width:null,zoomSrc:null,children:void 0},getProps:function(e){return o.getMergedProps(e,E.defaultProps)},getOtherProps:function(e){return o.getDiffProps(e,E.defaultProps)}},b=e.memo(e.forwardRef((function(m,p){var f=E.getProps(m),d=y(e.useState(!1),2),g=d[0],b=d[1],v=y(e.useState(!1),2),h=v[0],w=v[1],N=y(e.useState(0),2),S=N[0],k=N[1],C=y(e.useState(1),2),O=C[0],P=C[1],x=e.useRef(null),I=e.useRef(null),j=e.useRef(null),A=e.useRef(null),R=e.useRef(!1),H=function(){f.preview&&(b(!0),setTimeout((function(){w(!0)}),25))},T=function(){R.current||(w(!1),k(0),P(1)),R.current=!1},z=function(){R.current=!0},M=function(){u.saveAs({name:f.alt,src:f.src}),R.current=!0},_=function(){k((function(e){return e+90})),R.current=!0},D=function(){k((function(e){return e-90})),R.current=!0},J=function(){P((function(e){return e+.1})),R.current=!0},U=function(){P((function(e){return e-.1})),R.current=!0},X=function(){l.set("modal",j.current,t.autoZIndex,t.zIndex.modal)},Y=function(){f.onShow&&f.onShow()},Z=function(){u.addClass(j.current,"p-component-overlay-leave")},$=function(){f.onHide&&f.onHide()},q=function(){l.clear(j.current),b(!1)};a((function(){j.current&&l.clear(j.current)}));e.useImperativeHandle(p,(function(){return{props:f,show:H,hide:T,getElement:function(){return x.current},getImage:function(){return I.current}}}));var B,F,G=f.src,K=f.alt,L=f.width,Q=f.height,V=E.getOtherProps(f),W=c("p-image p-component",f.className,{"p-image-preview-container":f.preview}),ee=(B={transform:"rotate("+S+"deg) scale("+O+")"},F=O<=.5||O>=1.5,e.createElement("div",{ref:j,className:"p-image-mask p-component-overlay p-component-overlay-enter",onClick:T},e.createElement("div",{className:"p-image-toolbar"},f.downloadable&&e.createElement("button",{className:"p-image-action p-link",onClick:M,type:"button"},e.createElement("i",{className:"pi pi-download"})),e.createElement("button",{className:"p-image-action p-link",onClick:_,type:"button"},e.createElement("i",{className:"pi pi-refresh"})),e.createElement("button",{className:"p-image-action p-link",onClick:D,type:"button"},e.createElement("i",{className:"pi pi-undo"})),e.createElement("button",{className:"p-image-action p-link",onClick:U,type:"button",disabled:F},e.createElement("i",{className:"pi pi-search-minus"})),e.createElement("button",{className:"p-image-action p-link",onClick:J,type:"button",disabled:F},e.createElement("i",{className:"pi pi-search-plus"})),e.createElement("button",{className:"p-image-action p-link",type:"button","aria-label":n("close")},e.createElement("i",{className:"pi pi-times"}))),e.createElement(r,{nodeRef:A,classNames:"p-image-preview",in:h,timeout:{enter:150,exit:150},unmountOnExit:!0,onEntering:X,onEntered:Y,onExit:Z,onExiting:$,onExited:q},e.createElement("div",{ref:A},e.createElement("img",{src:f.zoomSrc||f.src,className:"p-image-preview",style:B,onClick:z,alt:f.alt}))))),te=f.template?o.getJSXElement(f.template,f):e.createElement("i",{className:"p-image-preview-icon pi pi-eye"}),ne=f.preview?e.createElement("div",{className:"p-image-preview-indicator",onClick:H},te):null,re=f.src&&e.createElement("img",{ref:I,src:G,className:f.imageClassName,width:L,height:Q,style:f.imageStyle,alt:K,onError:f.onError});return e.createElement("span",s({ref:x,className:W},V),re,ne,g&&e.createElement(i,{element:ee,appendTo:document.body}))})));b.displayName="Image";export{b as Image};