imgcache.js icon indicating copy to clipboard operation
imgcache.js copied to clipboard

[ionic 4.0.0] Failed to load resource: net::ERR_UNKNOWN_URL_SCHEME

Open thenaim opened this issue 6 years ago • 5 comments

error link: cdvfile://localhost/persistent/imgcache/58f0fa6c8f79117ebbc575b1214450e63a7563d1.jpeg screenshot

Ps: I took all the steps CORDOVA.md, but still does not work and do not understand what the problem is. Pss: running app on android device

app.component.ts

this.platform.ready().then(() => {
    ...
    ImgCache.options.chromeQuota = 50 * 1024 * 1024;
    ImgCache.init(() => {
      console.log('OK');
    }, () => {
      console.log('ERROR');
    });
    ...
});

image-cache.directive.ts

import { Directive, ElementRef, OnInit } from '@angular/core';

declare var ImgCache: any;

@Directive({
  selector: '[appImageCache]'
})
export class ImageCacheDirective implements OnInit {
  constructor(
    private el: ElementRef
  ) { }

  ngOnInit() {
    ImgCache.isCached(this.el.nativeElement.src, (path: string, success: boolean) => {
      if (success) {
        ImgCache.useCachedFile(this.el.nativeElement);
      } else {
        ImgCache.cacheFile(this.el.nativeElement.src, () => {
          ImgCache.useCachedFile(this.el.nativeElement);
        });
      }
    });
  }
}

$ ionic info

Ionic:

   ionic (Ionic CLI)             : 4.9.0 (/usr/local/lib/node_modules/ionic)
   Ionic Framework               : @ionic/angular 4.0.0
   @angular-devkit/build-angular : 0.12.4
   @angular-devkit/schematics    : 7.2.4
   @angular/cli                  : 7.2.4
   @ionic/angular-toolkit        : 1.2.3

Cordova:

   cordova (Cordova CLI) : 8.1.2 ([email protected])
   Cordova Platforms     : android 7.1.4, browser 5.0.4, ios 4.5.5
   Cordova Plugins       : cordova-plugin-ionic-keyboard 2.1.3, cordova-plugin-ionic-webview 2.3.2, (and 30 other plugins)

System:

   Android SDK Tools : 26.1.1 (/home/ubuntu/Android/Sdk)
   NodeJS            : v10.14.2 (/usr/local/bin/node)
   npm               : 6.7.0
   OS                : Linux 4.15

thenaim avatar Feb 03 '19 15:02 thenaim

I'm facing the same issue

syedsaadqamar avatar May 23 '19 17:05 syedsaadqamar

@chrisben , do you have any thoughts on this issue? it seems to be blocking us from implementing the image cache :/

AhsanAyaz avatar May 26 '19 21:05 AhsanAyaz

@bossjon , I've resolved the issue by creating a function and utilizingresolveLocalFileSystemURL as follows:

actuallyNormalize(cacheUrl) {
    return new Promise((resolve, reject) => {
      window.resolveLocalFileSystemURL(cacheUrl, (entry: any) => {
        cacheUrl = entry.toURL();
        const ionicNormalizer = window['Ionic'] &&
          ((window['Ionic'].WebView && window['Ionic'].WebView.convertFileSrc) || window['Ionic'].normalizeURL);
        if (typeof ionicNormalizer === 'function') {
          cacheUrl = ionicNormalizer(cacheUrl);
          resolve(cacheUrl);
        } else {
          reject('could not find cache url');
        }
      });
    });
  }

Modified the cache function as below:

/**
   * Cache is image by using a url. If the image is already cached this method
   * will return the URL
   * @param src {string}
   */
  public cache(src: string): Observable<string> {
    return this.notifier$.pipe(
      switchMapTo(
        this.isCached(src)
          .pipe(
            flatMap(([path, success]: [string, boolean]) => {
              return success ? this.getCachedFileURL(path) : this.cacheFile(path);
            }),
            mergeMap((url: string) => {
              if (this.platform.is('ios')) {
                return of(this.normalizeURlWKWview(url));
              } else if (this.platform.is('cordova')) {
                return from(this.actuallyNormalize(url));
              }
            }),
            map((url: string) => {
              return url;
            })
          )
      )
    );
  }

Note that I'm using from and of operators from rxjs.

import { from, of } from 'rxjs';

AhsanAyaz avatar May 27 '19 11:05 AhsanAyaz

I am facing the same issue so I have changed in code while returning URL from getLocalCacheUrl method and need to replace because now we need URL in this format

http://localhost:8080/app_file/'YOUR_PROJECT_STORAGE_LOCATION'/imgcache/58f0fa6c8f79117ebbc575b1214450e63a7563d1.jpeg

ravi9376 avatar Aug 17 '19 17:08 ravi9376

2+ weeks of work right here to determine that;

On iOS, the problem is the version of imgcache. The latest is 2.1.1, and using that with webview 2.5.2, the map crashes with custom avatar. Reverting to imgcache version 2.0.0 (which is what we used previously), causes the map avatar to show without the map crashing on iOS. On Android, reverting imgcache alone doesn't fix the problem. Reverting from webview plugin version 2.5.2 to 2.5.1 ixes the issue (map avatar shows and app doesn't crash). However, reverting to 2.4.0 didn't fix the issue. This may explain why some older builds didn't work that formerly did, until we were using webview plugin version 2.4.0.

tryhardest avatar Feb 06 '20 20:02 tryhardest