UNPKG

rm-image-slider

Version:

Angular Image slider with lightbox. An Angular responsive image slider with lightbox popup. Also support youtube url, image base64 string and mp4 video urls and base64 string.

478 lines 179 kB
import { Component, Input, Output, EventEmitter, ViewEncapsulation, ViewChild, HostListener, PLATFORM_ID, Inject, } from '@angular/core'; import { CommonModule, isPlatformBrowser } from '@angular/common'; import { SliderLightboxComponent } from './slider-lightbox/slider-lightbox.component'; import { SliderCustomImageComponent } from './slider-custom-image/slider-custom-image.component'; import * as i0 from "@angular/core"; import * as i1 from "./rm-image-slider.service"; import * as i2 from "@angular/common"; const NEXT_ARROW_CLICK_MESSAGE = 'next', PREV_ARROW_CLICK_MESSAGE = 'previous'; export class RmImageSliderComponent { // @inputs set imageSize(data) { if (data && typeof data === 'object') { if (data.hasOwnProperty('space') && typeof data['space'] === 'number' && data['space'] > -1) { this.imageMargin = data['space']; } if (data.hasOwnProperty('width') && (typeof data['width'] === 'number' || typeof data['width'] === 'string')) { this.sliderImageReceivedWidth = data['width']; // this.sliderImageSizeWithPadding = data['width'] + (this.imageMargin * 2); // addeing padding with image width } if (data.hasOwnProperty('height') && (typeof data['height'] === 'number' || typeof data['height'] === 'string')) { this.sliderImageReceivedHeight = data['height']; } } } set direction(dir) { if (dir) { this.textDirection = dir; } } set animationSpeed(data) { if (data && typeof data === 'number' && data >= 0.1 && data <= 5) { this.speed = data; this.effectStyle = `all ${this.speed}s ease-in-out`; } } set slideImage(count) { if (count && typeof count === 'number') { this.slideImageCount = Math.round(count); } } set autoSlide(count) { if (count && (typeof count === 'number' || typeof count === 'boolean' || typeof count === 'object')) { if (typeof count === 'number' && count >= 1 && count <= 5) { count = Math.round(count); } else if (typeof count === 'boolean') { count = 1; } else if (typeof count === 'object' && count.hasOwnProperty('interval') && Math.round(count['interval']) && Math.round(count['interval']) >= 1 && Math.round(count['interval']) <= 5) { this.stopSlideOnHover = count.hasOwnProperty('stopOnHover') ? count['stopOnHover'] : true; count = Math.round(count['interval']); } this.autoSlideCount = count * 1000; } } set showArrow(flag) { if (flag !== undefined && typeof flag === 'boolean') { this.showArrowButton = flag; } } set orderType(data) { if (data !== undefined && typeof data === 'string') { this.sliderOrderType = data.toUpperCase(); } } set defaultActiveImage(activeIndex) { if (typeof activeIndex === 'number' && activeIndex > -1) { this.activeImageIndex = activeIndex; } } onResize(event) { this.setSliderWidth(); } handleKeyboardEvent(event) { if (event && event.key) { if (event.key.toLowerCase() === 'arrowright' && !this.ligthboxShow && this.arrowKeyMove) { this.next(); } if (event.key.toLowerCase() === 'arrowleft' && !this.ligthboxShow && this.arrowKeyMove) { this.prev(); } if (event.key.toLowerCase() === 'escape' && this.ligthboxShow) { this.close(); } } } constructor(cdRef, platformId, imageSliderService, elRef // @Inject(ElementRef) private _elementRef: ElementRef ) { this.cdRef = cdRef; this.platformId = platformId; this.imageSliderService = imageSliderService; this.elRef = elRef; // for slider this.sliderMainDivWidth = 0; this.imageParentDivWidth = 0; this.imageObj = []; this.ligthboxImageObj = []; this.totalImages = 0; this.leftPos = 0; this.effectStyle = 'all 1s ease-in-out'; this.speed = 1; // default speed in second this.sliderPrevDisable = false; this.sliderNextDisable = false; this.slideImageCount = 1; this.sliderImageWidth = 205; this.sliderImageReceivedWidth = 205; this.sliderImageHeight = 200; this.sliderImageReceivedHeight = 205; this.sliderImageSizeWithPadding = 211; this.autoSlideCount = 0; this.stopSlideOnHover = true; this.showArrowButton = true; this.textDirection = 'ltr'; this.imageMargin = 3; this.sliderOrderType = 'ASC'; // for lightbox this.ligthboxShow = false; this.activeImageIndex = -1; this.visiableImageIndex = 0; this.infinite = false; this.imagePopup = true; this.images = []; this.videoAutoPlay = false; this.paginationShow = false; this.arrowKeyMove = true; this.manageImageRatio = false; this.showVideoControls = true; this.lazyLoading = false; // @Outputs this.imageClick = new EventEmitter(); this.arrowClick = new EventEmitter(); this.lightboxArrowClick = new EventEmitter(); this.lightboxClose = new EventEmitter(); } ngOnInit() { // @TODO: for future use // console.log(this._elementRef) // for slider if (this.infinite) { this.effectStyle = 'none'; this.leftPos = -1 * this.sliderImageSizeWithPadding * this.slideImageCount; for (let i = 1; i <= this.slideImageCount; i++) { this.imageObj.unshift(this.imageObj[this.imageObj.length - i]); } } } // for slider ngAfterViewInit() { this.setSliderWidth(); this.cdRef.detectChanges(); if (isPlatformBrowser(this.platformId)) { this.imageAutoSlide(); } } ngOnDestroy() { if (this.autoSlideInterval) { clearInterval(this.autoSlideInterval); } if (this.ligthboxShow === true) { this.close(); } } ngOnChanges(changes) { if (changes['images'] && changes['images'].hasOwnProperty('previousValue') && changes['images'].hasOwnProperty('currentValue') && changes['images'].previousValue != changes['images'].currentValue) { this.setSliderImages(changes['images'].currentValue); } if (changes && changes['imageSize']) { const size = changes['imageSize']; if (size && size.previousValue && size.currentValue && size.previousValue.width && size.previousValue.height && size.currentValue.width && size.currentValue.height && (size.previousValue.width !== size.currentValue.width || size.previousValue.height !== size.currentValue.height)) { this.setSliderWidth(); } } } ngDoCheck() { if (this.images && this.ligthboxImageObj && this.images.length !== this.ligthboxImageObj.length) { this.setSliderImages(this.images); } } setSliderImages(imgObj) { if (imgObj && imgObj instanceof Array && imgObj.length) { // const sliderOrderEnable = imgObj.find((img: any) => { // if (img.hasOwnProperty('order')) { // return true; // } // }); const sliderOrderEnable = imgObj.find((img) => { return img.order !== undefined; }) !== undefined; if (sliderOrderEnable) { imgObj = this.imageSliderService.orderArray(imgObj, this.sliderOrderType.toUpperCase()); } this.imageObj = imgObj.map((img, index) => { img['index'] = index; return img; }); this.ligthboxImageObj = [...this.imageObj]; this.totalImages = this.imageObj.length; // this.imageParentDivWidth = imgObj.length * this.sliderImageSizeWithPadding; } else { this.imageObj = []; this.ligthboxImageObj = []; this.totalImages = 0; this.imageParentDivWidth = 0; this.activeImageIndex = 0; } this.setSliderWidth(); } setSliderWidth() { if (this.sliderMain && this.sliderMain.nativeElement && this.sliderMain.nativeElement.offsetWidth) { this.sliderMainDivWidth = this.sliderMain.nativeElement.offsetWidth; } if (this.sliderMainDivWidth && this.sliderImageReceivedWidth) { if (typeof this.sliderImageReceivedWidth === 'number') { this.sliderImageWidth = this.sliderImageReceivedWidth; } else if (typeof this.sliderImageReceivedWidth === 'string') { if (this.sliderImageReceivedWidth.indexOf('px') >= 0) { this.sliderImageWidth = parseFloat(this.sliderImageReceivedWidth); } else if (this.sliderImageReceivedWidth.indexOf('%') >= 0) { this.sliderImageWidth = +((this.sliderMainDivWidth * parseFloat(this.sliderImageReceivedWidth)) / 100).toFixed(2); } else if (parseFloat(this.sliderImageReceivedWidth)) { this.sliderImageWidth = parseFloat(this.sliderImageReceivedWidth); } } } if (isPlatformBrowser(this.platformId)) { if (window && window.innerHeight && this.sliderImageReceivedHeight) { if (typeof this.sliderImageReceivedHeight === 'number') { this.sliderImageHeight = this.sliderImageReceivedHeight; } else if (typeof this.sliderImageReceivedHeight === 'string') { if (this.sliderImageReceivedHeight.indexOf('px') >= 0) { this.sliderImageHeight = parseFloat(this.sliderImageReceivedHeight); } else if (this.sliderImageReceivedHeight.indexOf('%') >= 0) { this.sliderImageHeight = +((window.innerHeight * parseFloat(this.sliderImageReceivedHeight)) / 100).toFixed(2); } else if (parseFloat(this.sliderImageReceivedHeight)) { this.sliderImageHeight = parseFloat(this.sliderImageReceivedHeight); } } } } this.sliderImageSizeWithPadding = this.sliderImageWidth + this.imageMargin * 2; this.imageParentDivWidth = this.imageObj.length * this.sliderImageSizeWithPadding; if (this.imageDiv && this.imageDiv.nativeElement && this.imageDiv.nativeElement.offsetWidth) { const staticLeftPos = 0 - (this.sliderImageSizeWithPadding * this.visiableImageIndex + this.imageMargin * 2); this.leftPos = this.infinite ? -1 * this.sliderImageSizeWithPadding * this.slideImageCount : staticLeftPos; } this.nextPrevSliderButtonDisable(); } imageOnClick(index) { this.activeImageIndex = index; if (this.imagePopup) { this.showLightbox(); } this.imageClick.emit(index); } imageAutoSlide() { if (this.infinite && this.autoSlideCount && !this.ligthboxShow) { this.autoSlideInterval = setInterval(() => { this.next(); }, this.autoSlideCount); } } imageMouseEnterHandler() { if (this.infinite && this.autoSlideCount && this.autoSlideInterval) { clearInterval(this.autoSlideInterval); } } prev() { if (!this.sliderPrevDisable) { if (this.infinite) { this.infinitePrevImg(); } else { this.prevImg(); } //this.arrowClick.emit(PREV_ARROW_CLICK_MESSAGE); this.sliderArrowDisableTeam(PREV_ARROW_CLICK_MESSAGE); this.getVisiableIndex(); } } next() { if (!this.sliderNextDisable) { if (this.infinite) { this.infiniteNextImg(); } else { this.nextImg(); } //this.arrowClick.emit(NEXT_ARROW_CLICK_MESSAGE); this.sliderArrowDisableTeam(NEXT_ARROW_CLICK_MESSAGE); this.getVisiableIndex(); } } prevImg() { if (0 >= this.leftPos + this.sliderImageSizeWithPadding * this.slideImageCount) { this.leftPos += this.sliderImageSizeWithPadding * this.slideImageCount; } else { this.leftPos = 0; } } nextImg() { if (this.imageParentDivWidth + this.leftPos - this.sliderMainDivWidth > this.sliderImageSizeWithPadding * this.slideImageCount) { this.leftPos -= this.sliderImageSizeWithPadding * this.slideImageCount; } else if (this.imageParentDivWidth + this.leftPos - this.sliderMainDivWidth > 0) { this.leftPos -= this.imageParentDivWidth + this.leftPos - this.sliderMainDivWidth; } } infinitePrevImg() { this.effectStyle = `all ${this.speed}s ease-in-out`; this.leftPos = 0; setTimeout(() => { this.effectStyle = 'none'; this.leftPos = -1 * this.sliderImageSizeWithPadding * this.slideImageCount; for (let i = 0; i < this.slideImageCount; i++) { this.imageObj.unshift(this.imageObj[this.imageObj.length - this.slideImageCount - 1]); this.imageObj.pop(); } }, this.speed * 1000); } infiniteNextImg() { this.effectStyle = `all ${this.speed}s ease-in-out`; this.leftPos = -2 * this.sliderImageSizeWithPadding * this.slideImageCount; setTimeout(() => { this.effectStyle = 'none'; for (let i = 0; i < this.slideImageCount; i++) { this.imageObj.push(this.imageObj[this.slideImageCount]); this.imageObj.shift(); } this.leftPos = -1 * this.sliderImageSizeWithPadding * this.slideImageCount; }, this.speed * 1000); } getVisiableIndex() { const currentIndex = Math.round((Math.abs(this.leftPos) + this.sliderImageWidth) / this.sliderImageWidth); if (this.imageObj && this.imageObj[currentIndex - 1] && this.imageObj[currentIndex - 1]['index']) { this.visiableImageIndex = this.imageObj[currentIndex - 1]['index'] ?? 0; } } /** * Disable slider left/right arrow when image moving */ sliderArrowDisableTeam(msg) { this.sliderNextDisable = true; this.sliderPrevDisable = true; setTimeout(() => { this.nextPrevSliderButtonDisable(msg); }, this.speed * 1000); } nextPrevSliderButtonDisable(msg) { this.sliderNextDisable = false; this.sliderPrevDisable = false; const actionMsg = {}; if (!this.infinite) { if (this.imageParentDivWidth + this.leftPos <= this.sliderMainDivWidth) { this.sliderNextDisable = true; } if (this.leftPos >= 0) { this.sliderPrevDisable = true; } actionMsg['prevDisable'] = this.sliderPrevDisable; actionMsg['nextDisable'] = this.sliderNextDisable; } if (msg) { this.arrowClick.emit({ action: msg, ...actionMsg, }); } } // for lightbox showLightbox() { if (this.imageObj.length) { this.imageMouseEnterHandler(); this.ligthboxShow = true; this.elRef.nativeElement.ownerDocument.body.style.overflow = 'hidden'; } } close() { this.ligthboxShow = false; this.elRef.nativeElement.ownerDocument.body.style.overflow = ''; this.lightboxClose.emit(); this.imageAutoSlide(); } lightboxArrowClickHandler(event) { this.lightboxArrowClick.emit(event); } swipe(e, when) { const coord = [ e.changedTouches[0].pageX, e.changedTouches[0].pageY, ]; const time = new Date().getTime(); if (when === 'start') { this.swipeCoord = coord; this.swipeTime = time; } else if (when === 'end' && this.swipeCoord && this.swipeTime) { const direction = [ coord[0] - this.swipeCoord[0], coord[1] - this.swipeCoord[1], ]; const duration = time - this.swipeTime; if (duration < 1000 && // Math.abs(direction[0]) > 30 && // Long enough Math.abs(direction[0]) > Math.abs(direction[1] * 3)) { // Horizontal enough if (direction[0] < 0) { this.next(); } else { this.prev(); } } } } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.10", ngImport: i0, type: RmImageSliderComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: PLATFORM_ID }, { token: i1.RmImageSliderService }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.10", type: RmImageSliderComponent, isStandalone: true, selector: "rm-image-slider", inputs: { imageSize: "imageSize", infinite: "infinite", imagePopup: "imagePopup", direction: "direction", animationSpeed: "animationSpeed", images: "images", slideImage: "slideImage", autoSlide: "autoSlide", showArrow: "showArrow", orderType: "orderType", videoAutoPlay: "videoAutoPlay", paginationShow: "paginationShow", arrowKeyMove: "arrowKeyMove", manageImageRatio: "manageImageRatio", showVideoControls: "showVideoControls", defaultActiveImage: "defaultActiveImage", lazyLoading: "lazyLoading" }, outputs: { imageClick: "imageClick", arrowClick: "arrowClick", lightboxArrowClick: "lightboxArrowClick", lightboxClose: "lightboxClose" }, host: { listeners: { "window:resize": "onResize($event)", "document:keyup": "handleKeyboardEvent($event)" } }, viewQueries: [{ propertyName: "sliderMain", first: true, predicate: ["sliderMain"], descendants: true }, { propertyName: "imageDiv", first: true, predicate: ["imageDiv"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"ng-image-slider\" [ngStyle]=\"{'height':sliderImageHeight+'px'}\">\r\n <div class=\"ng-image-slider-container\">\r\n <div class=\"main\" [ngStyle]=\"{'height':sliderImageHeight+'px'}\" #sliderMain>\r\n @if (imageObj.length) {\r\n <div class=\"main-inner\" [ngClass]=\"{'with-ng-main-pagination': paginationShow}\"\r\n [ngStyle]=\"{'margin-left':leftPos+'px', 'width':imageParentDivWidth+'px', 'transition': effectStyle}\"\r\n (touchstart)=\"swipe($event, 'start')\" (touchend)=\"swipe($event, 'end')\">\r\n @for (img of imageObj; track img; let i = $index) {\r\n <div\r\n [ngClass]=\"{'image-popup': imagePopup, 'selected-image': activeImageIndex == i}\"\r\n [ngStyle]=\"{'width':sliderImageWidth+'px', 'margin-left':imageMargin+'px', 'margin-right':imageMargin+'px'}\"\r\n class=\"img-div\" (click)=\"imageOnClick(img.index)\" (mouseenter)=\"stopSlideOnHover && imageMouseEnterHandler()\"\r\n (mouseleave)=\"stopSlideOnHover && imageAutoSlide()\" #imageDiv>\r\n <custom-img [imageUrl]=\"img?.thumbImage || img?.posterImage || img?.video\"\r\n [isVideo]=\"!!(img?.posterImage || img?.video)\" [alt]=\"img?.alt || img?.title || ''\"\r\n [title]=\"img?.title || img?.alt || ''\" [direction]=\"textDirection\" [ratio]=\"manageImageRatio\"\r\n [lazy]=\"lazyLoading\">\r\n </custom-img>\r\n @if (img?.title) {\r\n <div [dir]=\"textDirection\" class=\"caption\">{{ img?.title }}</div>\r\n }\r\n </div>\r\n }\r\n </div>\r\n }\r\n @if (!imageObj.length) {\r\n <div class=\"ng-image-slider-error\">\r\n <span class=\"ng-image-slider-loader\"></span>\r\n </div>\r\n }\r\n @if (showArrowButton && imageObj.length > 1) {\r\n <a [ngClass]=\"{'disable': sliderPrevDisable}\"\r\n class=\"prev icons prev-icon\" (click)=\"prev()\" (mouseenter)=\"stopSlideOnHover && imageMouseEnterHandler()\"\r\n (mouseleave)=\"stopSlideOnHover && imageAutoSlide()\">&lsaquo;</a>\r\n }\r\n @if (showArrowButton && imageObj.length > 1) {\r\n <a [ngClass]=\"{'disable': sliderNextDisable}\"\r\n class=\"next icons next-icon\" (click)=\"next()\" (mouseenter)=\"imageMouseEnterHandler()\"\r\n (mouseleave)=\"imageAutoSlide()\">&rsaquo;</a>\r\n }\r\n </div>\r\n @if (imageObj.length && paginationShow) {\r\n <div class=\"ng-main-pagination\">{{visiableImageIndex + 1}} of\r\n {{totalImages}}</div>\r\n }\r\n </div>\r\n</div>\r\n@if (ligthboxShow) {\r\n <div>\r\n <slider-lightbox [paginationShow]=\"paginationShow\" [showVideoControls]=\"showVideoControls\"\r\n [arrowKeyMove]=\"arrowKeyMove\" [images]=\"ligthboxImageObj\" [infinite]=\"infinite\" [animationSpeed]=\"speed\"\r\n [imageIndex]=\"activeImageIndex\" [show]=\"ligthboxShow\" [direction]=\"textDirection\" [videoAutoPlay]=\"videoAutoPlay\"\r\n (prevImage)=\"lightboxArrowClickHandler($event)\" (nextImage)=\"lightboxArrowClickHandler($event)\" (close)=\"close()\">\r\n </slider-lightbox>\r\n </div>\r\n}", styles: [".ng-image-slider{display:inline-block;position:relative;width:100%}.ng-image-slider .ng-image-slider-container .main{overflow:hidden;position:absolute;height:200px;width:100%}.ng-image-slider .ng-image-slider-container .main .main-inner{width:1760px;padding:0;height:100%}.ng-image-slider .ng-image-slider-container .main .main-inner.with-ng-main-pagination{height:calc(100% - 30px)}.ng-image-slider .ng-image-slider-container .main .main-inner .full-screen{background:url();background-size:40px 40px;background-repeat:no-repeat;position:absolute;z-index:8;display:block;height:40px;width:40px;top:4px;right:8px;opacity:.4;transition:all .5s ease-in-out;cursor:pointer}.ng-image-slider .ng-image-slider-container .main .main-inner .img-div{width:205px;height:100%;margin-right:3px;margin-left:3px;position:relative;display:inline-block;box-shadow:inset 0 0 1px #0000003d,0 0 2px #0000001f;border-radius:5px}.ng-image-slider .ng-image-slider-container .main .main-inner .img-div.image-popup{cursor:pointer}.ng-image-slider .ng-image-slider-container .main .main-inner .img-div img,.ng-image-slider .ng-image-slider-container .main .main-inner .img-div video{position:absolute;margin:auto;height:100%;width:100%;inset:0;border-radius:5px}.ng-image-slider .ng-image-slider-container .main .main-inner .img-div img.ratio,.ng-image-slider .ng-image-slider-container .main .main-inner .img-div video.ratio{width:auto;height:auto;max-width:100%;max-height:100%}.ng-image-slider .ng-image-slider-container .main .main-inner .img-div .youtube-icon{background:url();background-size:140px 80px;background-repeat:no-repeat;position:absolute;z-index:6;display:block;height:100%;width:100%;top:0;left:0;background-position:center center}.ng-image-slider .ng-image-slider-container .main .main-inner .img-div .caption{position:absolute;bottom:0;padding:5px;color:#fff;background-image:linear-gradient(to right,#0000001a,#00000040,#00000080,#00000040,#0000001a);width:100%;text-align:center;box-sizing:border-box;border-radius:0 0 5px 5px}.ng-image-slider .ng-image-slider-container .main .main-inner:hover .full-screen{transition:all .5s ease-in-out;opacity:1}.ng-image-slider .ng-image-slider-container .main .next,.ng-image-slider .ng-image-slider-container .main .prev{position:absolute;right:10px;top:50%;background-color:#fff;border-radius:50%;cursor:pointer;margin-top:-16px;outline:0;width:35px;height:35px;font-size:35px;line-height:30px;z-index:8;transition:all .5s ease-in-out;text-align:center}.ng-image-slider .ng-image-slider-container .main .next:hover,.ng-image-slider .ng-image-slider-container .main .prev:hover{background-color:#d4cdcd;background-position:-192px -415px}.ng-image-slider .ng-image-slider-container .main .next.disable,.ng-image-slider .ng-image-slider-container .main .prev.disable{color:#bbb;background-color:#fff;opacity:.5;cursor:default}.ng-image-slider .ng-image-slider-container .main .prev{left:10px}.ng-image-slider .ng-image-slider-container .main .prev:hover{background-position:-194px -450px}.ng-image-slider .ng-image-slider-container .ng-main-pagination{background-color:inherit;color:inherit;position:absolute;height:30px;width:calc(100% - 6px);text-align:center;bottom:0;font-size:16px;line-height:30px;border-radius:0 0 5px 5px;margin:0 3px}.ng-image-slider .ng-image-slider-error{height:100%;position:relative;display:flex;justify-content:center;align-items:center}.ng-image-slider .ng-image-slider-error .ng-image-slider-loader{background-image:url();background-repeat:no-repeat;background-position:center center;background-size:25px 25px;width:25px;height:25px}.close-outside{height:100%;width:100%;position:absolute;top:0;left:0}@media (max-width: 1199px){.ng-image-slider .ng-image-slider-container .main .main-inner .img-div{width:170px;max-width:100%}}@media (max-width: 991px){.ng-image-slider .ng-image-slider-container .main .main-inner .img-div{width:297px;max-width:100%}}@media (max-width: 768px){.ng-image-slider .ng-image-slider-container .main .main-inner .img-div{width:247px;max-width:100%}}@media (max-width: 576px){.ng-image-slider .ng-image-slider-container .main .main-inner .img-div{width:350px;max-width:100%}}.ng-image-fullscreen-view{position:fixed;z-index:1031;background-color:#0009;width:100%;height:100%;top:0;overflow:hidden;-webkit-transition:all .5s ease-in-out;-moz-transition:all .5s ease-in-out;-o-transition:all .5s ease-in-out;transition:all .5s ease-in-out;left:0;text-align:center}.ng-image-fullscreen-view.image-fullview-hide{display:none!important}.ng-image-fullscreen-view .lightbox-wrapper{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#1f1f1f;transition:all .5s ease;display:flex;justify-content:center;align-items:center}.ng-image-fullscreen-view .lightbox-wrapper.ng-ligthbox-pagination{height:calc(100% - 30px)}.ng-image-fullscreen-view .lightbox-wrapper .lightbox-div{width:100%;height:100%;border:1px solid;border-color:#00000059;position:relative;overflow:hidden}.ng-image-fullscreen-view .lightbox-wrapper .lightbox-div .pre-loader{background-color:inherit;width:100%;height:100%}.ng-image-fullscreen-view .lightbox-wrapper .lightbox-div .pre-loader .mnml-spinner{background-image:url(