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;
+ }
}