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