mirror of
https://github.com/DSpace/dspace-angular.git
synced 2025-10-07 01:54:15 +00:00
182 lines
6.0 KiB
TypeScript
182 lines
6.0 KiB
TypeScript
import {
|
|
AsyncPipe,
|
|
NgForOf,
|
|
NgIf,
|
|
} from '@angular/common';
|
|
import {
|
|
Component,
|
|
OnDestroy,
|
|
OnInit,
|
|
} from '@angular/core';
|
|
import { RouterLink } from '@angular/router';
|
|
import {
|
|
TranslateModule,
|
|
TranslateService,
|
|
} from '@ngx-translate/core';
|
|
import { Observable } from 'rxjs';
|
|
import {
|
|
map,
|
|
mergeMap,
|
|
switchMap,
|
|
take,
|
|
toArray,
|
|
} from 'rxjs/operators';
|
|
|
|
import { BitstreamFormatDataService } from '../../../core/data/bitstream-format-data.service';
|
|
import { FindListOptions } from '../../../core/data/find-list-options.model';
|
|
import { PaginatedList } from '../../../core/data/paginated-list.model';
|
|
import { RemoteData } from '../../../core/data/remote-data';
|
|
import { PaginationService } from '../../../core/pagination/pagination.service';
|
|
import { BitstreamFormat } from '../../../core/shared/bitstream-format.model';
|
|
import { NoContent } from '../../../core/shared/NoContent.model';
|
|
import { getFirstCompletedRemoteData } from '../../../core/shared/operators';
|
|
import { NotificationsService } from '../../../shared/notifications/notifications.service';
|
|
import { PaginationComponent } from '../../../shared/pagination/pagination.component';
|
|
import { PaginationComponentOptions } from '../../../shared/pagination/pagination-component-options.model';
|
|
|
|
/**
|
|
* This component renders a list of bitstream formats
|
|
*/
|
|
@Component({
|
|
selector: 'ds-bitstream-formats',
|
|
templateUrl: './bitstream-formats.component.html',
|
|
imports: [
|
|
NgIf,
|
|
AsyncPipe,
|
|
RouterLink,
|
|
TranslateModule,
|
|
PaginationComponent,
|
|
NgForOf,
|
|
],
|
|
standalone: true,
|
|
})
|
|
export class BitstreamFormatsComponent implements OnInit, OnDestroy {
|
|
|
|
/**
|
|
* A paginated list of bitstream formats to be shown on the page
|
|
*/
|
|
bitstreamFormats$: Observable<RemoteData<PaginatedList<BitstreamFormat>>>;
|
|
|
|
/**
|
|
* The currently selected {@link BitstreamFormat} IDs
|
|
*/
|
|
selectedBitstreamFormatIDs$: Observable<string[]>;
|
|
|
|
/**
|
|
* The current pagination configuration for the page
|
|
* Currently simply renders all bitstream formats
|
|
*/
|
|
pageConfig: PaginationComponentOptions = Object.assign(new PaginationComponentOptions(), {
|
|
id: 'rbp',
|
|
pageSize: 20,
|
|
pageSizeOptions: [20, 40, 60, 80, 100],
|
|
});
|
|
|
|
constructor(private notificationsService: NotificationsService,
|
|
private translateService: TranslateService,
|
|
private bitstreamFormatService: BitstreamFormatDataService,
|
|
private paginationService: PaginationService,
|
|
) {
|
|
}
|
|
|
|
|
|
/**
|
|
* Deletes the currently selected formats from the registry and updates the presented list
|
|
*/
|
|
deleteFormats() {
|
|
this.bitstreamFormatService.clearBitStreamFormatRequests();
|
|
this.bitstreamFormatService.getSelectedBitstreamFormats().pipe(
|
|
take(1),
|
|
// emit all formats in the array one at a time
|
|
mergeMap((formats: BitstreamFormat[]) => formats),
|
|
// delete each format
|
|
mergeMap((format: BitstreamFormat) => this.bitstreamFormatService.delete(format.id).pipe(
|
|
// wait for each response to come back
|
|
getFirstCompletedRemoteData(),
|
|
// return a boolean to indicate whether a response succeeded
|
|
map((response: RemoteData<NoContent>) => response.hasSucceeded),
|
|
)),
|
|
// wait for all responses to come in and return them as a single array
|
|
toArray(),
|
|
).subscribe((results: boolean[]) => {
|
|
// Count the number of succeeded and failed deletions
|
|
const successResponses = results.filter((result: boolean) => result);
|
|
const failedResponses = results.filter((result: boolean) => !result);
|
|
|
|
// Show a notification indicating the number of succeeded and failed deletions
|
|
if (successResponses.length > 0) {
|
|
this.showNotification(true, successResponses.length);
|
|
}
|
|
if (failedResponses.length > 0) {
|
|
this.showNotification(false, failedResponses.length);
|
|
}
|
|
|
|
// reset the selection
|
|
this.deselectAll();
|
|
|
|
// reload the page
|
|
this.paginationService.resetPage(this.pageConfig.id);
|
|
});
|
|
}
|
|
|
|
/**
|
|
* Deselects all selecetd bitstream formats
|
|
*/
|
|
deselectAll() {
|
|
this.bitstreamFormatService.deselectAllBitstreamFormats();
|
|
}
|
|
|
|
/**
|
|
* Returns the list of all the bitstream formats that are selected in the list (checkbox)
|
|
*/
|
|
selectedBitstreamFormatIDs(): Observable<string[]> {
|
|
return this.bitstreamFormatService.getSelectedBitstreamFormats().pipe(
|
|
map((bitstreamFormats: BitstreamFormat[]) => bitstreamFormats.map((selectedFormat) => selectedFormat.id)),
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Selects or deselects a bitstream format based on the checkbox state
|
|
* @param bitstreamFormat
|
|
* @param event
|
|
*/
|
|
selectBitStreamFormat(bitstreamFormat: BitstreamFormat, event) {
|
|
event.target.checked ?
|
|
this.bitstreamFormatService.selectBitstreamFormat(bitstreamFormat) :
|
|
this.bitstreamFormatService.deselectBitstreamFormat(bitstreamFormat);
|
|
}
|
|
|
|
/**
|
|
* Show notifications for an amount of deleted bitstream formats
|
|
* @param success Whether or not the notification should be a success message (error message when false)
|
|
* @param amount The amount of deleted bitstream formats
|
|
*/
|
|
private showNotification(success: boolean, amount: number) {
|
|
const prefix = 'admin.registries.bitstream-formats.delete';
|
|
const suffix = success ? 'success' : 'failure';
|
|
|
|
const head: string = this.translateService.instant(`${prefix}.${suffix}.head`);
|
|
const content: string = this.translateService.instant(`${prefix}.${suffix}.amount`, { amount: amount });
|
|
|
|
if (success) {
|
|
this.notificationsService.success(head, content);
|
|
} else {
|
|
this.notificationsService.error(head, content);
|
|
}
|
|
}
|
|
|
|
ngOnInit(): void {
|
|
this.bitstreamFormats$ = this.paginationService.getFindListOptions(this.pageConfig.id, this.pageConfig).pipe(
|
|
switchMap((findListOptions: FindListOptions) => {
|
|
return this.bitstreamFormatService.findAll(findListOptions);
|
|
}),
|
|
);
|
|
this.selectedBitstreamFormatIDs$ = this.selectedBitstreamFormatIDs();
|
|
}
|
|
|
|
|
|
ngOnDestroy(): void {
|
|
this.paginationService.clearPagination(this.pageConfig.id);
|
|
}
|
|
}
|