UNPKG

primevue

Version:

[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT) [![npm version](https://badge.fury.io/js/primevue.svg)](https://badge.fury.io/js/primevue) [![Discord Chat](https://img.shields.io/discord/55794023

2 lines (1 loc) 6.56 kB
"use strict";var e=require("primevue/utils"),i=require("vue"),t={name:"Image",inheritAttrs:!1,props:{preview:{type:Boolean,default:!1},class:null,style:null,imageStyle:null,imageClass:null},mask:null,data:()=>({maskVisible:!1,previewVisible:!1,rotate:0,scale:1}),beforeUnmount(){this.mask&&e.ZIndexUtils.clear(this.container)},methods:{maskRef(e){this.mask=e},toolbarRef(e){this.toolbarRef=e},onImageClick(){this.preview&&(this.maskVisible=!0,setTimeout((()=>{this.previewVisible=!0}),25))},onPreviewImageClick(){this.previewClick=!0},onMaskClick(){this.previewClick||(this.previewVisible=!1,this.rotate=0,this.scale=1),this.previewClick=!1},rotateRight(){this.rotate+=90,this.previewClick=!0},rotateLeft(){this.rotate-=90,this.previewClick=!0},zoomIn(){this.scale=this.scale+.1,this.previewClick=!0},zoomOut(){this.scale=this.scale-.1,this.previewClick=!0},onBeforeEnter(){e.ZIndexUtils.set("modal",this.mask,this.$primevue.config.zIndex.modal)},onEnter(){this.$emit("show")},onBeforeLeave(){e.DomHandler.addClass(this.mask,"p-component-overlay-leave")},onLeave(){this.$emit("hide")},onAfterLeave(i){e.ZIndexUtils.clear(i),this.maskVisible=!1}},computed:{containerClass(){return["p-image p-component",this.class,{"p-image-preview-container":this.preview}]},maskClass:()=>["p-image-mask p-component-overlay p-component-overlay-enter"],rotateClass(){return"p-image-preview-rotate-"+this.rotate},imagePreviewStyle(){return{transform:"rotate("+this.rotate+"deg) scale("+this.scale+")"}},zoomDisabled(){return this.scale<=.5||this.scale>=1.5}}};const n=i.createVNode("i",{class:"p-image-preview-icon pi pi-eye"},null,-1),a={class:"p-image-toolbar"},o=i.createVNode("i",{class:"pi pi-refresh"},null,-1),s=i.createVNode("i",{class:"pi pi-undo"},null,-1),r=i.createVNode("i",{class:"pi pi-search-minus"},null,-1),l=i.createVNode("i",{class:"pi pi-search-plus"},null,-1),c=i.createVNode("i",{class:"pi pi-times"},null,-1),p={key:0};!function(e,i){void 0===i&&(i={});var t=i.insertAt;if(e&&"undefined"!=typeof document){var n=document.head||document.getElementsByTagName("head")[0],a=document.createElement("style");a.type="text/css","top"===t&&n.firstChild?n.insertBefore(a,n.firstChild):n.appendChild(a),a.styleSheet?a.styleSheet.cssText=e:a.appendChild(document.createTextNode(e))}}("\n.p-image-mask {\n display: -webkit-box;\n display: -ms-flexbox;\n display: flex;\n -webkit-box-align: center;\n -ms-flex-align: center;\n align-items: center;\n -webkit-box-pack: center;\n -ms-flex-pack: center;\n justify-content: center;\n}\n.p-image-preview-container {\n position: relative;\n display: inline-block;\n}\n.p-image-preview-indicator {\n position: absolute;\n left: 0;\n top: 0;\n width: 100%;\n height: 100%;\n display: -webkit-box;\n display: -ms-flexbox;\n display: flex;\n -webkit-box-align: center;\n -ms-flex-align: center;\n align-items: center;\n -webkit-box-pack: center;\n -ms-flex-pack: center;\n justify-content: center;\n opacity: 0;\n -webkit-transition: opacity .3s;\n transition: opacity .3s;\n}\n.p-image-preview-icon {\n font-size: 1.5rem;\n}\n.p-image-preview-container:hover > .p-image-preview-indicator {\n opacity: 1;\n cursor: pointer;\n}\n.p-image-preview-container > img {\n cursor: pointer;\n}\n.p-image-toolbar {\n position: absolute;\n top: 0;\n right: 0;\n display: -webkit-box;\n display: -ms-flexbox;\n display: flex;\n}\n.p-image-action.p-link {\n display: -webkit-box;\n display: -ms-flexbox;\n display: flex;\n -webkit-box-pack: center;\n -ms-flex-pack: center;\n justify-content: center;\n -webkit-box-align: center;\n -ms-flex-align: center;\n align-items: center;\n}\n.p-image-preview {\n -webkit-transition: -webkit-transform .15s;\n transition: -webkit-transform .15s;\n transition: transform .15s;\n transition: transform .15s, -webkit-transform .15s;\n max-width: 100vw;\n max-height: 100vh;\n}\n.p-image-preview-enter-active {\n -webkit-transition: all 150ms cubic-bezier(0, 0, 0.2, 1);\n transition: all 150ms cubic-bezier(0, 0, 0.2, 1);\n}\n.p-image-preview-leave-active {\n -webkit-transition: all 150ms cubic-bezier(0.4, 0.0, 0.2, 1);\n transition: all 150ms cubic-bezier(0.4, 0.0, 0.2, 1);\n}\n.p-image-preview-enter-from,\n.p-image-preview-leave-to {\n opacity: 0;\n -webkit-transform: scale(0.7);\n transform: scale(0.7);\n}\n"),t.render=function(e,t,m,d,k,b){return i.openBlock(),i.createBlock("span",{class:b.containerClass,style:m.style},[i.createVNode("img",i.mergeProps(e.$attrs,{style:m.imageStyle,class:m.imageClass}),null,16),m.preview?(i.openBlock(),i.createBlock("div",{key:0,class:"p-image-preview-indicator",onClick:t[1]||(t[1]=(...e)=>b.onImageClick&&b.onImageClick(...e))},[i.renderSlot(e.$slots,"indicator",{},(()=>[n]))])):i.createCommentVNode("",!0),(i.openBlock(),i.createBlock(i.Teleport,{to:"body"},[k.maskVisible?(i.openBlock(),i.createBlock("div",{key:0,ref:b.maskRef,class:b.maskClass,onClick:t[8]||(t[8]=(...e)=>b.onMaskClick&&b.onMaskClick(...e))},[i.createVNode("div",a,[i.createVNode("button",{class:"p-image-action p-link",onClick:t[2]||(t[2]=(...e)=>b.rotateRight&&b.rotateRight(...e)),type:"button"},[o]),i.createVNode("button",{class:"p-image-action p-link",onClick:t[3]||(t[3]=(...e)=>b.rotateLeft&&b.rotateLeft(...e)),type:"button"},[s]),i.createVNode("button",{class:"p-image-action p-link",onClick:t[4]||(t[4]=(...e)=>b.zoomOut&&b.zoomOut(...e)),type:"button",disabled:b.zoomDisabled},[r],8,["disabled"]),i.createVNode("button",{class:"p-image-action p-link",onClick:t[5]||(t[5]=(...e)=>b.zoomIn&&b.zoomIn(...e)),type:"button",disabled:b.zoomDisabled},[l],8,["disabled"]),i.createVNode("button",{class:"p-image-action p-link",type:"button",onClick:t[6]||(t[6]=(...i)=>e.hidePreview&&e.hidePreview(...i))},[c])]),i.createVNode(i.Transition,{name:"p-image-preview",onBeforeEnter:b.onBeforeEnter,onEnter:b.onEnter,onLeave:b.onLeave,onBeforeLeave:b.onBeforeLeave,onAfterLeave:b.onAfterLeave},{default:i.withCtx((()=>[k.previewVisible?(i.openBlock(),i.createBlock("div",p,[i.createVNode("img",{src:e.$attrs.src,class:"p-image-preview",style:b.imagePreviewStyle,onClick:t[7]||(t[7]=(...e)=>b.onPreviewImageClick&&b.onPreviewImageClick(...e))},null,12,["src"])])):i.createCommentVNode("",!0)])),_:1},8,["onBeforeEnter","onEnter","onLeave","onBeforeLeave","onAfterLeave"])],2)):i.createCommentVNode("",!0)]))],6)},module.exports=t;