2018-03-30 15:30:30 -04:00
|
|
|
import {Injectable} from '@angular/core';
|
2018-12-08 18:17:33 +01:00
|
|
|
import {ThumbnailLoaderService, ThumbnailLoadingListener, ThumbnailLoadingPriority, ThumbnailTaskEntity} from './thumbnailLoader.service';
|
2018-11-04 19:28:32 +01:00
|
|
|
import {Media} from './Media';
|
|
|
|
import {MediaIcon} from './MediaIcon';
|
2017-03-20 00:01:41 +01:00
|
|
|
|
|
|
|
|
|
|
|
@Injectable()
|
|
|
|
export class ThumbnailManagerService {
|
|
|
|
|
|
|
|
|
2017-06-10 22:32:56 +02:00
|
|
|
constructor(private thumbnailLoader: ThumbnailLoaderService) {
|
|
|
|
}
|
2017-03-20 00:01:41 +01:00
|
|
|
|
2018-11-04 19:28:32 +01:00
|
|
|
public getThumbnail(photo: Media): Thumbnail {
|
2017-06-10 22:32:56 +02:00
|
|
|
return new Thumbnail(photo, this.thumbnailLoader);
|
|
|
|
}
|
2017-03-20 21:37:23 +01:00
|
|
|
|
2018-11-04 19:28:32 +01:00
|
|
|
public getLazyThumbnail(photo: Media): Thumbnail {
|
2017-07-23 22:36:53 +02:00
|
|
|
return new Thumbnail(photo, this.thumbnailLoader, false);
|
|
|
|
}
|
|
|
|
|
2017-03-20 21:37:23 +01:00
|
|
|
|
2018-11-04 19:28:32 +01:00
|
|
|
public getIcon(photo: MediaIcon) {
|
2017-06-10 22:32:56 +02:00
|
|
|
return new IconThumbnail(photo, this.thumbnailLoader);
|
|
|
|
}
|
2017-03-20 21:37:23 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
export abstract class ThumbnailBase {
|
|
|
|
|
2018-05-12 12:19:51 -04:00
|
|
|
protected available = false;
|
2017-06-10 22:32:56 +02:00
|
|
|
protected src: string = null;
|
2018-11-02 10:40:09 +01:00
|
|
|
public loading = false;
|
2018-05-12 12:19:51 -04:00
|
|
|
protected error = false;
|
2017-06-10 22:32:56 +02:00
|
|
|
protected onLoad: Function = null;
|
2017-07-23 22:36:53 +02:00
|
|
|
protected thumbnailTask: ThumbnailTaskEntity = null;
|
2017-03-20 21:37:23 +01:00
|
|
|
|
|
|
|
|
2018-05-12 12:19:51 -04:00
|
|
|
protected constructor(protected thumbnailService: ThumbnailLoaderService) {
|
2017-06-10 22:32:56 +02:00
|
|
|
}
|
2017-03-20 21:37:23 +01:00
|
|
|
|
2017-06-10 22:32:56 +02:00
|
|
|
abstract set Visible(visible: boolean);
|
2017-03-20 21:37:23 +01:00
|
|
|
|
2017-06-10 22:32:56 +02:00
|
|
|
set OnLoad(onLoad: Function) {
|
|
|
|
this.onLoad = onLoad;
|
|
|
|
}
|
2017-03-20 21:37:23 +01:00
|
|
|
|
|
|
|
|
2017-07-17 23:11:35 +02:00
|
|
|
get Available(): boolean {
|
2017-06-10 22:32:56 +02:00
|
|
|
return this.available;
|
|
|
|
}
|
2017-03-20 21:37:23 +01:00
|
|
|
|
2017-07-17 23:11:35 +02:00
|
|
|
get Src(): string {
|
2017-06-10 22:32:56 +02:00
|
|
|
return this.src;
|
|
|
|
}
|
2017-03-20 21:37:23 +01:00
|
|
|
|
2017-07-17 23:11:35 +02:00
|
|
|
get Loading(): boolean {
|
2017-06-10 22:32:56 +02:00
|
|
|
return this.loading;
|
|
|
|
}
|
2017-03-20 21:37:23 +01:00
|
|
|
|
2017-07-17 23:11:35 +02:00
|
|
|
get Error(): boolean {
|
|
|
|
return this.error;
|
|
|
|
}
|
|
|
|
|
2017-06-10 22:32:56 +02:00
|
|
|
destroy() {
|
|
|
|
if (this.thumbnailTask != null) {
|
|
|
|
this.thumbnailService.removeTask(this.thumbnailTask);
|
|
|
|
this.thumbnailTask = null;
|
2017-03-20 21:37:23 +01:00
|
|
|
}
|
2017-06-10 22:32:56 +02:00
|
|
|
}
|
2017-03-20 00:01:41 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-03-20 21:37:23 +01:00
|
|
|
export class IconThumbnail extends ThumbnailBase {
|
2017-03-20 00:01:41 +01:00
|
|
|
|
2018-11-04 19:28:32 +01:00
|
|
|
constructor(private media: MediaIcon, thumbnailService: ThumbnailLoaderService) {
|
2017-06-10 22:32:56 +02:00
|
|
|
super(thumbnailService);
|
2018-03-30 15:30:30 -04:00
|
|
|
this.src = '';
|
2017-06-21 21:16:04 +02:00
|
|
|
this.error = false;
|
2018-11-04 19:28:32 +01:00
|
|
|
if (this.media.isIconAvailable()) {
|
|
|
|
this.src = this.media.getIconPath();
|
2017-06-10 22:32:56 +02:00
|
|
|
this.available = true;
|
2018-05-12 12:19:51 -04:00
|
|
|
if (this.onLoad) {
|
|
|
|
this.onLoad();
|
|
|
|
}
|
2017-06-10 22:32:56 +02:00
|
|
|
}
|
|
|
|
|
2018-11-04 19:28:32 +01:00
|
|
|
if (!this.media.isIconAvailable()) {
|
2017-06-10 22:56:23 +02:00
|
|
|
setTimeout(() => {
|
2017-06-10 22:32:56 +02:00
|
|
|
|
2018-05-12 12:19:51 -04:00
|
|
|
const listener: ThumbnailLoadingListener = {
|
|
|
|
onStartedLoading: () => { // onLoadStarted
|
2017-06-10 22:32:56 +02:00
|
|
|
this.loading = true;
|
|
|
|
},
|
2018-05-12 12:19:51 -04:00
|
|
|
onLoad: () => {// onLoaded
|
2018-11-04 19:28:32 +01:00
|
|
|
this.src = this.media.getIconPath();
|
2018-05-12 12:19:51 -04:00
|
|
|
if (this.onLoad) {
|
|
|
|
this.onLoad();
|
|
|
|
}
|
2017-06-10 22:32:56 +02:00
|
|
|
this.available = true;
|
|
|
|
this.loading = false;
|
|
|
|
this.thumbnailTask = null;
|
|
|
|
},
|
2018-12-08 18:17:33 +01:00
|
|
|
onError: () => {// onError
|
2017-06-10 22:32:56 +02:00
|
|
|
this.thumbnailTask = null;
|
2017-06-21 21:16:04 +02:00
|
|
|
this.loading = false;
|
|
|
|
this.error = true;
|
2017-06-10 22:32:56 +02:00
|
|
|
}
|
|
|
|
};
|
2018-11-04 19:28:32 +01:00
|
|
|
this.thumbnailTask = this.thumbnailService.loadIcon(this.media, ThumbnailLoadingPriority.high, listener);
|
2017-03-20 00:01:41 +01:00
|
|
|
|
2017-03-20 21:37:23 +01:00
|
|
|
|
2017-06-10 22:56:23 +02:00
|
|
|
}, 0);
|
2017-03-20 21:37:23 +01:00
|
|
|
}
|
|
|
|
|
2017-06-10 22:32:56 +02:00
|
|
|
}
|
2017-03-20 21:37:23 +01:00
|
|
|
|
2017-06-10 22:32:56 +02:00
|
|
|
set Visible(visible: boolean) {
|
2018-05-12 12:19:51 -04:00
|
|
|
if (!this.thumbnailTask) {
|
|
|
|
return;
|
|
|
|
}
|
2017-06-10 22:32:56 +02:00
|
|
|
if (visible === true) {
|
|
|
|
this.thumbnailTask.priority = ThumbnailLoadingPriority.high;
|
|
|
|
} else {
|
|
|
|
this.thumbnailTask.priority = ThumbnailLoadingPriority.medium;
|
2017-03-20 21:37:23 +01:00
|
|
|
}
|
2017-06-10 22:32:56 +02:00
|
|
|
}
|
|
|
|
|
2017-03-20 21:37:23 +01:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
export class Thumbnail extends ThumbnailBase {
|
|
|
|
|
|
|
|
|
2018-11-04 19:28:32 +01:00
|
|
|
constructor(private media: Media, thumbnailService: ThumbnailLoaderService, autoLoad: boolean = true) {
|
2017-06-10 22:32:56 +02:00
|
|
|
super(thumbnailService);
|
2018-11-04 19:28:32 +01:00
|
|
|
if (this.media.isThumbnailAvailable()) {
|
|
|
|
this.src = this.media.getThumbnailPath();
|
2017-06-10 22:32:56 +02:00
|
|
|
this.available = true;
|
2018-05-12 12:19:51 -04:00
|
|
|
if (this.onLoad) {
|
|
|
|
this.onLoad();
|
|
|
|
}
|
2018-11-04 19:28:32 +01:00
|
|
|
} else if (this.media.isReplacementThumbnailAvailable()) {
|
|
|
|
this.src = this.media.getReplacementThumbnailPath();
|
2017-06-10 22:32:56 +02:00
|
|
|
this.available = true;
|
|
|
|
}
|
2017-07-23 22:36:53 +02:00
|
|
|
if (autoLoad) {
|
|
|
|
this.load();
|
|
|
|
}
|
|
|
|
}
|
2017-06-10 22:32:56 +02:00
|
|
|
|
2017-07-25 23:40:07 +02:00
|
|
|
set CurrentlyWaiting(value: boolean) {
|
2018-05-12 12:19:51 -04:00
|
|
|
if (!this.thumbnailTask) {
|
|
|
|
return;
|
|
|
|
}
|
2017-07-25 23:40:07 +02:00
|
|
|
if (value === true) {
|
2018-11-04 19:28:32 +01:00
|
|
|
if (this.media.isReplacementThumbnailAvailable()) {
|
2017-07-25 23:40:07 +02:00
|
|
|
this.thumbnailTask.priority = ThumbnailLoadingPriority.medium;
|
|
|
|
} else {
|
|
|
|
this.thumbnailTask.priority = ThumbnailLoadingPriority.extraHigh;
|
|
|
|
}
|
|
|
|
} else {
|
2018-11-04 19:28:32 +01:00
|
|
|
if (this.media.isReplacementThumbnailAvailable()) {
|
2017-07-25 23:40:07 +02:00
|
|
|
this.thumbnailTask.priority = ThumbnailLoadingPriority.low;
|
|
|
|
} else {
|
|
|
|
this.thumbnailTask.priority = ThumbnailLoadingPriority.medium;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-05-12 12:19:51 -04:00
|
|
|
set Visible(visible: boolean) {
|
|
|
|
if (!this.thumbnailTask) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (visible === true) {
|
2018-11-04 19:28:32 +01:00
|
|
|
if (this.media.isReplacementThumbnailAvailable()) {
|
2018-05-12 12:19:51 -04:00
|
|
|
this.thumbnailTask.priority = ThumbnailLoadingPriority.medium;
|
|
|
|
} else {
|
|
|
|
this.thumbnailTask.priority = ThumbnailLoadingPriority.high;
|
|
|
|
}
|
|
|
|
} else {
|
2018-11-04 19:28:32 +01:00
|
|
|
if (this.media.isReplacementThumbnailAvailable()) {
|
2018-05-12 12:19:51 -04:00
|
|
|
this.thumbnailTask.priority = ThumbnailLoadingPriority.low;
|
|
|
|
} else {
|
|
|
|
this.thumbnailTask.priority = ThumbnailLoadingPriority.medium;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-07-23 22:36:53 +02:00
|
|
|
public load() {
|
2018-11-04 19:28:32 +01:00
|
|
|
if (!this.media.isThumbnailAvailable() && this.thumbnailTask == null) {
|
2017-07-25 23:40:07 +02:00
|
|
|
// setTimeout(() => {
|
2018-05-12 12:19:51 -04:00
|
|
|
const listener: ThumbnailLoadingListener = {
|
|
|
|
onStartedLoading: () => { // onLoadStarted
|
2018-03-30 15:30:30 -04:00
|
|
|
this.loading = true;
|
|
|
|
},
|
2018-05-12 12:19:51 -04:00
|
|
|
onLoad: () => {// onLoaded
|
2018-11-04 19:28:32 +01:00
|
|
|
this.src = this.media.getThumbnailPath();
|
2018-05-12 12:19:51 -04:00
|
|
|
if (this.onLoad) {
|
|
|
|
this.onLoad();
|
|
|
|
}
|
2018-03-30 15:30:30 -04:00
|
|
|
this.available = true;
|
|
|
|
this.loading = false;
|
|
|
|
this.thumbnailTask = null;
|
|
|
|
},
|
2018-12-08 18:17:33 +01:00
|
|
|
onError: () => {// onError
|
2018-03-30 15:30:30 -04:00
|
|
|
this.thumbnailTask = null;
|
|
|
|
this.loading = false;
|
|
|
|
this.error = true;
|
2017-03-20 00:01:41 +01:00
|
|
|
}
|
2018-03-30 15:30:30 -04:00
|
|
|
};
|
2018-11-04 19:28:32 +01:00
|
|
|
if (this.media.isReplacementThumbnailAvailable()) {
|
|
|
|
this.thumbnailTask = this.thumbnailService.loadImage(this.media, ThumbnailLoadingPriority.medium, listener);
|
2018-03-30 15:30:30 -04:00
|
|
|
} else {
|
2018-11-04 19:28:32 +01:00
|
|
|
this.thumbnailTask = this.thumbnailService.loadImage(this.media, ThumbnailLoadingPriority.high, listener);
|
2018-03-30 15:30:30 -04:00
|
|
|
}
|
2017-07-25 23:40:07 +02:00
|
|
|
// }, 0);
|
2017-03-20 00:01:41 +01:00
|
|
|
}
|
2017-06-10 22:32:56 +02:00
|
|
|
}
|
|
|
|
|
2017-03-20 00:01:41 +01:00
|
|
|
}
|
|
|
|
|