diff --git a/src/components/ionic-image-cache.ts b/src/components/ionic-image-cache.ts index a04ad95..cc7f3de 100644 --- a/src/components/ionic-image-cache.ts +++ b/src/components/ionic-image-cache.ts @@ -1,320 +1,357 @@ import { IonicImageCacheConfig } from '../providers/ionic-image-cache-config'; -import { Component, Input, Output, NgZone, EventEmitter, ViewChild, ElementRef, ViewEncapsulation } from '@angular/core'; +import { + Component, + Input, + Output, + NgZone, + EventEmitter, + ViewChild, + ElementRef, + ViewEncapsulation +} from '@angular/core'; import { IonicImageCacheHelperProvider } from '../providers/ionic-image-cache-fileprocessor'; import { Platform } from 'ionic-angular'; import { FileEntry, RemoveResult, DirectoryEntry } from '@ionic-native/file'; import { ImageViewerController } from 'ionic-img-viewer'; - @Component({ - selector: 'ionic-image-cache', - template: ` -
-
- -
- - -
-`, - styles: [ - ` - ionic-image-cache .ionic-image-cache-container { - min-height: 20px; - } - ionic-image-cache.img-circle img { - border-radius: 50%; - } - ionic-image-cache.img-thumbnail img { - border-radius: 6px; - } - ionic-image-cache .ionic-image-cache-progress-div { - height: 30px; - } - ionic-image-cache img { - max-width: 100%; - max-height: 100%; - width: 100%; - } - ionic-image-cache img .width100percent { - width: 100%; - } - ionic-image-cache .ionic-image-cache-prelative { - position: relative; - } - ionic-image-cache .ionic-image-cache-absolute-center { - margin: auto; - position: absolute; - top: 0; - left: 0; - bottom: 0; - right: 0; - } - ionic-image-cache .ionic-image-cache-display-flex { - display: flex; - flex-wrap: wrap; - } - ionic-image-cache .ionic-image-cache-display-flex.flex-valign-center { - align-items: center; - } - ionic-image-cache .ionic-image-cache-display-flex.flex-valign-start { - align-items: flex-start; - } - ionic-image-cache .ionic-image-cache-display-flex.flex-valign-end { - align-items: flex-end; - } - ionic-image-cache .ionic-image-cache-display-flex.flex-halign-center { - justify-content: center; - } - ionic-image-cache .ionic-image-cache-display-flex.flex-halign-start { - justify-content: flex-start; - } - ionic-image-cache .ionic-image-cache-display-flex.flex-halign-end { - justify-content: flex-end; - } - ionic-image-cache .ionic-image-cache-display-flex.no-wrap { - flex-wrap: nowrap; - } -` - ], - encapsulation: ViewEncapsulation.None + selector: 'ionic-image-cache', + template: ` +
+
+ +
+ + +
+ `, + styles: [ + ` + ionic-image-cache .ionic-image-cache-container { + min-height: 20px; + } + ionic-image-cache.img-circle img { + border-radius: 50%; + } + ionic-image-cache.img-thumbnail img { + border-radius: 6px; + } + ionic-image-cache .ionic-image-cache-progress-div { + height: 30px; + } + ionic-image-cache img { + max-width: 100%; + max-height: 100%; + width: 100%; + } + ionic-image-cache img .width100percent { + width: 100%; + } + ionic-image-cache .ionic-image-cache-prelative { + position: relative; + } + ionic-image-cache .ionic-image-cache-absolute-center { + margin: auto; + position: absolute; + top: 0; + left: 0; + bottom: 0; + right: 0; + } + ionic-image-cache .ionic-image-cache-display-flex { + display: flex; + flex-wrap: wrap; + } + ionic-image-cache + .ionic-image-cache-display-flex.flex-valign-center { + align-items: center; + } + ionic-image-cache + .ionic-image-cache-display-flex.flex-valign-start { + align-items: flex-start; + } + ionic-image-cache .ionic-image-cache-display-flex.flex-valign-end { + align-items: flex-end; + } + ionic-image-cache + .ionic-image-cache-display-flex.flex-halign-center { + justify-content: center; + } + ionic-image-cache + .ionic-image-cache-display-flex.flex-halign-start { + justify-content: flex-start; + } + ionic-image-cache .ionic-image-cache-display-flex.flex-halign-end { + justify-content: flex-end; + } + ionic-image-cache .ionic-image-cache-display-flex.no-wrap { + flex-wrap: nowrap; + } + ` + ], + encapsulation: ViewEncapsulation.None }) export class IonicImageCacheComponent { - - avatarbase64:string = ``; - - - srcUrl:string; - imageViewerBigSrcUrl:string; - cache_directory_name:string = this.imageCacheConfig.cacheDirectoryName; - fallback:string = this.imageCacheConfig.fallbackUrl; - altString:string = this.imageCacheConfig.alt; - spinnerNameString:string = this.imageCacheConfig.spinnerName; - spinnerColorString:string = this.imageCacheConfig.spinnerColor; - showPrev:boolean | string = true; - @Input("imgCssClass") imgCssClass:string; - @ViewChild("realImage") realImage: ElementRef; - - _imageViewerCtrl: ImageViewerController; - @Input() set src(value: string) { - - if (!this.platform.is('cordova')) { - this.setImageSrc(value); - // we are running on a browser, or using livereload - // plugin will not function in this case - if(this.imageCacheConfig.debugMode){ - console.log('You are running on a browser or using livereload.'); - } - - }else{ - if(this.helpers.ValidURL(value)){ - this.initialise(value); - }else{ - this.setImageSrc(value); - if(this.imageCacheConfig.debugMode){ - console.log(value + ' is not a remote URL'); + avatarbase64: string = ``; + + srcUrl: string; + imageViewerBigSrcUrl: string; + cache_directory_name: string = this.imageCacheConfig.cacheDirectoryName; + fallback: string = this.imageCacheConfig.fallbackUrl; + altString: string = this.imageCacheConfig.alt; + spinnerNameString: string = this.imageCacheConfig.spinnerName; + spinnerColorString: string = this.imageCacheConfig.spinnerColor; + showPrev: boolean | string = true; + @Input('imgCssClass') imgCssClass: string; + @ViewChild('realImage') realImage: ElementRef; + + _imageViewerCtrl: ImageViewerController; + @Input() set src(value: string) { + if (this.isImageExistsOnServer(value)) { + if (!this.platform.is('cordova')) { + this.setImageSrc(value); + // we are running on a browser, or using livereload + // plugin will not function in this case + if (this.imageCacheConfig.debugMode) { + console.log( + 'You are running on a browser or using livereload.' + ); + } + } else { + if (this.helpers.ValidURL(value)) { + this.initialise(value); + } else { + this.setImageSrc(value); + if (this.imageCacheConfig.debugMode) { + console.log(value + ' is not a remote URL'); + } + } + } + } else { + this.setImageSrc(this.fallback); } - } - } - } - - @Input("clickReturnObj") clickReturnObj:any; - - get src(): string { - return this.srcUrl; - } - - @Input() set highResSrc(value: string) { - this.imageViewerBigSrcUrl = value; - } - - get highResSrc(): string { - return this.imageViewerBigSrcUrl; - } - - @Input() set fallbackUrl(src: string) { - this.fallback = src; - - } - - get fallbackUrl(): string { - return this.imageCacheConfig.fallbackUrl; - } - - //spinnerNameString - - @Input() set spinnerName(text: string) { - this.spinnerNameString = text; - } - - get spinnerName(): string { - return this.imageCacheConfig.spinnerName; - } - - @Input() set spinnerColor(text: string) { - this.spinnerColorString = text; - } - - get spinnerColor(): string { - return this.imageCacheConfig.spinnerColor; - } - - @Input() set alt(text: string) { - - this.altString = text; - } - - get alt(): string { - return this.imageCacheConfig.alt; - } - - @Input() set showPreview(bool: boolean | string) { - - this.showPrev = (bool == "true" || bool == true); - } - - get showPreview(): boolean | string { - return this.showPrev; - } - - @Input() set enableSpinner(bool: boolean | string) { - - this.imageCacheConfig.spinnerEnabled = (bool == "true" || bool == true); - } - - @Input() set isAvatar(bool: boolean | string) { - this.fallback = ((bool == "true" || bool == true) ? this.avatarbase64 : this.fallback); - } - - get enableSpinner(): boolean | string { - return this.imageCacheConfig.spinnerEnabled; - } - - - - @Output() loaded = new EventEmitter(); - @Output() clicked = new EventEmitter(); - constructor(imageViewerCtrl: ImageViewerController, private ngZone:NgZone, public platform: Platform, public imageCacheConfig:IonicImageCacheConfig, private helpers: IonicImageCacheHelperProvider) { - this._imageViewerCtrl = imageViewerCtrl; - } - - presentImage(event,realImage){ - if(this.showPrev == true || this.showPrev == "true"){ - - //Change this to add high res image - let config = {fullResImage: (this.imageViewerBigSrcUrl || this.srcUrl), onCloseCallback: null, enableBackdropDismiss:null}; - const imageViewer = this._imageViewerCtrl.create(realImage, config); - imageViewer.present(); - - imageViewer.onDidDismiss((e) => { - if(this.imageCacheConfig.debugMode){ - console.log(e, "Image viewer closed"); - } - }); - } - this.clicked.emit({clickReturnObj:this.clickReturnObj}); - } - - setImageSrc(nativeURL:string = null, entry:FileEntry = null){ - let url = entry == null ? nativeURL : entry.nativeURL; - if(this.platform.is("cordova")){ - if(this.platform.is("ios")){ - url = this.helpers.safeiOSNativeURL(url); - } + @Input('clickReturnObj') clickReturnObj: any; + + get src(): string { + return this.srcUrl; } - this.ngZone.run(()=>{ - this.srcUrl = url; - setTimeout(() =>{ - this.loaded.emit(this.srcUrl); - },this.helpers.randomIntFromInterval(300, 700)); + @Input() set highResSrc(value: string) { + this.imageViewerBigSrcUrl = value; + } - }) + get highResSrc(): string { + return this.imageViewerBigSrcUrl; + } + @Input() set fallbackUrl(src: string) { + this.fallback = src; + } - + get fallbackUrl(): string { + return this.imageCacheConfig.fallbackUrl; + } - } + //spinnerNameString - imageOnLoad(){ - setTimeout(() =>{ - let realImg:HTMLImageElement = this.realImage.nativeElement; - realImg.addEventListener('loaded', (e) => { - //console.log("image loaddd"); - this.loaded.emit(this.srcUrl); - },false) - },500) - } + @Input() set spinnerName(text: string) { + this.spinnerNameString = text; + } - saveImageToFilesystem(src:string){ - if(this.imageCacheConfig.debugMode){ - console.log("Fetch from server.......", src); + get spinnerName(): string { + return this.imageCacheConfig.spinnerName; } - - this.helpers.downloadImage(src, this.platform, this.cache_directory_name, this.imageCacheConfig.trustAllHosts).then((entry:FileEntry) =>{ - if(this.imageCacheConfig.debugMode){ - console.log("File saved", entry); - } - - this.setImageSrc(entry.nativeURL, entry); - }).catch(err =>{ - if(this.imageCacheConfig.debugMode){ - console.log("Failed to saved file to directory", err); - } - this.setImageSrc(src); - }) - } - - - - clearAllCache(){ - if(this.activeDirectory){ - this.helpers.clearAllCache(this.cache_directory_name, this.platform).then((removeResult:RemoveResult) =>{ - if(this.imageCacheConfig.debugMode){ - console.log(removeResult); - } - - }); + + @Input() set spinnerColor(text: string) { + this.spinnerColorString = text; + } + + get spinnerColor(): string { + return this.imageCacheConfig.spinnerColor; + } + + @Input() set alt(text: string) { + this.altString = text; + } + + get alt(): string { + return this.imageCacheConfig.alt; + } + + @Input() set showPreview(bool: boolean | string) { + this.showPrev = bool == 'true' || bool == true; + } + + get showPreview(): boolean | string { + return this.showPrev; } - } + @Input() set enableSpinner(bool: boolean | string) { + this.imageCacheConfig.spinnerEnabled = bool == 'true' || bool == true; + } + @Input() set isAvatar(bool: boolean | string) { + this.fallback = + bool == 'true' || bool == true ? this.avatarbase64 : this.fallback; + } + get enableSpinner(): boolean | string { + return this.imageCacheConfig.spinnerEnabled; + } + @Output() loaded = new EventEmitter(); + @Output() clicked = new EventEmitter(); + constructor( + imageViewerCtrl: ImageViewerController, + private ngZone: NgZone, + public platform: Platform, + public imageCacheConfig: IonicImageCacheConfig, + private helpers: IonicImageCacheHelperProvider + ) { + this._imageViewerCtrl = imageViewerCtrl; + } - verifyFileAvailability(src:string, dEntry:DirectoryEntry){ + presentImage(event, realImage) { + if (this.showPrev == true || this.showPrev == 'true') { + //Change this to add high res image + let config = { + fullResImage: this.imageViewerBigSrcUrl || this.srcUrl, + onCloseCallback: null, + enableBackdropDismiss: null + }; + const imageViewer = this._imageViewerCtrl.create(realImage, config); + imageViewer.present(); + + imageViewer.onDidDismiss(e => { + if (this.imageCacheConfig.debugMode) { + console.log(e, 'Image viewer closed'); + } + }); + } + this.clicked.emit({ clickReturnObj: this.clickReturnObj }); + } - this.helpers.getFile(dEntry,this.helpers.extractPath(src)).then((entry:FileEntry) =>{ - if(entry != null){ - this.setImageSrc(null, entry); - }else{ - this.saveImageToFilesystem(src); - } - }) - } + setImageSrc(nativeURL: string = null, entry: FileEntry = null) { + let url = entry == null ? nativeURL : entry.nativeURL; + if (this.platform.is('cordova')) { + if (this.platform.is('ios')) { + url = this.helpers.safeiOSNativeURL(url); + } + } - - activeDirectory:DirectoryEntry; - async initialise(src:string){ + this.ngZone.run(() => { + this.srcUrl = url; + setTimeout(() => { + this.loaded.emit(this.srcUrl); + }, this.helpers.randomIntFromInterval(300, 700)); + }); + } - await this.helpers.resolveDirectoryUrl(this.cache_directory_name, this.platform).then((dEntry:DirectoryEntry) =>{ - if(dEntry != null){ - this.activeDirectory = dEntry; - if(this.imageCacheConfig.debugMode){ - console.log(dEntry); + imageOnLoad() { + setTimeout(() => { + let realImg: HTMLImageElement = this.realImage.nativeElement; + realImg.addEventListener( + 'loaded', + e => { + //console.log("image loaddd"); + this.loaded.emit(this.srcUrl); + }, + false + ); + }, 500); + } + + saveImageToFilesystem(src: string) { + if (this.imageCacheConfig.debugMode) { + console.log('Fetch from server.......', src); } - - this.verifyFileAvailability(src, dEntry); - }else{ - this.saveImageToFilesystem(src); - } - }) + this.helpers + .downloadImage( + src, + this.platform, + this.cache_directory_name, + this.imageCacheConfig.trustAllHosts + ) + .then((entry: FileEntry) => { + if (this.imageCacheConfig.debugMode) { + console.log('File saved', entry); + } + + this.setImageSrc(entry.nativeURL, entry); + }) + .catch(err => { + if (this.imageCacheConfig.debugMode) { + console.log('Failed to saved file to directory', err); + } + this.setImageSrc(src); + }); + } - } + clearAllCache() { + if (this.activeDirectory) { + this.helpers + .clearAllCache(this.cache_directory_name, this.platform) + .then((removeResult: RemoveResult) => { + if (this.imageCacheConfig.debugMode) { + console.log(removeResult); + } + }); + } + } + verifyFileAvailability(src: string, dEntry: DirectoryEntry) { + this.helpers + .getFile(dEntry, this.helpers.extractPath(src)) + .then((entry: FileEntry) => { + if (entry != null) { + this.setImageSrc(null, entry); + } else { + this.saveImageToFilesystem(src); + } + }); + } + activeDirectory: DirectoryEntry; + async initialise(src: string) { + await this.helpers + .resolveDirectoryUrl(this.cache_directory_name, this.platform) + .then((dEntry: DirectoryEntry) => { + if (dEntry != null) { + this.activeDirectory = dEntry; + if (this.imageCacheConfig.debugMode) { + console.log(dEntry); + } + + this.verifyFileAvailability(src, dEntry); + } else { + this.saveImageToFilesystem(src); + } + }); + } + + isImageExistsOnServer(image_url) { + var http = new XMLHttpRequest(); + http.open('HEAD', image_url, false); + http.send(); + + return http.status != 404; + } }