[Trunk|Admin]: 1. Add Community Layout Component. 2. Add module ngx-color-picker. 3.Change property AdminToolesUrl to mpagasas(for test)
git-svn-id: https://svn.driver.research-infrastructures.eu/driver/dnet40/modules/uoa-admin-portal/trunk@55028 d315682c-612b-4755-9ff5-7f18f6832af3
This commit is contained in:
parent
8ad9d70834
commit
a5d711b6c7
|
@ -32,6 +32,7 @@
|
||||||
"jquery": "^3.2.1",
|
"jquery": "^3.2.1",
|
||||||
"ng2-ckeditor": "1.1.9",
|
"ng2-ckeditor": "1.1.9",
|
||||||
"ngx-bootstrap": "^1.6.6",
|
"ngx-bootstrap": "^1.6.6",
|
||||||
|
"ngx-color-picker": "^4.5.3",
|
||||||
"ngx-json-ld": "0.1.6",
|
"ngx-json-ld": "0.1.6",
|
||||||
"rxjs": "^5.4.2",
|
"rxjs": "^5.4.2",
|
||||||
"ts-md5": "^1.2.0",
|
"ts-md5": "^1.2.0",
|
||||||
|
|
|
@ -30,6 +30,12 @@
|
||||||
<span>Community profile</span>
|
<span>Community profile</span>
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
|
<li >
|
||||||
|
<a routerLink="/community-layout" routerLinkActive="active" [queryParams]="{communityId: this.communityId}">
|
||||||
|
|
||||||
|
<span>Community Layout</span>
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
</ul>
|
</ul>
|
||||||
</li>
|
</li>
|
||||||
<li *ngIf="communityId != 'openaire'" class="uk-nav-header uk-parent">
|
<li *ngIf="communityId != 'openaire'" class="uk-nav-header uk-parent">
|
||||||
|
|
|
@ -38,6 +38,11 @@ const appRoutes: Routes = [
|
||||||
loadChildren: './pages/community/community-edit-form/community-edit-form.module#CommunityEditFormModule',
|
loadChildren: './pages/community/community-edit-form/community-edit-form.module#CommunityEditFormModule',
|
||||||
resolve: { envSpecific: EnvironmentSpecificResolver }
|
resolve: { envSpecific: EnvironmentSpecificResolver }
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
path: 'community-layout',
|
||||||
|
loadChildren: './pages/community/layout/community-layout.module#CommunityLayoutModule',
|
||||||
|
resolve: { envSpecific: EnvironmentSpecificResolver }
|
||||||
|
},
|
||||||
{
|
{
|
||||||
path: 'manage-zenodo-communities',
|
path: 'manage-zenodo-communities',
|
||||||
loadChildren: './pages/zenodo-communities/zenodo-communities.module#ZenodoCommunitiesModule',
|
loadChildren: './pages/zenodo-communities/zenodo-communities.module#ZenodoCommunitiesModule',
|
||||||
|
|
|
@ -0,0 +1,14 @@
|
||||||
|
import { NgModule } from '@angular/core';
|
||||||
|
import {RouterModule} from '@angular/router';
|
||||||
|
import {CommunityLayoutComponent} from './community-layout.component';
|
||||||
|
import {IsCommunity} from '../../../openaireLibrary/connect/communityGuard/isCommunity.guard';
|
||||||
|
import {ConnectAdminLoginGuard} from '../../../openaireLibrary/connect/communityGuard/connectAdminLoginGuard.guard';
|
||||||
|
|
||||||
|
@NgModule({
|
||||||
|
imports: [
|
||||||
|
RouterModule.forChild([
|
||||||
|
{ path: '', canActivate: [IsCommunity, ConnectAdminLoginGuard], component: CommunityLayoutComponent}
|
||||||
|
])
|
||||||
|
]
|
||||||
|
})
|
||||||
|
export class CommunityLayoutRoutingModule { }
|
|
@ -0,0 +1,39 @@
|
||||||
|
<div id="community-edit-form " class=" uk-card uk-card-default uk-padding">
|
||||||
|
<div class="uk-text-large uk-text-center uk-width-5-6@l uk-width ">Edit community layout</div>
|
||||||
|
<div>
|
||||||
|
<div *ngIf="showLoading" class="uk-animation-fade uk-width-1-1" role="alert"><span class="loading-gif uk-align-center"></span></div>
|
||||||
|
<table *ngIf="communityId != null && layout !== null && !showLoading && !errorMessage" class="uk-width-1-1">
|
||||||
|
<tbody class="uk-table uk-align-center">
|
||||||
|
<tr>
|
||||||
|
<td for="color" class="uk-text-bold uk-width-1-2@xl uk-width-1-3@m uk-width-expand@s uk-text-right">Color:</td>
|
||||||
|
<td class="uk-text-left uk-width-1-3@xl uk-width-1-3@m uk-width-expand@s">
|
||||||
|
<button [(colorPicker)]="layout.color" [style.background]="layout.color"
|
||||||
|
id="color" class="uk-icon-button"
|
||||||
|
(click)="change()">
|
||||||
|
</button>
|
||||||
|
</td>
|
||||||
|
<td for="color" class="uk-text uk-width-1-3@xl uk-width-1-3@m uk-width-expand@s uk-text-left" [style.color]="layout.color">Change your community color</td>
|
||||||
|
</tr>
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
<div *ngIf="errorMessage" class="uk-alert uk-alert-danger" role="alert">{{errorMessage}}</div>
|
||||||
|
<div *ngIf="successfulSaveMessage" class="uk-alert uk-alert-success" role="alert">{{successfulSaveMessage}}</div>
|
||||||
|
<div *ngIf="successfulResetMessage" class="uk-alert uk-alert-warning" role="alert">{{successfulResetMessage}}</div>
|
||||||
|
|
||||||
|
<table *ngIf="communityId != null && layout != null && !showLoading && !errorMessage" class="uk-width-1-1">
|
||||||
|
<tbody class="uk-table uk-align-center">
|
||||||
|
<tr>
|
||||||
|
<td class="uk-width-2-3@xl uk-width-1-2@m uk-width-1-2@s uk-text-right"></td>
|
||||||
|
<td class="uk-text-left">
|
||||||
|
<div class="uk-grid-margin uk-first-column uk-align-center uk-text-left uk-padding uk-padding-remove-top uk-padding-remove-bottom">
|
||||||
|
<button *ngIf="hasChanged" class="uk-button uk-button-primary" (click)="updateLayout()">Save</button>
|
||||||
|
<button *ngIf="!hasChanged" class="uk-button uk-button-default" disabled>Save</button>
|
||||||
|
<button class="uk-button" (click)="resetLayout()">Reset</button>
|
||||||
|
<button class="uk-button connect-default-button" (click)="loadDefaultLayout()">Default Layout</button>
|
||||||
|
</div>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
</div>
|
||||||
|
</div>
|
|
@ -0,0 +1,134 @@
|
||||||
|
import {Component, OnInit, ElementRef} from '@angular/core';
|
||||||
|
import {ActivatedRoute} from '@angular/router';
|
||||||
|
|
||||||
|
|
||||||
|
import {EnvProperties} from '../../../openaireLibrary/utils/properties/env-properties';
|
||||||
|
import {LayoutService} from '../../../openaireLibrary/services/layout.service';
|
||||||
|
|
||||||
|
@Component({
|
||||||
|
selector: 'community-layout',
|
||||||
|
templateUrl: './community-layout.component.html',
|
||||||
|
})
|
||||||
|
|
||||||
|
export class CommunityLayoutComponent implements OnInit {
|
||||||
|
|
||||||
|
public showLoading = true;
|
||||||
|
public errorMessage = '';
|
||||||
|
|
||||||
|
public successfulSaveMessage = '';
|
||||||
|
public successfulResetMessage = '';
|
||||||
|
|
||||||
|
public hasChanged = false;
|
||||||
|
public communityId = null;
|
||||||
|
public layout = null;
|
||||||
|
public properties: EnvProperties = null;
|
||||||
|
|
||||||
|
constructor (private element: ElementRef,
|
||||||
|
private route: ActivatedRoute,
|
||||||
|
private _layoutService: LayoutService) { }
|
||||||
|
|
||||||
|
|
||||||
|
ngOnInit() {
|
||||||
|
this.route.data.subscribe((data: { envSpecific: EnvProperties }) => {
|
||||||
|
this.properties = data.envSpecific;
|
||||||
|
this.route.queryParams.subscribe(
|
||||||
|
communityId => {
|
||||||
|
this.scroll();
|
||||||
|
this.communityId = communityId['communityId'];
|
||||||
|
if (this.communityId != null && this.communityId !== '') {
|
||||||
|
this.showLoading = true;
|
||||||
|
this.errorMessage = '';
|
||||||
|
this._layoutService.getLayout(this.communityId,
|
||||||
|
this.properties.adminToolsAPIURL).subscribe (
|
||||||
|
layout => {
|
||||||
|
this.layout = layout;
|
||||||
|
this.showLoading = false;
|
||||||
|
},
|
||||||
|
error => this.handleError('System error retrieving community layout', error)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
public scroll() {
|
||||||
|
if (typeof document !== 'undefined') {
|
||||||
|
this.element.nativeElement.scrollIntoView();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public updateLayout() {
|
||||||
|
if (this.communityId != null && this.communityId !== '') {
|
||||||
|
this.showLoading = true;
|
||||||
|
this._layoutService.saveLayout(this.communityId,
|
||||||
|
this.properties.adminToolsAPIURL, this.layout).subscribe (
|
||||||
|
layout => {
|
||||||
|
this.layout = layout;
|
||||||
|
this.showLoading = false;
|
||||||
|
this.handleSuccessfulSave('Community Layout saved!');
|
||||||
|
},
|
||||||
|
error => this.handleError('System error saving community layout', error)
|
||||||
|
);
|
||||||
|
this.resetChange();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public resetLayout() {
|
||||||
|
if (this.communityId != null && this.communityId !== '') {
|
||||||
|
this.showLoading = true;
|
||||||
|
this._layoutService.getLayout(this.communityId,
|
||||||
|
this.properties.adminToolsAPIURL).subscribe (
|
||||||
|
layout => {
|
||||||
|
this.layout = layout;
|
||||||
|
this.showLoading = false;
|
||||||
|
this.handleSuccessfulReset('Community Layout reset!');
|
||||||
|
},
|
||||||
|
error => this.handleError('System error retrieving community layout', error)
|
||||||
|
);
|
||||||
|
this.resetChange();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public loadDefaultLayout() {
|
||||||
|
if (this.communityId != null && this.communityId !== '') {
|
||||||
|
this.showLoading = true;
|
||||||
|
this._layoutService.loadDefaultLayout(this.communityId,
|
||||||
|
this.properties.adminToolsAPIURL).subscribe (
|
||||||
|
layout => {
|
||||||
|
this.layout = layout;
|
||||||
|
this.showLoading = false;
|
||||||
|
this.handleSuccessfulReset('Default Community Layout has been loaded!');
|
||||||
|
},
|
||||||
|
error => this.handleError('System error loading default community layout', error)
|
||||||
|
);
|
||||||
|
this.resetChange();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private change() {
|
||||||
|
this.hasChanged = true;
|
||||||
|
this.successfulSaveMessage = '';
|
||||||
|
this.successfulResetMessage = '';
|
||||||
|
}
|
||||||
|
|
||||||
|
private resetChange() {
|
||||||
|
this.hasChanged = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
handleError(message: string, error) {
|
||||||
|
this.errorMessage = message;
|
||||||
|
console.log('Server responded: ' + error);
|
||||||
|
|
||||||
|
this.showLoading = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
handleSuccessfulSave(message) {
|
||||||
|
this.showLoading = false;
|
||||||
|
this.successfulSaveMessage = message;
|
||||||
|
}
|
||||||
|
|
||||||
|
handleSuccessfulReset(message) {
|
||||||
|
this.showLoading = false;
|
||||||
|
this.successfulResetMessage = message;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,28 @@
|
||||||
|
import {NgModule} from '@angular/core';
|
||||||
|
import {CommonModule} from '@angular/common';
|
||||||
|
import {RouterModule} from '@angular/router';
|
||||||
|
|
||||||
|
import {CommunityLayoutComponent} from './community-layout.component';
|
||||||
|
|
||||||
|
import {CommunityLayoutRoutingModule} from './community-layout-routing.module';
|
||||||
|
import {IsCommunity} from '../../../openaireLibrary/connect/communityGuard/isCommunity.guard';
|
||||||
|
import {ConnectAdminLoginGuard} from '../../../openaireLibrary/connect/communityGuard/connectAdminLoginGuard.guard';
|
||||||
|
import {ColorPickerModule} from 'ngx-color-picker';
|
||||||
|
import {LayoutService} from '../../../openaireLibrary/services/layout.service';
|
||||||
|
|
||||||
|
@NgModule({
|
||||||
|
imports: [
|
||||||
|
CommunityLayoutRoutingModule, CommonModule, RouterModule, ColorPickerModule
|
||||||
|
],
|
||||||
|
declarations: [
|
||||||
|
CommunityLayoutComponent
|
||||||
|
],
|
||||||
|
providers: [
|
||||||
|
IsCommunity, ConnectAdminLoginGuard, LayoutService
|
||||||
|
],
|
||||||
|
exports: [
|
||||||
|
CommunityLayoutComponent
|
||||||
|
]
|
||||||
|
})
|
||||||
|
|
||||||
|
export class CommunityLayoutModule { }
|
|
@ -10,7 +10,6 @@ import { Community } from "../domain/community";
|
||||||
import { Entity } from "../domain/entity";
|
import { Entity } from "../domain/entity";
|
||||||
import { DivId } from "../domain/divId";
|
import { DivId } from "../domain/divId";
|
||||||
import { DivHelpContent } from "../domain/div-help-content";
|
import { DivHelpContent } from "../domain/div-help-content";
|
||||||
import {COOKIE} from "../openaireLibrary/login/utils/helper.class"
|
|
||||||
import {StatisticsDisplay, StatisticsSummary} from '../openaireLibrary/connect/statistics/statisticsEntities';
|
import {StatisticsDisplay, StatisticsSummary} from '../openaireLibrary/connect/statistics/statisticsEntities';
|
||||||
import { CustomOptions } from '../openaireLibrary/services/servicesUtils/customOptions.class';
|
import { CustomOptions } from '../openaireLibrary/services/servicesUtils/customOptions.class';
|
||||||
|
|
||||||
|
|
|
@ -49,7 +49,7 @@
|
||||||
|
|
||||||
"cacheUrl" :"http://scoobydoo.di.uoa.gr:3000/get?url=",
|
"cacheUrl" :"http://scoobydoo.di.uoa.gr:3000/get?url=",
|
||||||
|
|
||||||
"adminToolsAPIURL" :"http://duffy.di.uoa.gr:8080/uoa-admin-tools/",
|
"adminToolsAPIURL" :"http://mpagasas.di.uoa.gr:8080/uoa-admin-tools/",
|
||||||
|
|
||||||
"adminToolsCommunity" :"openaire",
|
"adminToolsCommunity" :"openaire",
|
||||||
"communityAPI": "https://dev-openaire.d4science.org/openaire/community/",
|
"communityAPI": "https://dev-openaire.d4science.org/openaire/community/",
|
||||||
|
|
Loading…
Reference in New Issue