mirror of
https://github.com/DSpace/dspace-angular.git
synced 2025-10-07 18:14:17 +00:00
480 lines
12 KiB
TypeScript
480 lines
12 KiB
TypeScript
import { Component, Injector, OnInit } from '@angular/core';
|
|
import { Observable } from 'rxjs/internal/Observable';
|
|
import { slide, slideHorizontal, slideSidebar } from '../../shared/animations/slide';
|
|
import { CSSVariableService } from '../../shared/sass-helper/sass-helper.service';
|
|
import { MenuService } from '../../shared/menu/menu.service';
|
|
import { MenuID, MenuItemType } from '../../shared/menu/initial-menus-state';
|
|
import { MenuComponent } from '../../shared/menu/menu.component';
|
|
import { TextMenuItemModel } from '../../shared/menu/menu-item/models/text.model';
|
|
import { LinkMenuItemModel } from '../../shared/menu/menu-item/models/link.model';
|
|
import { AuthService } from '../../core/auth/auth.service';
|
|
import { first, map } from 'rxjs/operators';
|
|
import { combineLatest as combineLatestObservable } from 'rxjs';
|
|
|
|
/**
|
|
* Component representing the admin sidebar
|
|
*/
|
|
@Component({
|
|
selector: 'ds-admin-sidebar',
|
|
templateUrl: './admin-sidebar.component.html',
|
|
styleUrls: ['./admin-sidebar.component.scss'],
|
|
animations: [slideHorizontal, slideSidebar]
|
|
})
|
|
export class AdminSidebarComponent extends MenuComponent implements OnInit {
|
|
/**
|
|
* The menu ID of the Navbar is PUBLIC
|
|
* @type {MenuID.ADMIN}
|
|
*/
|
|
menuID = MenuID.ADMIN;
|
|
|
|
/**
|
|
* Observable that emits the width of the collapsible menu sections
|
|
*/
|
|
sidebarWidth: Observable<string>;
|
|
|
|
/**
|
|
* Is true when the sidebar is open, is false when the sidebar is animating or closed
|
|
* @type {boolean}
|
|
*/
|
|
sidebarOpen = true; // Open in UI, animation finished
|
|
|
|
/**
|
|
* Is true when the sidebar is closed, is false when the sidebar is animating or open
|
|
* @type {boolean}
|
|
*/
|
|
sidebarClosed = !this.sidebarOpen; // Closed in UI, animation finished
|
|
|
|
/**
|
|
* Emits true when either the menu OR the menu's preview is expanded, else emits false
|
|
*/
|
|
sidebarExpanded: Observable<boolean>;
|
|
|
|
constructor(protected menuService: MenuService,
|
|
protected injector: Injector,
|
|
private variableService: CSSVariableService,
|
|
private authService: AuthService
|
|
) {
|
|
super(menuService, injector);
|
|
}
|
|
|
|
/**
|
|
* Set and calculate all initial values of the instance variables
|
|
*/
|
|
ngOnInit(): void {
|
|
this.createMenu();
|
|
super.ngOnInit();
|
|
this.sidebarWidth = this.variableService.getVariable('sidebarItemsWidth');
|
|
this.authService.isAuthenticated()
|
|
.subscribe((loggedIn: boolean) => {
|
|
if (loggedIn) {
|
|
this.menuService.showMenu(this.menuID);
|
|
}
|
|
});
|
|
this.menuCollapsed.pipe(first())
|
|
.subscribe((collapsed: boolean) => {
|
|
this.sidebarOpen = !collapsed;
|
|
this.sidebarClosed = collapsed;
|
|
});
|
|
this.sidebarExpanded = combineLatestObservable(this.menuCollapsed, this.menuPreviewCollapsed)
|
|
.pipe(
|
|
map(([collapsed, previewCollapsed]) => (!collapsed || !previewCollapsed))
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Initialize all menu sections and items for this menu
|
|
*/
|
|
private createMenu() {
|
|
const menuList = [
|
|
/* News */
|
|
{
|
|
id: 'new',
|
|
active: false,
|
|
visible: true,
|
|
model: {
|
|
type: MenuItemType.TEXT,
|
|
text: 'menu.section.new'
|
|
} as TextMenuItemModel,
|
|
icon: 'plus-circle',
|
|
index: 0
|
|
},
|
|
{
|
|
id: 'new_community',
|
|
parentID: 'new',
|
|
active: false,
|
|
visible: true,
|
|
model: {
|
|
type: MenuItemType.LINK,
|
|
text: 'menu.section.new_community',
|
|
link: '/communities/submission'
|
|
} as LinkMenuItemModel,
|
|
},
|
|
{
|
|
id: 'new_collection',
|
|
parentID: 'new',
|
|
active: false,
|
|
visible: true,
|
|
model: {
|
|
type: MenuItemType.LINK,
|
|
text: 'menu.section.new_collection',
|
|
link: '/collections/submission'
|
|
} as LinkMenuItemModel,
|
|
},
|
|
{
|
|
id: 'new_item',
|
|
parentID: 'new',
|
|
active: false,
|
|
visible: true,
|
|
model: {
|
|
type: MenuItemType.LINK,
|
|
text: 'menu.section.new_item',
|
|
link: '/items/submission'
|
|
} as LinkMenuItemModel,
|
|
},
|
|
{
|
|
id: 'new_item_version',
|
|
parentID: 'new',
|
|
active: false,
|
|
visible: true,
|
|
model: {
|
|
type: MenuItemType.LINK,
|
|
text: 'menu.section.new_item_version',
|
|
link: '#'
|
|
} as LinkMenuItemModel,
|
|
},
|
|
|
|
/* Edit */
|
|
{
|
|
id: 'edit',
|
|
active: false,
|
|
visible: true,
|
|
model: {
|
|
type: MenuItemType.TEXT,
|
|
text: 'menu.section.edit'
|
|
} as TextMenuItemModel,
|
|
icon: 'pencil-alt',
|
|
index: 1
|
|
},
|
|
{
|
|
id: 'edit_community',
|
|
parentID: 'edit',
|
|
active: false,
|
|
visible: true,
|
|
model: {
|
|
type: MenuItemType.LINK,
|
|
text: 'menu.section.edit_community',
|
|
link: '#'
|
|
} as LinkMenuItemModel,
|
|
},
|
|
{
|
|
id: 'edit_collection',
|
|
parentID: 'edit',
|
|
active: false,
|
|
visible: true,
|
|
model: {
|
|
type: MenuItemType.LINK,
|
|
text: 'menu.section.edit_collection',
|
|
link: '#'
|
|
} as LinkMenuItemModel,
|
|
},
|
|
{
|
|
id: 'edit_item',
|
|
parentID: 'edit',
|
|
active: false,
|
|
visible: true,
|
|
model: {
|
|
type: MenuItemType.LINK,
|
|
text: 'menu.section.edit_item',
|
|
link: '#'
|
|
} as LinkMenuItemModel,
|
|
},
|
|
|
|
/* Import */
|
|
{
|
|
id: 'import',
|
|
active: false,
|
|
visible: true,
|
|
model: {
|
|
type: MenuItemType.TEXT,
|
|
text: 'menu.section.import'
|
|
} as TextMenuItemModel,
|
|
icon: 'sign-in-alt',
|
|
index: 2
|
|
},
|
|
{
|
|
id: 'import_metadata',
|
|
parentID: 'import',
|
|
active: false,
|
|
visible: true,
|
|
model: {
|
|
type: MenuItemType.LINK,
|
|
text: 'menu.section.import_metadata',
|
|
link: '#'
|
|
} as LinkMenuItemModel,
|
|
},
|
|
{
|
|
id: 'import_batch',
|
|
parentID: 'import',
|
|
active: false,
|
|
visible: true,
|
|
model: {
|
|
type: MenuItemType.LINK,
|
|
text: 'menu.section.import_batch',
|
|
link: '#'
|
|
} as LinkMenuItemModel,
|
|
},
|
|
|
|
/* Export */
|
|
{
|
|
id: 'export',
|
|
active: false,
|
|
visible: true,
|
|
model: {
|
|
type: MenuItemType.TEXT,
|
|
text: 'menu.section.export'
|
|
} as TextMenuItemModel,
|
|
icon: 'sign-out-alt',
|
|
index: 3
|
|
},
|
|
{
|
|
id: 'export_community',
|
|
parentID: 'export',
|
|
active: false,
|
|
visible: true,
|
|
model: {
|
|
type: MenuItemType.LINK,
|
|
text: 'menu.section.export_community',
|
|
link: '#'
|
|
} as LinkMenuItemModel,
|
|
},
|
|
{
|
|
id: 'export_collection',
|
|
parentID: 'export',
|
|
active: false,
|
|
visible: true,
|
|
model: {
|
|
type: MenuItemType.LINK,
|
|
text: 'menu.section.export_collection',
|
|
link: '#'
|
|
} as LinkMenuItemModel,
|
|
},
|
|
{
|
|
id: 'export_item',
|
|
parentID: 'export',
|
|
active: false,
|
|
visible: true,
|
|
model: {
|
|
type: MenuItemType.LINK,
|
|
text: 'menu.section.export_item',
|
|
link: '#'
|
|
} as LinkMenuItemModel,
|
|
}, {
|
|
id: 'export_metadata',
|
|
parentID: 'export',
|
|
active: false,
|
|
visible: true,
|
|
model: {
|
|
type: MenuItemType.LINK,
|
|
text: 'menu.section.export_metadata',
|
|
link: '#'
|
|
} as LinkMenuItemModel,
|
|
},
|
|
|
|
/* Access Control */
|
|
{
|
|
id: 'access_control',
|
|
active: false,
|
|
visible: true,
|
|
model: {
|
|
type: MenuItemType.TEXT,
|
|
text: 'menu.section.access_control'
|
|
} as TextMenuItemModel,
|
|
icon: 'key',
|
|
index: 4
|
|
},
|
|
{
|
|
id: 'access_control_people',
|
|
parentID: 'access_control',
|
|
active: false,
|
|
visible: true,
|
|
model: {
|
|
type: MenuItemType.LINK,
|
|
text: 'menu.section.access_control_people',
|
|
link: '#'
|
|
} as LinkMenuItemModel,
|
|
},
|
|
{
|
|
id: 'access_control_groups',
|
|
parentID: 'access_control',
|
|
active: false,
|
|
visible: true,
|
|
model: {
|
|
type: MenuItemType.LINK,
|
|
text: 'menu.section.access_control_groups',
|
|
link: '#'
|
|
} as LinkMenuItemModel,
|
|
},
|
|
{
|
|
id: 'access_control_authorizations',
|
|
parentID: 'access_control',
|
|
active: false,
|
|
visible: true,
|
|
model: {
|
|
type: MenuItemType.LINK,
|
|
text: 'menu.section.access_control_authorizations',
|
|
link: '#'
|
|
} as LinkMenuItemModel,
|
|
},
|
|
|
|
/* Search */
|
|
{
|
|
id: 'find',
|
|
active: false,
|
|
visible: true,
|
|
model: {
|
|
type: MenuItemType.TEXT,
|
|
text: 'menu.section.find'
|
|
} as TextMenuItemModel,
|
|
icon: 'search',
|
|
index: 5
|
|
},
|
|
{
|
|
id: 'find_items',
|
|
parentID: 'find',
|
|
active: false,
|
|
visible: true,
|
|
model: {
|
|
type: MenuItemType.LINK,
|
|
text: 'menu.section.find_items',
|
|
link: '/search'
|
|
} as LinkMenuItemModel,
|
|
},
|
|
{
|
|
id: 'find_withdrawn_items',
|
|
parentID: 'find',
|
|
active: false,
|
|
visible: true,
|
|
model: {
|
|
type: MenuItemType.LINK,
|
|
text: 'menu.section.find_withdrawn_items',
|
|
link: '#'
|
|
} as LinkMenuItemModel,
|
|
},
|
|
{
|
|
id: 'find_private_items',
|
|
parentID: 'find',
|
|
active: false,
|
|
visible: true,
|
|
model: {
|
|
type: MenuItemType.LINK,
|
|
text: 'menu.section.find_private_items',
|
|
link: '/admin/items'
|
|
} as LinkMenuItemModel,
|
|
},
|
|
|
|
/* Registries */
|
|
{
|
|
id: 'registries',
|
|
active: false,
|
|
visible: true,
|
|
model: {
|
|
type: MenuItemType.TEXT,
|
|
text: 'menu.section.registries'
|
|
} as TextMenuItemModel,
|
|
icon: 'list',
|
|
index: 6
|
|
},
|
|
{
|
|
id: 'registries_metadata',
|
|
parentID: 'registries',
|
|
active: false,
|
|
visible: true,
|
|
model: {
|
|
type: MenuItemType.LINK,
|
|
text: 'menu.section.registries_metadata',
|
|
link: 'admin/registries/metadata'
|
|
} as LinkMenuItemModel,
|
|
},
|
|
{
|
|
id: 'registries_format',
|
|
parentID: 'registries',
|
|
active: false,
|
|
visible: true,
|
|
model: {
|
|
type: MenuItemType.LINK,
|
|
text: 'menu.section.registries_format',
|
|
link: 'admin/registries/bitstream-formats'
|
|
} as LinkMenuItemModel,
|
|
},
|
|
|
|
/* Curation tasks */
|
|
{
|
|
id: 'curation_tasks',
|
|
active: false,
|
|
visible: true,
|
|
model: {
|
|
type: MenuItemType.LINK,
|
|
text: 'menu.section.curation_task',
|
|
link: '/curation'
|
|
} as LinkMenuItemModel,
|
|
icon: 'filter',
|
|
index: 7
|
|
},
|
|
|
|
/* Statistics */
|
|
{
|
|
id: 'statistics_task',
|
|
active: false,
|
|
visible: true,
|
|
model: {
|
|
type: MenuItemType.LINK,
|
|
text: 'menu.section.statistics_task',
|
|
link: '#'
|
|
} as LinkMenuItemModel,
|
|
icon: 'chart-bar',
|
|
index: 8
|
|
},
|
|
|
|
/* Control Panel */
|
|
{
|
|
id: 'control_panel',
|
|
active: false,
|
|
visible: true,
|
|
model: {
|
|
type: MenuItemType.LINK,
|
|
text: 'menu.section.control_panel',
|
|
link: '#'
|
|
} as LinkMenuItemModel,
|
|
icon: 'cogs',
|
|
index: 9
|
|
},
|
|
];
|
|
menuList.forEach((menuSection) => this.menuService.addSection(this.menuID, menuSection));
|
|
|
|
}
|
|
|
|
/**
|
|
* Method to change this.collapsed to false when the slide animation ends and is sliding open
|
|
* @param event The animation event
|
|
*/
|
|
startSlide(event: any): void {
|
|
if (event.toState === 'expanded') {
|
|
this.sidebarClosed = false;
|
|
} else if (event.toState === 'collapsed') {
|
|
this.sidebarOpen = false;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Method to change this.collapsed to false when the slide animation ends and is sliding open
|
|
* @param event The animation event
|
|
*/
|
|
finishSlide(event: any): void {
|
|
if (event.fromState === 'expanded') {
|
|
this.sidebarClosed = true;
|
|
} else if (event.fromState === 'collapsed') {
|
|
this.sidebarOpen = true;
|
|
}
|
|
}
|
|
}
|