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
JavaScript
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()\">‹</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()\">›</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(