mirror of
https://github.com/DSpace/dspace-angular.git
synced 2025-10-13 13:03:04 +00:00
#0 fix thumbnail
This commit is contained in:
@@ -1,3 +1,10 @@
|
|||||||
<div class="thumbnail">
|
<div class="thumbnail" *ngVar="src$ | async as src">
|
||||||
<img [src]="src | dsSafeUrl" (error)="errorHandler($event)"/>
|
<ds-loading
|
||||||
|
*ngIf="!src"
|
||||||
|
message="{{ 'loading.default' | translate }}"
|
||||||
|
[showMessage]="false"
|
||||||
|
></ds-loading>
|
||||||
|
<ng-container *ngIf="src">
|
||||||
|
<img [src]="src | dsSafeUrl" (error)="errorHandler($event)" />
|
||||||
|
</ng-container>
|
||||||
</div>
|
</div>
|
||||||
|
@@ -1,4 +1,6 @@
|
|||||||
import { Component, Input, OnInit } from '@angular/core';
|
import { Component, Input, OnInit } from '@angular/core';
|
||||||
|
import { BehaviorSubject, Observable, isObservable } from 'rxjs';
|
||||||
|
import { RemoteData } from '../../../core/data/remote-data';
|
||||||
import { Bitstream } from '../../../core/shared/bitstream.model';
|
import { Bitstream } from '../../../core/shared/bitstream.model';
|
||||||
import { hasValue } from '../../empty.util';
|
import { hasValue } from '../../empty.util';
|
||||||
|
|
||||||
@@ -11,30 +13,45 @@ import { hasValue } from '../../empty.util';
|
|||||||
@Component({
|
@Component({
|
||||||
selector: 'ds-grid-thumbnail',
|
selector: 'ds-grid-thumbnail',
|
||||||
styleUrls: ['./grid-thumbnail.component.scss'],
|
styleUrls: ['./grid-thumbnail.component.scss'],
|
||||||
templateUrl: './grid-thumbnail.component.html'
|
templateUrl: './grid-thumbnail.component.html',
|
||||||
})
|
})
|
||||||
export class GridThumbnailComponent implements OnInit {
|
export class GridThumbnailComponent implements OnInit {
|
||||||
|
@Input() thumbnail: string | Observable<RemoteData<Bitstream>>;
|
||||||
@Input() thumbnail: Bitstream;
|
|
||||||
|
|
||||||
data: any = {};
|
data: any = {};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The default 'holder.js' image
|
* The default 'holder.js' image
|
||||||
*/
|
*/
|
||||||
@Input() defaultImage? = '';
|
@Input() defaultImage? =
|
||||||
|
'';
|
||||||
|
|
||||||
src: string;
|
src$: BehaviorSubject<string>;
|
||||||
errorHandler(event) {
|
errorHandler(event) {
|
||||||
event.currentTarget.src = this.defaultImage;
|
event.currentTarget.src = this.defaultImage;
|
||||||
}
|
}
|
||||||
|
|
||||||
ngOnInit(): void {
|
ngOnInit(): void {
|
||||||
if (hasValue(this.thumbnail) && hasValue(this.thumbnail._links) && this.thumbnail._links.content.href) {
|
this.src$ = new BehaviorSubject<string>(this.defaultImage);
|
||||||
this.src = this.thumbnail._links.content.href;
|
console.log('this.thumbnail', this.thumbnail);
|
||||||
|
if (isObservable(this.thumbnail)) {
|
||||||
|
this.thumbnail.subscribe((thumbnailRD) => {
|
||||||
|
this.checkThumbnail(thumbnailRD.payload);
|
||||||
|
});
|
||||||
} else {
|
} else {
|
||||||
this.src = this.defaultImage
|
if (this.thumbnail) {
|
||||||
|
this.src$.next(this.thumbnail);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
checkThumbnail(thumbnail: Bitstream) {
|
||||||
|
if (
|
||||||
|
hasValue(thumbnail) &&
|
||||||
|
hasValue(thumbnail._links) &&
|
||||||
|
thumbnail._links.content.href
|
||||||
|
) {
|
||||||
|
this.src$.next(thumbnail._links.content.href);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@@ -4,13 +4,13 @@
|
|||||||
<a *ngIf="linkType != linkTypes.None" [target]="(linkType == linkTypes.ExternalLink) ? '_blank' : '_self'" rel="noopener noreferrer" [routerLink]="['/items/' + dso.id]"
|
<a *ngIf="linkType != linkTypes.None" [target]="(linkType == linkTypes.ExternalLink) ? '_blank' : '_self'" rel="noopener noreferrer" [routerLink]="['/items/' + dso.id]"
|
||||||
class="card-img-top full-width">
|
class="card-img-top full-width">
|
||||||
<div>
|
<div>
|
||||||
<ds-grid-thumbnail [thumbnail]="getThumbnail() | async">
|
<ds-grid-thumbnail [thumbnail]="getThumbnail()">
|
||||||
</ds-grid-thumbnail>
|
</ds-grid-thumbnail>
|
||||||
</div>
|
</div>
|
||||||
</a>
|
</a>
|
||||||
<span *ngIf="linkType == linkTypes.None" class="card-img-top full-width">
|
<span *ngIf="linkType == linkTypes.None" class="card-img-top full-width">
|
||||||
<div>
|
<div>
|
||||||
<ds-grid-thumbnail [thumbnail]="getThumbnail() | async">
|
<ds-grid-thumbnail [thumbnail]="getThumbnail()">
|
||||||
</ds-grid-thumbnail>
|
</ds-grid-thumbnail>
|
||||||
</div>
|
</div>
|
||||||
</span>
|
</span>
|
||||||
|
@@ -6,10 +6,11 @@ import { BitstreamDataService } from '../../../core/data/bitstream-data.service'
|
|||||||
import { Bitstream } from '../../../core/shared/bitstream.model';
|
import { Bitstream } from '../../../core/shared/bitstream.model';
|
||||||
import { DSpaceObject } from '../../../core/shared/dspace-object.model';
|
import { DSpaceObject } from '../../../core/shared/dspace-object.model';
|
||||||
import { Metadata } from '../../../core/shared/metadata.utils';
|
import { Metadata } from '../../../core/shared/metadata.utils';
|
||||||
import { getFirstSucceededRemoteDataPayload } from '../../../core/shared/operators';
|
|
||||||
import { hasValue } from '../../empty.util';
|
import { hasValue } from '../../empty.util';
|
||||||
import { AbstractListableElementComponent } from '../../object-collection/shared/object-collection-element/abstract-listable-element.component';
|
import { AbstractListableElementComponent } from '../../object-collection/shared/object-collection-element/abstract-listable-element.component';
|
||||||
import { TruncatableService } from '../../truncatable/truncatable.service';
|
import { TruncatableService } from '../../truncatable/truncatable.service';
|
||||||
|
import { RemoteData } from '../../../core/data/remote-data';
|
||||||
|
import { filter, map } from 'rxjs/operators';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'ds-search-result-grid-element',
|
selector: 'ds-search-result-grid-element',
|
||||||
@@ -42,7 +43,9 @@ export class SearchResultGridElementComponent<T extends SearchResult<K>, K exten
|
|||||||
*/
|
*/
|
||||||
ngOnInit(): void {
|
ngOnInit(): void {
|
||||||
if (hasValue(this.object)) {
|
if (hasValue(this.object)) {
|
||||||
|
console.log(this.object)
|
||||||
this.dso = this.object.indexableObject;
|
this.dso = this.object.indexableObject;
|
||||||
|
console.log('this.dso',this.dso)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -71,9 +74,7 @@ export class SearchResultGridElementComponent<T extends SearchResult<K>, K exten
|
|||||||
}
|
}
|
||||||
|
|
||||||
// TODO refactor to return RemoteData, and thumbnail template to deal with loading
|
// TODO refactor to return RemoteData, and thumbnail template to deal with loading
|
||||||
getThumbnail(): Observable<Bitstream> {
|
getThumbnail(): Observable<RemoteData<Bitstream>> {
|
||||||
return this.bitstreamDataService.getThumbnailFor(this.dso as any).pipe(
|
return this.bitstreamDataService.getThumbnailFor(this.dso as any);
|
||||||
getFirstSucceededRemoteDataPayload()
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user