[Connect Admin | Library | new-theme]: Redesign of remove/add projects and zenodo communities pages according to the new mocks.

1. searchProjects.service.ts: Added "params" parameter in "getFunders()" method.
2. resultsAndPagesNum.component.ts: Do not show number of results and pages when no results.
3. manage-communities.module.ts: Remove "group" and "lock" icons from registerIcons call.
4. add-projects.component & communityProjects.module.ts & manage-projects.component.ts & remove-projects.component: Redesign of remove/add projects pages according to the new mocks.
5. add-zenodo-communities.component & manage-zenodo-communities.component & preview-z-community.component.ts & zenodo-communities.component.ts & zenodo-communities.module.ts: Redesign of remove/add zenodo communities pages according to the new mocks.
This commit is contained in:
Konstantina Galouni 2022-07-05 01:31:56 +03:00
parent 7c9d0936b3
commit 4c08b4dad3
14 changed files with 867 additions and 893 deletions

View File

@ -24,6 +24,6 @@ import {SearchInputModule} from '../../openaireLibrary/sharedComponents/search-i
}) })
export class ManageCommunitiesModule { export class ManageCommunitiesModule {
constructor(private iconsService: IconsService) { constructor(private iconsService: IconsService) {
this.iconsService.registerIcons([group, lock, earth]); this.iconsService.registerIcons([earth]);
} }
} }

View File

@ -1,110 +1,152 @@
<div [class]="'uk-width-1-1 uk-flex uk-flex-middle uk-grid uk-margin-medium-bottom ' + (allOptions.length > 0 ? '' : 'uk-flex-right@m')" uk-grid> <ng-template #selected_filters_pills>
<div *ngIf="allOptions?.length > 0" <h1>
class="uk-width-1-2@m uk-width-1-1"> <div class="uk-width-1-1" uk-slider="finite: true">
<div class="uk-grid uk-flex uk-flex-middle uk-flex-wrap uk-flex-center uk-flex-right@m uk-width-1-1"> <div [class.uk-invisible]="list.children.length === 0" class="uk-position-relative">
<span class="">Filter by: </span> <div class="uk-slider-container" style="height: 40px">
<div class="uk-width-expand uk-padding-remove uk-margin-small-left" dashboard-input <ul #list class="uk-slider-items uk-grid uk-grid-small uk-margin-small-right uk-flex-nowrap">
[formInput]="filterForm.get('funder')" <ng-container *ngIf="funders && funders.countSelectedValues > 0">
placeholder="Search by funder" <ng-container *ngFor="let value of getSelectedValues(funders); let i = index; let end = last; ">
type="autocomplete" [options]="allOptions" [showOptionsOnEmpty]="false"> <li>
<span class="uk-label uk-label-primary uk-flex uk-flex-middle">
<span
class="uk-margin-small-right uk-width-expand uk-text-truncate">
<span *ngIf="funders.type && funders.type == 'boolean' else noboolean">{{funders.title}}:
{{value.name=='true'?'Yes':'No'}}
</span>
<ng-template #noboolean>
{{value.name}}
</ng-template></span>
<button class="uk-close uk-icon" [class.uk-disabled]="disabled" [disabled]="disabled" (click)="removeFilter(value, funders)">
<icon name="close" flex="true" ratio="0.7"></icon>
</button>
</span>
</li>
</ng-container>
</ng-container>
</ul>
</div>
<div class="">
<a class="uk-position-center-left blur-background" uk-slider-item="previous"><span uk-icon="chevron-left"></span></a>
<a class="uk-position-center-right blur-background" uk-slider-item="next"><span uk-icon="chevron-right"></span></a>
</div>
</div> </div>
</div> </div>
</h1>
</ng-template>
<ng-template #filters_column>
<!-- [class.filterLoading]="disabled"-->
<div >
<div class="uk-flex uk-flex-middle">
<h4 class="uk-margin-right uk-margin-remove-bottom">Filters</h4>
<a *ngIf="selectedFunderId" (click)="clearFilters()"
class="uk-text-small" [class.uk-disabled]="disabled" [class.uk-link-muted]="disabled">
Clear All
</a>
</div>
<!-- <div *ngIf="openaireSearchUtils.refineStatus == errorCodes.LOADING"-->
<!-- class="uk-margin-top" role="alert">-->
<!-- <loading></loading>-->
<!-- </div>-->
<div *ngIf="openaireSearchUtils.refineStatus != errorCodes.LOADING && openaireSearchUtils.refineStatus != errorCodes.DONE && openaireProjects.length > 0"
class="uk-margin-top uk-text-meta">
<span *ngIf="openaireSearchUtils.refineStatus == errorCodes.NONE">No filters available</span>
<span *ngIf="openaireSearchUtils.refineStatus != errorCodes.NONE" class="uk-text-warning">Filters temporarily unavailable. Please try again later.</span>
</div>
<ul class="uk-list uk-list-xlarge">
<li *ngIf="funders && funders.values && funders.values.length > 0">
<search-filter [showMoreInline]="true"
[filter]="funders" [showResultCount]="true"
[actionRoute]="false" (onFilterChange)="funderChanged(funders)"
[isDisabled]="disabled">
</search-filter>
</li>
</ul>
</div> </div>
<div class="uk-flex uk-flex-wrap uk-flex-center uk-flex-right@m uk-width-1-1 uk-width-1-2@m"> </ng-template>
<div class="uk-width-1-1 uk-width-expand@m">
<div #searchInputComponent search-input [control]="filterForm.controls.keyword" [showSearch]="false" <div class="uk-section uk-flex uk-flex-center uk-flex uk-flex-middle">
placeholder="Search Projects" <div class="uk-width-auto uk-margin-right">
[selected]="openaireSearchUtils.keyword" (closeEmitter)="onSearchClose()" (resetEmitter)="resetInput()" <a uk-icon="icon: info; ratio: 1.3"></a>
[bordered]="true" colorClass="uk-text-secondary"></div> <div *ngIf="community" class="uk-dropdown uk-padding-small uk-width-medium" uk-dropdown="mode: hover">
If you cannot find a funder that is relevant for your community, please contact us
(<a
[href]="'mailto:' + properties.feedbackmailForMissingEntities +'?Subject=[OpenAIRE Connect - '+ community.shortTitle + '] report missing Funder' + '&body=' + body"
target="_top">{{properties.feedbackmailForMissingEntities}}</a>)
and we will try to get the funder on board!
</div> </div>
</div> </div>
<div search-input class="uk-width-xlarge@l uk-width-large" [searchControl]="filterForm.get('keyword')" searchInputClass="outer"
[placeholder]="'Search '+openaireEntities.PROJECTS" [disabled]="loading"></div>
</div> </div>
<div class="uk-section uk-section-small uk-position-relative">
<div id="manage-projects"> <div class="uk-grid" uk-grid>
<div *ngIf="openaireSearchUtils.status == errorCodes.LOADING" class="uk-position-large-top"> <div class="uk-width-1-4@m search-filters uk-visible@m">
<loading></loading> <ng-container *ngTemplateOutlet="filters_column; context: {}"></ng-container>
</div>
<div *ngIf="openaireSearchUtils.totalResults == 0"
class="uk-card uk-card-default uk-padding-large uk-text-center uk-margin-bottom uk-text-bold">
<div>
<div *ngIf="openaireSearchUtils.status == errorCodes.NONE">No OpenAIRE projects available</div>
<div *ngIf="openaireSearchUtils.status == errorCodes.NONE" class="uk-margin-top">
If you wish to suggest a new funder to include or report a missing project, please contact us via
<a target="_top"
[href]="'mailto:' + properties.feedbackmailForMissingEntities +'?Subject=[OpenAIRE Connect - '+ community + '] report missing project' + '&body=' + body">
feedback@openaire.eu</a>.
</div>
<div *ngIf="openaireSearchUtils.status == errorCodes.ERROR">An Error Occurred. No OpenAIRE projects found</div>
<div *ngIf="openaireSearchUtils.status == errorCodes.NOT_AVAILABLE">Service temporarily unavailable. Please try again later.</div>
<div *ngIf="openaireSearchUtils.status == errorCodes.NOT_FOUND">No OpenAIRE projects found</div>
<!-- <div *ngIf="openaireSearchUtils.status == errorCodes.OUT_OF_BOUND">Requested page out of bounds</div>-->
</div> </div>
</div> <div class="uk-width-expand@m uk-with-1-1@s">
<!-- <errorMessages [status]="[openaireSearchUtils.status]" [type]="'OpenAIRE projects'"></errorMessages>--> <div *ngIf="(selectedFunderId && openaireSearchUtils.status !== errorCodes.LOADING)">
<!-- <div *ngIf="openaireSearchUtils.status == errorCodes.NONE" class="uk-alert uk-alert-primary">--> <ng-container *ngTemplateOutlet="selected_filters_pills;"></ng-container>
<!-- <span class="uk-margin-small-right uk-icon" uk-icon="warning"></span>--> </div>
<!-- If you wish to suggest a new funder to include or report a missing project, please contact us via--> <div>
<!-- <a--> <div *ngIf="openaireSearchUtils.status == errorCodes.LOADING" class="uk-position-center">
<!-- [href]="'mailto:' + properties.feedbackmailForMissingEntities +'?Subject=[OpenAIRE Connect - '+ community + '] report missing project' + '&body=' + body"--> <loading></loading>
<!-- target="_top">feedback@openaire.eu</a>.--> </div>
<!-- </div>--> <div *ngIf="openaireSearchUtils.status !== errorCodes.LOADING">
<div *ngIf="openaireSearchUtils.totalResults == 0"
<ng-container *ngIf="openaireSearchUtils.totalResults > 0"> class="uk-card uk-card-default uk-padding-large uk-text-center uk-margin-bottom uk-text-bold">
<no-load-paging [type]="'Projects'" <div>No {{openaireEntities.PROJECTS | lowercase}} found</div>
[page]="openaireSearchUtils.page" [pageSize]="resultsPerPage" (pageChange)="goTo($event.value)" </div>
[totalResults]="openaireSearchUtils.totalResults"> <ng-container *ngIf="openaireSearchUtils.totalResults > 0">
</no-load-paging> <no-load-paging [type]="openaireEntities.PROJECTS"
[page]="openaireSearchUtils.page" [pageSize]="resultsPerPage" (pageChange)="goTo($event.value, false)"
<ul class="uk-list search-results uk-margin-medium-top uk-margin-medium-bottom"> [totalResults]="openaireSearchUtils.totalResults">
<li *ngFor="let result of openaireProjects" class="uk-animation-fade"> </no-load-paging>
<div class="uk-card uk-card-default uk-card-hover uk-text-small uk-margin-bottom"> <div class="uk-grid uk-child-width-1-1 uk-margin-medium-top uk-margin-bottom" uk-grid>
<div class="uk-grid uk-grid-divider uk-padding-small" uk-grid> <div *ngFor="let result of openaireProjects">
<div class="uk-width-expand@m uk-width-1-1"> <div class="uk-card uk-card-default">
<result-preview [properties]="properties" [showOrganizations]="true" <div class="uk-card-body">
[showSubjects]="true" [result]="getResultPreview(result)" <result-preview [properties]="properties" [showOrganizations]="true"
[externalUrl]="projectUrl"> [showSubjects]="true" [result]="getResultPreview(result)"
</result-preview> [externalUrl]="projectUrl">
</div> </result-preview>
<div class="uk-width-auto@m uk-width-1-1">
<div class="uk-flex uk-flex-middle uk-flex-center uk-flex-column uk-height-1-1">
<div class="uk-padding-small uk-padding-remove-horizontal">
<div [class.hide-element]="!getCommunityProject(result)">
<a (click)="removeProject(result)" class="uk-button action uk-flex uk-flex-middle">
<icon name="remove_circle_outline"></icon>
<span class="uk-margin-small-left">Remove project</span>
</a>
</div> </div>
<div class="uk-card-footer uk-padding-remove-vertical">
<div [class.hide-element]="getCommunityProject(result)"> <div class="uk-grid uk-grid-small uk-flex-nowrap uk-grid-divider uk-flex-right" uk-grid>
<a (click)="addProject(result)" class="uk-button action uk-flex uk-flex-middle" <div *ngIf="!getCommunityProject(result)">
uk-tooltip="title:<div class='uk-padding-small'><div class='uk-margin-bottom uk-text-bold'>Add new project </div><div>Newly added projects will be linked to your community on the next run of our algorithms.</div></div>"> <div class="uk-padding-small uk-padding-remove-horizontal">
<div class="uk-text-success"> <a (click)="addProject(result)" class="uk-button uk-button-link uk-flex uk-flex-middle">
<icon name="add"></icon> <icon name="add" [flex]="true"></icon>
<span class="uk-margin-small-left">
Add
</span>
</a>
</div>
</div> </div>
<span class="uk-margin-small-left">Add project</span> <div *ngIf="getCommunityProject(result)">
</a> <div class="uk-padding-small uk-padding-remove-horizontal">
<a (click)="removeProject(result)"
class="uk-button uk-button-link uk-flex uk-flex-middle">
<icon name="remove" [flex]="true"></icon>
<span class="uk-margin-small-left">Remove</span>
</a>
</div>
</div>
</div>
</div> </div>
</div> </div>
</div> </div>
</div> </div>
</div> <div class="uk-margin-small-top">
<no-load-paging [type]="openaireEntities.PROJECTS"
[page]="openaireSearchUtils.page" [pageSize]="resultsPerPage" (pageChange)="goTo($event.value, false)"
[totalResults]="openaireSearchUtils.totalResults">
</no-load-paging>
</div>
</ng-container>
</div> </div>
</li> </div>
</ul>
<!-- <div [class]="openaireSearchUtils.page > pagingLimit ? 'search-results' : ''"--> </div>
<!-- *ngIf="(openaireSearchUtils.page >= pagingLimit) && (openaireSearchUtils.totalResults > resultsPerPage*pagingLimit)">--> </div>
<!-- <div class="uk-card uk-card-default uk-padding-large uk-text-center uk-margin-bottom uk-text-bold">-->
<!-- For more results please try a new, more specific query-->
<!-- </div>-->
<!-- </div>-->
<no-load-paging [type]="'Projects'"
[page]="openaireSearchUtils.page" [pageSize]="resultsPerPage" (pageChange)="goTo($event.value)"
[totalResults]="openaireSearchUtils.totalResults">
</no-load-paging>
</ng-container>
</div> </div>

View File

@ -9,15 +9,16 @@ import {RouterHelper} from '../../openaireLibrary/utils/routerHelper.class';
import {StringUtils} from '../../openaireLibrary/utils/string-utils.class'; import {StringUtils} from '../../openaireLibrary/utils/string-utils.class';
import {ManageCommunityProjectsService} from '../../services/manageProjects.service'; import {ManageCommunityProjectsService} from '../../services/manageProjects.service';
import {Session} from '../../openaireLibrary/login/utils/helper.class';
import {LoginErrorCodes} from '../../openaireLibrary/login/utils/guardHelper.class';
import {properties} from "../../../environments/environment"; import {properties} from "../../../environments/environment";
import {Subscriber} from "rxjs"; import {Subscriber} from "rxjs";
import {FormBuilder, FormGroup} from "@angular/forms"; import {FormBuilder, FormGroup} from "@angular/forms";
import {Option} from "../../openaireLibrary/sharedComponents/input/input.component";
import {debounceTime, distinctUntilChanged} from "rxjs/operators"; import {debounceTime, distinctUntilChanged} from "rxjs/operators";
import {ResultPreview} from "../../openaireLibrary/utils/result-preview/result-preview"; import {ResultPreview} from "../../openaireLibrary/utils/result-preview/result-preview";
import {SearchInputComponent} from "../../openaireLibrary/sharedComponents/search-input/search-input.component"; import {SearchInputComponent} from "../../openaireLibrary/sharedComponents/search-input/search-input.component";
import {CommunityInfo} from "../../openaireLibrary/connect/community/communityInfo";
import {OpenaireEntities} from "../../openaireLibrary/utils/properties/searchFields";
import {Filter, Value} from "../../openaireLibrary/searchPages/searchUtils/searchHelperClasses.class";
import {HelperFunctions} from "../../openaireLibrary/utils/HelperFunctions.class";
declare var UIkit; declare var UIkit;
@ -30,7 +31,7 @@ export class AddProjectsComponent implements OnInit {
private subscriptions: any[] = []; private subscriptions: any[] = [];
public subResults: any; public subResults: any;
private community: string = ''; @Input() community: CommunityInfo = null;
public routerHelper: RouterHelper = new RouterHelper(); public routerHelper: RouterHelper = new RouterHelper();
public properties: EnvProperties = properties; public properties: EnvProperties = properties;
@ -46,35 +47,30 @@ export class AddProjectsComponent implements OnInit {
public selectedFunderId: string = ""; public selectedFunderId: string = "";
filterForm: FormGroup; filterForm: FormGroup;
allOptions: Option[] = []; funders: Filter = null;
@ViewChild('searchInputComponent') searchInputComponent: SearchInputComponent; @ViewChild('searchInputComponent') searchInputComponent: SearchInputComponent;
private projectUrl: string = "https://" + ((properties.environment == "beta" || properties.environment == "development") ? "beta." : "") + "explore.openaire.eu" + properties.searchLinkToProject; private projectUrl: string = "https://" + ((properties.environment == "beta" || properties.environment == "development") ? "beta." : "") + "explore.openaire.eu" + properties.searchLinkToProject;
public body: string = "Send from page"; public body: string = "Send from page";
@Output() toggleView: EventEmitter<any> = new EventEmitter(); openaireEntities = OpenaireEntities;
constructor(private route: ActivatedRoute, private _router: Router, private _searchProjectsService: SearchProjectsService, constructor(private route: ActivatedRoute, private _router: Router, private _searchProjectsService: SearchProjectsService,
private _manageCommunityProjectsService: ManageCommunityProjectsService, private _manageCommunityProjectsService: ManageCommunityProjectsService,
private _fb: FormBuilder) { private _fb: FormBuilder) {
this.errorCodes = new ErrorCodes(); this.errorCodes = new ErrorCodes();
this.openaireSearchUtils.status = this.errorCodes.LOADING; this.openaireSearchUtils.status = this.errorCodes.LOADING;
this.openaireSearchUtils.refineStatus = this.errorCodes.LOADING;
} }
ngOnInit() { ngOnInit() {
this.subscriptions.push(this.route.params.subscribe(params => { this.openaireSearchUtils.status = this.errorCodes.LOADING;
this.openaireSearchUtils.status = this.errorCodes.LOADING; this.openaireSearchUtils.refineStatus = this.errorCodes.LOADING;
this.getFunders();
this._getOpenaireProjects("", 1, this.resultsPerPage);
this.community = params['community']; this.body = "[Please write your message here]";
// this.projectUrl = "https://" + ((this.properties.environment == "beta" || this.properties.environment == "development") ? "beta." : "") this.body = StringUtils.URIEncode(this.body);
// + this.community + ".openaire.eu" + this.properties.searchLinkToProject;
this.getFunders();
this._getOpenaireProjects("", 1, this.resultsPerPage);
this.body = "[Please write your message here]";
this.body = StringUtils.URIEncode(this.body);
}));
this.openaireSearchUtils.keyword = ""; this.openaireSearchUtils.keyword = "";
@ -88,19 +84,6 @@ export class AddProjectsComponent implements OnInit {
.subscribe(value => { .subscribe(value => {
this.keywordChanged(value); this.keywordChanged(value);
})); }));
this.subscriptions.push(this.filterForm.get('funder').valueChanges
.pipe(debounceTime(1000), distinctUntilChanged())
.subscribe(value => {
// console.log("value: ",value);
if (value == null) {
// console.log("will be called funder changed: null");
this.funderChanged("", "");
} else if (value && value.id != undefined && value.id != this.selectedFunderId) {
// console.log("will be called funder changed: name="+value.label+", id="+value.id);
this.funderChanged(value.id, value.label);
}
}));
} }
public ngOnDestroy() { public ngOnDestroy() {
@ -115,65 +98,55 @@ export class AddProjectsComponent implements OnInit {
} }
} }
get loading() {
return this.openaireSearchUtils.status == this.errorCodes.LOADING
}
get disabled() {
return this.openaireSearchUtils.status == this.errorCodes.LOADING || this.openaireSearchUtils.refineStatus == this.errorCodes.LOADING;
}
public addProject(project: SearchResult) { public addProject(project: SearchResult) {
if (!Session.isLoggedIn()) { this.subscriptions.push(this._manageCommunityProjectsService.addProject(this.properties, this.community.communityId, project).subscribe(
this._router.navigate(['/user-info'], { data => {
queryParams: { this.communityProjects.push(data);
"errorCode": LoginErrorCodes.NOT_VALID, UIkit.notification('Project successfully added!', {
"redirectUrl": this._router.url status: 'success',
} timeout: 6000,
}); pos: 'bottom-right'
} else { });
this.subscriptions.push(this._manageCommunityProjectsService.addProject(this.properties, this.community, project).subscribe( this.communityProjectsChanged.emit({
data => { value: this.communityProjects,
this.communityProjects.push(data); });
UIkit.notification('Project successfully added!', { },
status: 'success', err => {
timeout: 6000, this.handleError('An error has been occurred. Try again later!');
pos: 'bottom-right' console.error(err.status);
}); }
this.communityProjectsChanged.emit({ ));
value: this.communityProjects,
});
},
err => {
this.handleError('An error has been occurred. Try again later!');
console.error(err.status);
}
));
}
} }
public removeProject(project: any) { public removeProject(project: any) {
if (!Session.isLoggedIn()) { let communityProject = this.getCommunityProject(project);
this._router.navigate(['/user-info'], { let projectId: string = communityProject['id'];
queryParams: { this.subscriptions.push(this._manageCommunityProjectsService.removeProject(this.properties, this.community.communityId, projectId).subscribe(
"errorCode": LoginErrorCodes.NOT_VALID, data => {
"redirectUrl": this._router.url let index = this.communityProjects.indexOf(communityProject);
} this.communityProjects.splice(index, 1);
}); UIkit.notification('Project successfully removed!', {
} else { status: 'success',
let communityProject = this.getCommunityProject(project); timeout: 6000,
let projectId: string = communityProject['id']; pos: 'bottom-right'
this.subscriptions.push(this._manageCommunityProjectsService.removeProject(this.properties, this.community, projectId).subscribe( });
data => { this.communityProjectsChanged.emit({
let index = this.communityProjects.indexOf(communityProject); value: this.communityProjects,
this.communityProjects.splice(index, 1); });
UIkit.notification('Project successfully removed!', { },
status: 'success', err => {
timeout: 6000, this.handleError('An error has been occurred. Try again later!');
pos: 'bottom-right' console.error(err);
}); }
this.communityProjectsChanged.emit({ ));
value: this.communityProjects,
});
},
err => {
this.handleError('An error has been occurred. Try again later!');
console.error(err);
}
));
}
} }
public getCommunityProject(project: any): string { public getCommunityProject(project: any): string {
@ -189,29 +162,27 @@ export class AddProjectsComponent implements OnInit {
} }
getFunders() { getFunders() {
if (!Session.isLoggedIn()) { this.openaireSearchUtils.refineStatus = this.errorCodes.LOADING;
this._router.navigate(['/user-info'], { this.subscriptions.push(this._searchProjectsService.getFunders(this.queryParameters, this.properties).subscribe(
queryParams: { data => {
"errorCode": LoginErrorCodes.NOT_VALID, this.funders = data[1][0];
"redirectUrl": this._router.url this.funders.values.map((value) => {
} if(value.id == this.selectedFunderId) {
}); value.selected = true;
} else { this.funders.countSelectedValues++;
this.subscriptions.push(this._searchProjectsService.getFunders(this.properties).subscribe(
data => {
let funders = data[1];
this.allOptions = [];
let i;
for (i = 0; i < funders.length; i++) {
let funder = funders[i];
if (funder && funder['id']) {
this.allOptions.push({label: funder['name'], value: {id: funder['id'], label: funder['name']}});
}
} }
}, })
err => console.error("Server error fetching funders: ", err) if(this.funders.values && this.funders.values.length == 0) {
)); this.openaireSearchUtils.refineStatus = this.errorCodes.NONE;
} } else {
this.openaireSearchUtils.refineStatus = this.errorCodes.DONE;
}
},
err => {
this.openaireSearchUtils.refineStatus = this.errorCodes.ERROR;
console.error("Server error fetching funders: ", err)
}
));
} }
public getResultPreview(result: SearchResult): ResultPreview { public getResultPreview(result: SearchResult): ResultPreview {
@ -219,63 +190,37 @@ export class AddProjectsComponent implements OnInit {
} }
private _getOpenaireProjects(parameters: string, page: number, size: number) { private _getOpenaireProjects(parameters: string, page: number, size: number) {
if (!Session.isLoggedIn()) { if (this.openaireSearchUtils.status == this.errorCodes.LOADING) {
this._router.navigate(['/user-info'], { this.openaireSearchUtils.status = this.errorCodes.LOADING;
queryParams: {
"errorCode": LoginErrorCodes.NOT_VALID,
"redirectUrl": this._router.url
}
});
} else {
// if (page > this.pagingLimit) {
// size = 0;
// }
if (this.openaireSearchUtils.status == this.errorCodes.LOADING) { this.openaireProjects = [];
this.openaireSearchUtils.status = this.errorCodes.LOADING; this.openaireSearchUtils.totalResults = 0;
this.openaireProjects = []; if (this.subResults) {
this.openaireSearchUtils.totalResults = 0; this.subResults.unsubscribe();
if (this.subResults) {
this.subResults.unsubscribe();
}
this.subResults = this._searchProjectsService.searchProjects(parameters, null, page, size, [], this.properties).subscribe(
data => {
this.openaireSearchUtils.totalResults = data[0];
this.openaireProjects = data[1];
//this.searchPage.checkSelectedFilters(this.filters);
this.openaireSearchUtils.status = this.errorCodes.DONE;
if (this.openaireSearchUtils.totalResults == 0) {
this.openaireSearchUtils.status = this.errorCodes.NONE;
}
// if (this.openaireSearchUtils.status == this.errorCodes.DONE) {
// // Page out of limit!!!
// let totalPages: any = this.openaireSearchUtils.totalResults / (this.openaireSearchUtils.size);
// if (!(Number.isInteger(totalPages))) {
// totalPages = (parseInt(totalPages, 10) + 1);
// }
// if (totalPages < page) {
// this.openaireSearchUtils.totalResults = 0;
// this.openaireSearchUtils.status = this.errorCodes.OUT_OF_BOUND;
// }
// }
},
err => {
console.error(err);
//TODO check erros (service not available, bad request)
if (err.status == '404') {
this.openaireSearchUtils.status = this.errorCodes.NOT_FOUND;
} else if (err.status == '500') {
this.openaireSearchUtils.status = this.errorCodes.ERROR;
} else {
this.openaireSearchUtils.status = this.errorCodes.NOT_AVAILABLE;
}
}
);
} }
this.subResults = this._searchProjectsService.searchProjects(parameters, null, page, size, [], this.properties).subscribe(
data => {
this.openaireSearchUtils.totalResults = data[0];
this.openaireProjects = data[1];
this.openaireSearchUtils.status = this.errorCodes.DONE;
if (this.openaireSearchUtils.totalResults == 0) {
this.openaireSearchUtils.status = this.errorCodes.NONE;
}
},
err => {
console.error(err);
//TODO check erros (service not available, bad request)
if (err.status == '404') {
this.openaireSearchUtils.status = this.errorCodes.NOT_FOUND;
} else if (err.status == '500') {
this.openaireSearchUtils.status = this.errorCodes.ERROR;
} else {
this.openaireSearchUtils.status = this.errorCodes.NOT_AVAILABLE;
}
}
);
} }
} }
@ -293,9 +238,8 @@ export class AddProjectsComponent implements OnInit {
this.goTo(1); this.goTo(1);
} }
funderChanged(funderId: string, funderName: string) { funderChanged(filter: Filter) {
this.selectedFunderId = funderId; this.getSelectedValues(filter);
this.buildQueryParameters(); this.buildQueryParameters();
this.goTo(1); this.goTo(1);
} }
@ -313,16 +257,17 @@ export class AddProjectsComponent implements OnInit {
} }
} }
goTo(page: number = 1) { goTo(page: number = 1, refineQuery: boolean = true) {
HelperFunctions.scroll();
this.openaireSearchUtils.page = page; this.openaireSearchUtils.page = page;
this.openaireSearchUtils.status = this.errorCodes.LOADING; this.openaireSearchUtils.status = this.errorCodes.LOADING;
if(refineQuery) {
this.openaireSearchUtils.refineStatus = this.errorCodes.LOADING;
this.getFunders();
}
this._getOpenaireProjects(this.queryParameters, page, this.resultsPerPage); this._getOpenaireProjects(this.queryParameters, page, this.resultsPerPage);
} }
back() {
this.toggleView.emit(null);
}
public onSearchClose() { public onSearchClose() {
this.openaireSearchUtils.keyword = this.filterForm.get('keyword').value; this.openaireSearchUtils.keyword = this.filterForm.get('keyword').value;
} }
@ -339,4 +284,40 @@ export class AddProjectsComponent implements OnInit {
pos: 'bottom-right' pos: 'bottom-right'
}); });
} }
getSelectedValues(filter): any {
var selected = [];
this.selectedFunderId = "";
if (filter.countSelectedValues > 0) {
for (var i = 0; i < filter.values.length; i++) {
if (filter.values[i].selected) {
selected.push(filter.values[i]);
this.selectedFunderId = filter.values[i].id;
}
}
}
return selected;
}
clearFilters() {
for (var j = 0; j < this.funders.countSelectedValues; j++) {
if (this.funders.values[j].selected) {
this.removeFilter(this.funders.values[j], this.funders);
break;
}
}
}
public removeFilter(value: Value, filter: Filter) {
this.selectedFunderId = "";
filter.countSelectedValues--;
if (value.selected == true) {
value.selected = false;
}
if (filter.filterType == "radio") {
filter.radioValue = "";
}
this.buildQueryParameters();
this.goTo(1);
}
} }

View File

@ -20,11 +20,11 @@ import {SearchInputModule} from "../../openaireLibrary/sharedComponents/search-i
import {NoLoadPaging} from "../../openaireLibrary/searchPages/searchUtils/no-load-paging.module"; import {NoLoadPaging} from "../../openaireLibrary/searchPages/searchUtils/no-load-paging.module";
import {LoadingModule} from "../../openaireLibrary/utils/loading/loading.module"; import {LoadingModule} from "../../openaireLibrary/utils/loading/loading.module";
import {IconsModule} from "../../openaireLibrary/utils/icons/icons.module"; import {IconsModule} from "../../openaireLibrary/utils/icons/icons.module";
import {IconsService} from "../../openaireLibrary/utils/icons/icons.service";
import {add, arrow_left, close, remove_circle_outline} from "../../openaireLibrary/utils/icons/icons";
import {FullScreenModalModule} from "../../openaireLibrary/utils/modal/full-screen-modal/full-screen-modal.module"; import {FullScreenModalModule} from "../../openaireLibrary/utils/modal/full-screen-modal/full-screen-modal.module";
import {ResultPreviewModule} from "../../openaireLibrary/utils/result-preview/result-preview.module"; import {ResultPreviewModule} from "../../openaireLibrary/utils/result-preview/result-preview.module";
import {ErrorMessagesModule} from "../../openaireLibrary/utils/errorMessages.module"; import {ErrorMessagesModule} from "../../openaireLibrary/utils/errorMessages.module";
import {DropdownFilterModule} from "../../openaireLibrary/utils/dropdown-filter/dropdown-filter.module";
import {SearchFilterModule} from "../../openaireLibrary/searchPages/searchUtils/searchFilter.module";
@NgModule({ @NgModule({
imports: [ imports: [
@ -46,7 +46,7 @@ import {ErrorMessagesModule} from "../../openaireLibrary/utils/errorMessages.mod
path: '', component: ManageProjectsComponent path: '', component: ManageProjectsComponent
} }
]), ]),
NoLoadPaging, LoadingModule, IconsModule, FullScreenModalModule, ResultPreviewModule NoLoadPaging, LoadingModule, IconsModule, FullScreenModalModule, ResultPreviewModule, DropdownFilterModule, SearchFilterModule
], ],
declarations: [ declarations: [
ManageProjectsComponent, ManageProjectsComponent,
@ -60,7 +60,5 @@ import {ErrorMessagesModule} from "../../openaireLibrary/utils/errorMessages.mod
exports: [ManageProjectsComponent] exports: [ManageProjectsComponent]
}) })
export class CommunityProjectsModule { export class CommunityProjectsModule {
constructor(private iconsService: IconsService) { constructor() {}
this.iconsService.registerIcons([remove_circle_outline, add, close, arrow_left]);
}
} }

View File

@ -3,39 +3,26 @@ import {ActivatedRoute, Router} from "@angular/router";
import {RemoveProjectsComponent} from './remove-projects.component'; import {RemoveProjectsComponent} from './remove-projects.component';
import {Session} from '../../openaireLibrary/login/utils/helper.class';
import {LoginErrorCodes} from '../../openaireLibrary/login/utils/guardHelper.class';
import {HelperFunctions} from "../../openaireLibrary/utils/HelperFunctions.class";
import {Title} from '@angular/platform-browser'; import {Title} from '@angular/platform-browser';
import {FullScreenModalComponent} from "../../openaireLibrary/utils/modal/full-screen-modal/full-screen-modal.component"; import {FullScreenModalComponent} from "../../openaireLibrary/utils/modal/full-screen-modal/full-screen-modal.component";
import {StringUtils} from "../../openaireLibrary/utils/string-utils.class"; import {StringUtils} from "../../openaireLibrary/utils/string-utils.class";
import {EnvProperties} from "../../openaireLibrary/utils/properties/env-properties"; import {EnvProperties} from "../../openaireLibrary/utils/properties/env-properties";
import {properties} from "../../../environments/environment"; import {properties} from "../../../environments/environment";
import {Subscriber} from "rxjs"; import {Subscriber} from "rxjs";
import {CommunityInfo} from "../../openaireLibrary/connect/community/communityInfo";
import {OpenaireEntities} from "../../openaireLibrary/utils/properties/searchFields";
import {CommunityService} from "../../openaireLibrary/connect/community/community.service";
@Component({ @Component({
selector: 'manage-projects', selector: 'manage-projects',
template: ` template: `
<remove-projects (toggleView)="toggleAction()" [communityProjects]="communityProjects" <remove-projects #removeProjectsComponent (addProjects)="openAddProjects()" [communityProjects]="communityProjects"
[showLoading]="showLoadingInRemove" [loading]="showLoadingInRemove" [community]="community" [disableAdd]="add.loading"
(communityProjectsChanged)="communityProjectsChanged($event)" [toggle]="toggle"> (communityProjectsChanged)="communityProjectsChanged($event)">
</remove-projects> </remove-projects>
<fs-modal #fsModal (cancelEmitter)="toggleAction()"> <fs-modal #fsModal>
<div actions class="uk-flex uk-flex-middle uk-height-1-1"> <add-projects #add [communityProjects]="communityProjects" [community]="community"
<span class="uk-button uk-text-secondary" uk-icon="icon: info; ratio: 1.3"></span> (communityProjectsChanged)="communityProjectsChanged($event)"></add-projects>
<div *ngIf="communityId" uk-drop="mode: hover">
<div class="uk-card uk-card-body uk-card-default">
If you cannot find a funder that is relevant for your community, please contact us
(<a
[href]="'mailto:' + properties.feedbackmailForMissingEntities +'?Subject=[OpenAIRE Connect - '+ communityId + '] report missing Funder' + '&body=' + body"
target="_top">{{properties.feedbackmailForMissingEntities}}</a>)
and we will try to get the funder on board!
</div>
</div>
</div>
<add-projects [communityProjects]="communityProjects"
(communityProjectsChanged)="communityProjectsChanged($event)"></add-projects>
</fs-modal> </fs-modal>
` `
}) })
@ -44,34 +31,27 @@ export class ManageProjectsComponent implements OnInit {
@Input() communityProjects = []; @Input() communityProjects = [];
@ViewChild(RemoveProjectsComponent) removeProjectsComponent: RemoveProjectsComponent; @ViewChild(RemoveProjectsComponent) removeProjectsComponent: RemoveProjectsComponent;
@ViewChild('fsModal', { static: true }) fullscreen: FullScreenModalComponent; @ViewChild('fsModal', { static: true }) fullscreen: FullScreenModalComponent;
public toggle: boolean = false;
private subscriptions: any[] = []; private subscriptions: any[] = [];
public showLoadingInRemove: boolean = true; public showLoadingInRemove: boolean = true;
public body: string = "Send from page"; public body: string = "Send from page";
public properties: EnvProperties = properties; public properties: EnvProperties = properties;
public communityId: string = ""; public community: CommunityInfo = null;
constructor(private element: ElementRef, constructor(private element: ElementRef,
private title: Title, private title: Title,
private route: ActivatedRoute, private _router: Router) { private route: ActivatedRoute, private _router: Router,
private communityService: CommunityService) {
} }
ngOnInit() { ngOnInit() {
this.subscriptions.push(this.route.params.subscribe(params => { this.subscriptions.push(this.communityService.getCommunityAsObservable().subscribe(community => {
this.communityId = params['community']; this.community = community;
if (this.community) {
if (this.communityId) { this.title.setTitle(this.community.shortTitle.toUpperCase() + ' | ' + OpenaireEntities.PROJECTS);
this.title.setTitle(this.communityId.toUpperCase() + ' | Projects');
this.body = "[Please write your message here]"; this.body = "[Please write your message here]";
this.body = StringUtils.URIEncode(this.body); this.body = StringUtils.URIEncode(this.body);
} }
this.fullscreen.title = "Search and Add Projects";
this.fullscreen.okButtonText = "Done";
this.fullscreen.okButton = true;
})); }));
} }
@ -83,26 +63,19 @@ export class ManageProjectsComponent implements OnInit {
}); });
} }
public toggleAction() { public openAddProjects() {
if (!Session.isLoggedIn()) { this.fullscreen.title = "Search and Add "+OpenaireEntities.PROJECTS;
this._router.navigate(['/user-info'], { this.fullscreen.okButtonText = "Done";
queryParams: {'errorCode': LoginErrorCodes.NOT_VALID, 'redirectUrl': this._router.url} this.fullscreen.back = true;
}); this.fullscreen.okButton = true;
} else { this.fullscreen.open();
HelperFunctions.scroll();
this.toggle = !this.toggle;
if (this.toggle) {
this.fullscreen.open();
}
}
} }
public communityProjectsChanged($event) { public communityProjectsChanged($event) {
this.communityProjects = $event.value; this.communityProjects = $event.value;
this.showLoadingInRemove = false; this.showLoadingInRemove = false;
if (this.toggle) { if (this.fullscreen.isOpen) {
this.removeProjectsComponent.applyFilters(); this.removeProjectsComponent.applyFilters();
this.removeProjectsComponent.createFunderFilter(); this.removeProjectsComponent.createFunderFilter();
} }

View File

@ -1,116 +1,138 @@
<div page-content> <div page-content (stickyEmitter)="stickyPageHeader = $event">
<div header> <div header>
<community-info tab="projects"></community-info> <div class="uk-flex uk-flex-middle uk-margin-top info" [class.uk-active]="stickyPageHeader">
<div [class.uk-invisible]="showLoading" <div>
class="uk-width-1-1 uk-flex uk-flex-right@m uk-flex-center uk-flex-wrap uk-flex-middle uk-grid" uk-grid> <div class="uk-margin-remove uk-text-background uk-text-bold uk-h6">Admin Dashboard - Manage {{openaireEntiites.PROJECTS}}
<div class="uk-flex-last@m"> </div>
<a class="uk-text-uppercase uk-flex uk-flex-middle" (click)="addNew()" <h1 class="uk-h4 uk-margin-remove">{{community.shortTitle}}</h1>
[attr.uk-tooltip]="(toggle? 'cls: uk-invisible; ' : 'cls: uk-active; ') +
'title: <div class=\'uk-padding-small\'><div class=\'uk-margin-bottom uk-text-bold\'> Search and add more Projects</div><div>The research results linked to the projects specified here will be automatically linked to your community dashboard.</div></div>'">
<button class="uk-icon-button large uk-button-secondary">
<icon name="add"></icon>
</button>
<button class="uk-button uk-button-link uk-margin-small-left uk-text-secondary">Add new project</button>
</a>
</div> </div>
<div #searchInputComponent search-input [control]="filterForm.controls.keyword" [showSearch]="false"
placeholder="Search Projects"
[selected]="communitySearchUtils.keyword" (closeEmitter)="onSearchClose()" (resetEmitter)="resetInput()"
[bordered]="true" colorClass="uk-text-secondary"
class="uk-width-1-3@xl uk-width-2-5@l uk-width-1-2@m uk-width-1-1"></div>
</div> </div>
<community-info tab="projects"></community-info>
</div> </div>
<div inner> <div inner>
<div *ngIf="showLoading" class="uk-margin-large-top"> <div class="uk-flex uk-flex-middle uk-margin-top">
<loading></loading> <div class="uk-width-expand@m uk-width-1-1 uk-grid uk-flex-middle uk-flex-right@m uk-flex-center uk-margin-remove-left" uk-grid>
<div search-input [expandable]="true" [searchControl]="filterForm.get('keyword')" searchInputClass="outer"
placeholder="Search project" [disabled]="loading"
class="uk-width-1-3@xl uk-width-2-5@l uk-width-1-2@m uk-width-1-1"></div>
<div>
<button class="uk-button uk-button-default uk-flex uk-flex-middle"
(click)="addNew()"
[attr.uk-tooltip]="('cls: uk-active; ') +
'title: <div class=\'uk-margin-bottom uk-text-bold\'> Search and add more '+openaireEntiites.PROJECTS+'</div>' +
'<div>The research results linked to the <span class=\'uk-text-lowercase\'>'+openaireEntiites.PROJECTS +
'</span> specified here will be automatically linked to your <span class=\'uk-text-lowercase\'>'+openaireEntiites.COMMUNITY+'</span> dashboard.</div>'"
[disabled]="loading || disableAdd" [class.uk-disabled]="loading || disableAdd">
<icon name="add" [flex]="true"></icon>
<span class="uk-margin-small-left">New {{openaireEntiites.PROJECT}}</span>
</button>
</div>
</div>
</div>
<div class="uk-margin-top">
<results-and-pages [type]="openaireEntiites.PROJECTS | lowercase" [page]="page" [pageSize]="resultsPerPage"
[totalResults]="previewCommunityProjects.length"></results-and-pages>
</div> </div>
<div *ngIf="!showLoading"> <div class="uk-grid uk-flex-middle uk-margin-medium-top" uk-grid>
<div> <div *ngIf="allOptions.length > 0">
<div class="uk-grid uk-flex uk-flex-middle uk-margin-medium-bottom" uk-grid> <dropdown-filter #dropdownFilter dropdownClass="uk-width-medium uk-padding-small"
<div *ngIf="allOptions.length > 0" name="Filter by Funder" [count]="filterForm.get('funder').value.length">
class="uk-grid uk-flex-middle uk-flex-left@m uk-flex-center uk-width-1-3@xl uk-width-2-5@l uk-width-1-2@m uk-width-1-1 uk-first-column"> <h6 class="uk-margin-remove-bottom" title="Filter by Funder">Funder</h6>
<span class="">Filter by: </span> <ul class="uk-list uk-margin-remove-bottom">
<div class="uk-width-expand uk-padding-remove uk-margin-small-left" dashboard-input <li *ngFor="let option of allOptions">
[formInput]="filterForm.get('funder')" <a class="uk-link-text">
placeholder="Search by funders" <label (click)="select(option.value, $event, dropdownFilter)" class="uk-flex uk-flex-middle">
type="chips" [options]="allOptions" chipLabel="label"> <input class="uk-checkbox"
</div> type="checkbox" [checked]="isSelected(option.value)">
</div> <span class="uk-margin-small-left">{{option.label}}</span>
<div *ngIf="previewCommunityProjects.length > 0" </label>
class="uk-width-expand@m uk-width-1-1"> </a>
<div class="uk-flex-middle uk-flex-right@m uk-flex-center uk-grid"> </li>
<span class="">Sort by: </span> </ul>
<div class="uk-width-medium uk-padding-remove uk-margin-small-left" dashboard-input </dropdown-filter>
[formInput]="filterForm.get('sort')" </div>
type="select" <div input inputClass="flat x-small" placeholder="Sort by"
[options]="sortOptions"> [disabled]="previewCommunityProjects.length == 0"
</div> [formInput]="filterForm.get('sort')"
</div> type="select" [options]="sortOptions">
</div> </div>
</div> <!-- </div>-->
<no-load-paging *ngIf="previewCommunityProjects.length > 0" [type]="'projects'" <div class="uk-width-expand@m uk-width-1-1 uk-flex uk-flex-right@m uk-flex-center">
(pageChange)="updatePage($event)" <paging-no-load *ngIf="previewCommunityProjects.length > 0"
[page]="page" [pageSize]="resultsPerPage" (pageChange)="updatePage($event)" [size]="resultsPerPage"
[totalResults]="previewCommunityProjects.length"> [totalResults]="previewCommunityProjects.length" customClasses="uk-flex-right">
</no-load-paging> </paging-no-load>
<div class="uk-margin-medium-top uk-margin-medium-bottom">
<div *ngIf="previewCommunityProjects.length == 0"
class="uk-card uk-card-default uk-padding-large uk-text-center uk-margin-bottom uk-text-bold">
<div>No projects for {{name}}</div>
</div>
<div class="uk-card uk-card-default uk-text-small uk-margin-bottom"
*ngFor="let item of previewCommunityProjects.slice((page - 1)*resultsPerPage, page*resultsPerPage)">
<div class="uk-grid uk-grid-divider uk-padding" uk-grid>
<div class="uk-width-expand@m uk-width-1-1">
<div class="uk-padding-small uk-padding-remove-horizontal">
<h6 class="uk-margin-small-bottom">
<a *ngIf="item.openaireId || (item.grantId && item.funder)"
target="_blank"
[href]="projectUrl+'?' + ((item.openaireId) ? 'projectId='+item.openaireId : 'grantId='+item.grantId+'&funder='+item.funder)">
<span *ngIf="item.name">{{item.name}}</span>
<span *ngIf="item.name && item.acronym"> (</span><span *ngIf="item.acronym">{{item.acronym}}</span><span *ngIf="item.name && item.acronym">)</span>
<span *ngIf="!item.name && !item.acronym">[no title available]</span>
<span class="custom-external custom-icon space"></span>
</a>
<span *ngIf="!item.openaireId && !(item.grantId && item.funder)">
<span *ngIf="item.name">{{item.name}}</span>
<span *ngIf="item.name && item.acronym"> (</span><span *ngIf="item.acronym">{{item.acronym}}</span><span *ngIf="item.name && item.acronym">)</span>
<span *ngIf="!item.name && !item.acronym">[no title available]</span>
</span>
</h6>
<div *ngIf="item.grantId" class="uk-margin-small-bottom">
<span class="title">Grant ID: </span>
<span>{{item.grantId}}</span>
</div>
<div *ngIf="item.funder" class="uk-margin-small-bottom">
<span class="title">Funder: </span>
<span>{{item.funder}}</span>
</div>
</div>
</div>
<div class="uk-width-auto@m uk-width-1-1">
<div class="uk-flex uk-flex-middle uk-flex-center uk-height-1-1">
<div class="uk-padding-small uk-padding-remove-horizontal">
<a (click)="removeProject(item)" class="uk-button action uk-flex uk-flex-middle">
<icon name="remove_circle_outline"></icon>
<span class="uk-margin-small-left">Remove project</span>
</a>
</div>
</div>
</div>
</div>
</div>
</div>
<no-load-paging *ngIf="previewCommunityProjects.length > 0" [type]="'projects'"
(pageChange)="updatePage($event)"
[page]="page" [pageSize]="resultsPerPage"
[totalResults]="previewCommunityProjects.length">
</no-load-paging>
</div> </div>
</div> </div>
<modal-alert #AlertModalDeleteCommunity (alertOutput)="confirmedDeleteProject($event)"></modal-alert> <div class="uk-section uk-section-small uk-position-relative" style="min-height: 60vh">
<div *ngIf="loading" class="uk-position-center">
<loading></loading>
</div>
<div *ngIf="!loading">
<div class="uk-margin-medium-bottom">
<div *ngIf="previewCommunityProjects.length == 0"
class="uk-card uk-card-default uk-padding-large uk-text-center uk-margin-bottom uk-text-bold">
<div>No {{openaireEntiites.PROJECTS | lowercase}} for {{community.shortTitle}}</div>
</div>
<div *ngIf="previewCommunityProjects.length > 0"
class="uk-grid uk-grid-large uk-child-width-1-1 uk-child-width-1-2@m uk-margin-bottom" uk-grid uk-height-match="target: .uk-card-body">
<div *ngFor="let item of previewCommunityProjects.slice((page - 1)*resultsPerPage, page*resultsPerPage); let i=index">
<div class="uk-card uk-card-default">
<div class="uk-card-body">
<h6 class="uk-margin-bottom">
<a *ngIf="item.openaireId || (item.grantId && item.funder)"
target="_blank" class="custom-external uk-link-text"
[href]="projectUrl+'?' + ((item.openaireId) ? 'projectId='+item.openaireId : 'grantId='+item.grantId+'&funder='+item.funder)">
<span *ngIf="item.name">{{item.name}}</span>
<span *ngIf="item.name && item.acronym"> (</span><span *ngIf="item.acronym">{{item.acronym}}</span><span *ngIf="item.name && item.acronym">)</span>
<span *ngIf="!item.name && !item.acronym">[no title available]</span>
</a>
<span *ngIf="!item.openaireId && !(item.grantId && item.funder)">
<span *ngIf="item.name">{{item.name}}</span>
<span *ngIf="item.name && item.acronym"> (</span><span *ngIf="item.acronym">{{item.acronym}}</span><span *ngIf="item.name && item.acronym">)</span>
<span *ngIf="!item.name && !item.acronym">[no title available]</span>
</span>
</h6>
<div class="uk-grid uk-child-width-1-2@l uk-text-small">
<div *ngIf="item.grantId">
<span class="uk-text-meta">Grant ID: </span>
<span>{{item.grantId}}</span>
</div>
<div *ngIf="item.funder">
<span class="uk-text-meta">Funder: </span>
<span>{{item.funder}}</span>
</div>
</div>
</div>
<div class="uk-card-footer uk-padding-remove-vertical">
<div class="uk-grid uk-grid-small uk-flex-nowrap uk-grid-divider uk-flex-right" uk-grid>
<div>
<div class="uk-padding-small uk-padding-remove-horizontal">
<button class="uk-button uk-button-link uk-flex uk-flex-middle"
(click)="removeProject(item)">
<icon name="remove" [flex]="true"></icon>
<span class="uk-margin-xsmall-left">Remove</span>
</button>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
<div class="uk-margin-small-top">
<paging-no-load [currentPage]="page"
[totalResults]="previewCommunityProjects.length" [size]="resultsPerPage"
(pageChange)="updatePage($event)" customClasses="uk-flex-right@m uk-flex-center">
</paging-no-load>
</div>
</div>
</div>
<modal-alert #AlertModalDeleteCommunity (alertOutput)="confirmedDeleteProject($event)" [overflowBody]="false"></modal-alert>
</div>
</div> </div>
</div> </div>

View File

@ -16,6 +16,10 @@ import {properties} from "../../../environments/environment";
import {CommunityService} from "../../openaireLibrary/connect/community/community.service"; import {CommunityService} from "../../openaireLibrary/connect/community/community.service";
import {Option} from "../../openaireLibrary/sharedComponents/input/input.component"; import {Option} from "../../openaireLibrary/sharedComponents/input/input.component";
import {SearchInputComponent} from "../../openaireLibrary/sharedComponents/search-input/search-input.component"; import {SearchInputComponent} from "../../openaireLibrary/sharedComponents/search-input/search-input.component";
import {DropdownFilterComponent} from "../../openaireLibrary/utils/dropdown-filter/dropdown-filter.component";
import {OpenaireEntities} from "../../openaireLibrary/utils/properties/searchFields";
import {CommunityInfo} from "../../openaireLibrary/connect/community/communityInfo";
import {HelperFunctions} from "../../openaireLibrary/utils/HelperFunctions.class";
declare var UIkit; declare var UIkit;
@ -25,16 +29,16 @@ declare var UIkit;
}) })
export class RemoveProjectsComponent implements OnInit { export class RemoveProjectsComponent implements OnInit {
public portal: string; @Input() public community: CommunityInfo;
public name: string; @Input() public loading: boolean = true;
@Input() public disableAdd: boolean = false;
@Output() addProjects: EventEmitter<void> = new EventEmitter();
private subscriptions: any[] = []; private subscriptions: any[] = [];
public routerHelper: RouterHelper = new RouterHelper(); public routerHelper: RouterHelper = new RouterHelper();
private projectUrl = "https://" + ((properties.environment == "beta" || properties.environment == "development") ? "beta." : "") + "explore.openaire.eu" + properties.searchLinkToProject.split("?")[0]; private projectUrl = "https://" + ((properties.environment == "beta" || properties.environment == "development") ? "beta." : "") + "explore.openaire.eu" + properties.searchLinkToProject.split("?")[0];
@Input() public showLoading: boolean = true;
@Output() communityProjectsChanged = new EventEmitter(); @Output() communityProjectsChanged = new EventEmitter();
@Input() public communityProjects = []; @Input() public communityProjects = [];
public previewCommunityProjects = []; public previewCommunityProjects = [];
@ -55,6 +59,7 @@ export class RemoveProjectsComponent implements OnInit {
public fundersCtrl: FormArray; public fundersCtrl: FormArray;
private searchText: RegExp = new RegExp(''); private searchText: RegExp = new RegExp('');
public keyword: string = ''; public keyword: string = '';
selectedFunders: string[] = [];
allOptions: Option[] = []; allOptions: Option[] = [];
sortOptions: Option[] = [ sortOptions: Option[] = [
//{label:"Title (desc) ", value:{ sort: "title",descending: true }}, //{label:"Title (desc) ", value:{ sort: "title",descending: true }},
@ -65,8 +70,9 @@ export class RemoveProjectsComponent implements OnInit {
{label: "Funder ", value: {sort: "funder", descending: false}} {label: "Funder ", value: {sort: "funder", descending: false}}
]; ];
@Output() toggleView: EventEmitter<any> = new EventEmitter(); public stickyPageHeader: boolean = false;
@Input() public toggle: boolean = true;
public openaireEntiites = OpenaireEntities;
constructor(private route: ActivatedRoute, private _router: Router, constructor(private route: ActivatedRoute, private _router: Router,
private _fb: FormBuilder, private _fb: FormBuilder,
@ -105,11 +111,10 @@ export class RemoveProjectsComponent implements OnInit {
this.subscriptions.push(this.communityService.getCommunityAsObservable().subscribe(community => { this.subscriptions.push(this.communityService.getCommunityAsObservable().subscribe(community => {
if (community) { if (community) {
this.portal = community.communityId; this.community = community;
this.name = community.shortTitle;
this.projectUrl = "https://" this.projectUrl = "https://"
+ ((this.properties.environment == "beta" || this.properties.environment == "development") ? "beta." : "") + ((this.properties.environment == "beta" || this.properties.environment == "development") ? "beta." : "")
+ this.portal + ".openaire.eu" + this.properties.searchLinkToProject.split("?")[0]; + this.community.communityId + ".openaire.eu" + this.properties.searchLinkToProject.split("?")[0];
this.keyword = ''; this.keyword = '';
this._getCommunityProjects(); this._getCommunityProjects();
@ -155,14 +160,14 @@ export class RemoveProjectsComponent implements OnInit {
} }
}); });
} else { } else {
this.subscriptions.push(this._manageCommunityProjectsService.removeProject(this.properties, this.portal, this.selectedCommunityProject.id).subscribe( this.subscriptions.push(this._manageCommunityProjectsService.removeProject(this.properties, this.community.communityId, this.selectedCommunityProject.id).subscribe(
data => { data => {
let index = this.communityProjects.indexOf(this.selectedCommunityProject); let index = this.communityProjects.indexOf(this.selectedCommunityProject);
this.communityProjects.splice(index, 1); this.communityProjects.splice(index, 1);
this.applyFilters(); this.applyFilters();
UIkit.notification('Project successfully removed!', { UIkit.notification(OpenaireEntities.PROJECT+' successfully removed!', {
status: 'success', status: 'success',
timeout: 6000, timeout: 6000,
pos: 'bottom-right' pos: 'bottom-right'
@ -195,7 +200,7 @@ export class RemoveProjectsComponent implements OnInit {
this.selectedCommunityProject = communityProject; this.selectedCommunityProject = communityProject;
this.alertModalDeleteCommunity.cancelButton = true; this.alertModalDeleteCommunity.cancelButton = true;
this.alertModalDeleteCommunity.okButton = true; this.alertModalDeleteCommunity.okButton = true;
this.alertModalDeleteCommunity.alertTitle = "Remove project?"; this.alertModalDeleteCommunity.alertTitle = "Remove "+OpenaireEntities.PROJECT;
let title = ""; let title = "";
if (communityProject.name) { if (communityProject.name) {
title = communityProject.name; title = communityProject.name;
@ -209,11 +214,11 @@ export class RemoveProjectsComponent implements OnInit {
if (communityProject.name && communityProject.acronym) { if (communityProject.name && communityProject.acronym) {
title += ")"; title += ")";
} }
this.alertModalDeleteCommunity.message = "Project"; this.alertModalDeleteCommunity.message = OpenaireEntities.PROJECT;
if (title) { if (title) {
this.alertModalDeleteCommunity.message += " '" + title + "' "; this.alertModalDeleteCommunity.message += " <b>" + title + "</b> ";
} }
this.alertModalDeleteCommunity.message += "will be removed from your community. Are you sure?"; this.alertModalDeleteCommunity.message += "will be removed from your "+OpenaireEntities.COMMUNITY.toLowerCase()+". Are you sure?";
this.alertModalDeleteCommunity.okButtonText = "Yes"; this.alertModalDeleteCommunity.okButtonText = "Yes";
this.alertModalDeleteCommunity.open(); this.alertModalDeleteCommunity.open();
} }
@ -234,7 +239,7 @@ export class RemoveProjectsComponent implements OnInit {
this.communitySearchUtils.page = 1; this.communitySearchUtils.page = 1;
this.communitySearchUtils.keyword = ""; this.communitySearchUtils.keyword = "";
this.subscriptions.push(this._searchCommunityProjectsService.searchProjects(this.properties, this.portal).subscribe( this.subscriptions.push(this._searchCommunityProjectsService.searchProjects(this.properties, this.community.communityId).subscribe(
data => { data => {
this.communityProjects = data; this.communityProjects = data;
this.previewCommunityProjects = this.communityProjects; this.previewCommunityProjects = this.communityProjects;
@ -249,7 +254,7 @@ export class RemoveProjectsComponent implements OnInit {
this.createFunderFilter(); this.createFunderFilter();
this.showLoading = false; this.loading = false;
}, },
err => { err => {
console.error(err); console.error(err);
@ -263,7 +268,7 @@ export class RemoveProjectsComponent implements OnInit {
this.communitySearchUtils.status = this.errorCodes.NOT_AVAILABLE; this.communitySearchUtils.status = this.errorCodes.NOT_AVAILABLE;
} }
this.showLoading = false; this.loading = false;
} }
)); ));
} }
@ -283,11 +288,12 @@ export class RemoveProjectsComponent implements OnInit {
} }
public updatePage($event) { public updatePage($event) {
HelperFunctions.scroll();
this.page = $event.value; this.page = $event.value;
} }
addNew() { addNew() {
this.toggleView.emit(null); this.addProjects.emit();
} }
public applyFilters() { public applyFilters() {
@ -367,4 +373,24 @@ export class RemoveProjectsComponent implements OnInit {
pos: 'bottom-right' pos: 'bottom-right'
}); });
} }
select(value: string, event, dropdownFilter: DropdownFilterComponent) {
if(event.target instanceof HTMLInputElement) {
dropdownFilter.closeDropdown();
if(event.target.checked && !this.selectedFunders.find(entity => value === entity)) {
this.selectedFunders.push(value);
this.fundersCtrl.setControl(this.fundersCtrl.value.length, this._fb.control(value));
} else if(!event.target.checked) {
let index = this.selectedFunders.indexOf(value);
if(index !== -1) {
this.selectedFunders.splice(index, 1);
this.fundersCtrl.removeAt(index);
}
}
}
}
isSelected(value: string) {
return this.filterForm && this.filterForm.get('funder').value.find(funder => funder === value)
}
} }

View File

@ -1,62 +1,59 @@
<div class="uk-width-1-1 uk-flex uk-flex-right@m uk-flex-center uk-flex-wrap uk-flex-middle uk-grid uk-margin-bottom" uk-grid> <div class="uk-section uk-flex uk-flex-center uk-flex uk-flex-middle">
<div #searchInputComponent search-input [control]="filterForm" [showSearch]="false" <div search-input class="uk-width-xlarge@l uk-width-large" [searchControl]="filterForm" searchInputClass="outer"
placeholder="Search Zenodo Communites" placeholder="Search Zenodo Communities" [disabled]="zenodoCommunitySearchUtils.status == errorCodes.LOADING"></div>
[selected]="zenodoCommunitySearchUtils.keyword" (closeEmitter)="onSearchClose()" (resetEmitter)="resetInput()"
[bordered]="true" colorClass="uk-text-secondary"
class="uk-width-1-2@l uk-width-1-2@m uk-width-1-1"></div>
</div> </div>
<div *ngIf="zenodoCommunitySearchUtils.status == errorCodes.LOADING" class="uk-position-large-top"> <div class="uk-section uk-section-small uk-position-relative">
<loading></loading> <div *ngIf="zenodoCommunitySearchUtils.status == errorCodes.LOADING" class="uk-position-center">
</div> <loading></loading>
<div *ngIf="zenodoCommunitySearchUtils.status == errorCodes.NONE "
class="uk-card uk-card-default uk-padding-large uk-text-center uk-margin-bottom uk-text-bold">
<div> No zenodo communities found
</div> </div>
</div> <div *ngIf="zenodoCommunitySearchUtils.status !== errorCodes.LOADING">
<div *ngIf="zenodoCommunitySearchUtils.totalResults > 0"> <div *ngIf="zenodoCommunitySearchUtils.totalResults == 0"
<no-load-paging [type]="'Zenodo Communities'" class="uk-card uk-card-default uk-padding-large uk-text-center uk-margin-bottom uk-text-bold">
[page]="zenodoCommunitySearchUtils.page" [pageSize]="rowsOnPage" (pageChange)="goTo($event.value)" <div>No zenodo communities found</div>
[totalResults]="zenodoCommunitySearchUtils.totalResults"> </div>
</no-load-paging> <ng-container *ngIf="zenodoCommunitySearchUtils.totalResults > 0">
<ul class="uk-list"> <no-load-paging [type]="'zenodo communities'"
<li class="" *ngFor="let item of zenodoCommunities; let i = index;" [page]="zenodoCommunitySearchUtils.page" [pageSize]="rowsOnPage" (pageChange)="goTo($event.value)"
class="uk-card uk-card-default uk-margin-bottom uk-padding"> [totalResults]="zenodoCommunitySearchUtils.totalResults">
<div class="uk-grid uk-grid-divider " uk-grid> </no-load-paging>
<div class="uk-width-expand"> <div class="uk-grid uk-grid-large uk-child-width-1-1 uk-margin-medium-top uk-margin-bottom" uk-grid>
<preview-zenodo-community [item]="item"></preview-zenodo-community> <div *ngFor="let item of zenodoCommunities; let i=index">
</div> <div class="uk-card uk-card-default">
<div class="uk-card-body">
<div class="uk-width-auto@m uk-width-1-1"> <preview-zenodo-community [item]="item" [master]="masterCommunity && item.id==masterCommunity.id"></preview-zenodo-community>
<div class=" uk-flex uk-flex-middle uk-flex-center uk-flex-column uk-height-1-1"> </div>
<div class="uk-padding-small uk-padding-remove-horizontal"> <div *ngIf="!masterCommunity || item.id!==masterCommunity.id" class="uk-card-footer uk-padding-remove-vertical">
<div [class.hide-element]="inThelist(item, selectedCommunities)"> <div class="uk-grid uk-grid-small uk-flex-nowrap uk-grid-divider uk-flex-right" uk-grid>
<span *ngIf=" masterCommunity && item.id==masterCommunity.id" class="uk-label uk-label-warning">Master zenodo community</span> <div *ngIf="!inThelist(item, selectedCommunities) && !(masterCommunity && item.id==masterCommunity.id)">
<div (click)="addCommunity(item)" class="uk-button action uk-flex uk-flex-middle" <div class="uk-padding-small uk-padding-remove-horizontal">
uk-tooltip="title:<div class='uk-padding-small'><div class='uk-margin-bottom uk-text-bold'>Add new community </div><div>Newly added Zenodo communities will be linked to your community on the next run of our algorithms.</div></div>"> <a (click)="addCommunity(item)" class="uk-button uk-button-link uk-flex uk-flex-middle">
<!-- <i class="clickable uk-text-success" uk-icon="plus"></i>--> <icon name="add" [flex]="true"></icon>
<div class="uk-text-success"> <span class="uk-margin-small-left">
<icon name="add"></icon> Add
</span>
</a>
</div> </div>
<span class="uk-margin-small-left"> Add community</span>
</div> </div>
</div> <div *ngIf="inThelist(item, selectedCommunities)">
<div <div class="uk-padding-small uk-padding-remove-horizontal">
[class.hide-element]="!inThelist(item, selectedCommunities) && !(masterCommunity && item.id==masterCommunity.id)"> <a (click)="removeCommunity(item)"
<div (click)="removeCommunity(item)" class="uk-button action uk-flex uk-flex-middle"> class="uk-button uk-button-link uk-flex uk-flex-middle">
<icon name="remove_circle_outline"></icon> <icon name="remove" [flex]="true"></icon>
<span class="uk-margin-small-left"> Remove community </span> <span class="uk-margin-small-left">Remove</span>
</a>
</div>
</div> </div>
</div> </div>
</div> </div>
</div> </div>
</div> </div>
</div> </div>
</li> <div class="uk-margin-small-top">
</ul> <paging-no-load [currentPage]="zenodoCommunitySearchUtils.page"
<no-load-paging [type]="'Zenodo Communities'" [totalResults]="zenodoCommunitySearchUtils.totalResults" [size]="rowsOnPage"
[page]="zenodoCommunitySearchUtils.page" [pageSize]="rowsOnPage" (pageChange)="goTo($event.value)" (pageChange)="goTo($event.value)" customClasses="uk-flex-right@m uk-flex-center">
[totalResults]="zenodoCommunitySearchUtils.totalResults"> </paging-no-load>
</no-load-paging> </div>
</ng-container>
</div>
</div> </div>

View File

@ -1,16 +1,16 @@
import {Component, Input, OnInit, ViewChild} from '@angular/core'; import {Component, EventEmitter, Input, OnInit, Output, ViewChild} from '@angular/core';
import {FormBuilder, FormControl} from '@angular/forms'; import {FormBuilder, FormControl} from '@angular/forms';
import {ActivatedRoute, Router} from '@angular/router'; import {ActivatedRoute, Router} from '@angular/router';
import {EnvProperties} from '../../openaireLibrary/utils/properties/env-properties'; import {EnvProperties} from '../../openaireLibrary/utils/properties/env-properties';
import {properties} from "../../../environments/environment";
import {ErrorCodes} from '../../openaireLibrary/utils/properties/errorCodes'; import {ErrorCodes} from '../../openaireLibrary/utils/properties/errorCodes';
import {SearchUtilsClass} from '../../openaireLibrary/searchPages/searchUtils/searchUtils.class'; import {SearchUtilsClass} from '../../openaireLibrary/searchPages/searchUtils/searchUtils.class';
import {ZenodoCommunitiesService} from '../../openaireLibrary/connect/zenodoCommunities/zenodo-communities.service'; import {ZenodoCommunitiesService} from '../../openaireLibrary/connect/zenodoCommunities/zenodo-communities.service';
import {Session} from '../../openaireLibrary/login/utils/helper.class';
import {LoginErrorCodes} from '../../openaireLibrary/login/utils/guardHelper.class';
import {ManageZenodoCommunitiesService} from '../../services/manageZenodoCommunities.service'; import {ManageZenodoCommunitiesService} from '../../services/manageZenodoCommunities.service';
import {SearchInputComponent} from '../../openaireLibrary/sharedComponents/search-input/search-input.component';
import {Subject, Subscription} from 'rxjs'; import {Subject, Subscription} from 'rxjs';
import {debounceTime, distinctUntilChanged} from 'rxjs/operators'; import {debounceTime, distinctUntilChanged} from 'rxjs/operators';
import {CommunityInfo} from "../../openaireLibrary/connect/community/communityInfo";
import {HelperFunctions} from "../../openaireLibrary/utils/HelperFunctions.class";
declare var UIkit; declare var UIkit;
@ -22,9 +22,8 @@ export class AddZenodoCommunitiesComponent implements OnInit {
public zenodoCommunities = null; // zenodo search API results public zenodoCommunities = null; // zenodo search API results
public totalZenodoCommunities = null; public totalZenodoCommunities = null;
@Input() properties: EnvProperties = null; properties: EnvProperties = properties;
@Input() communityId = null; @Input() community: CommunityInfo = null;
@ViewChild('searchInputComponent') searchInputComponent: SearchInputComponent;
public filterForm: FormControl; public filterForm: FormControl;
private subscriptions: any[] = []; private subscriptions: any[] = [];
public subResults: any; public subResults: any;
@ -34,6 +33,7 @@ export class AddZenodoCommunitiesComponent implements OnInit {
public rowsOnPage = 10; public rowsOnPage = 10;
@Input() masterCommunity = null; @Input() masterCommunity = null;
@Input() selectedCommunities = []; @Input() selectedCommunities = [];
@Output() zenodoCommunitiesChanged = new EventEmitter();
constructor(private route: ActivatedRoute, constructor(private route: ActivatedRoute,
private _router: Router, private _router: Router,
@ -58,73 +58,14 @@ export class AddZenodoCommunitiesComponent implements OnInit {
})); }));
this.zenodoCommunitySearchUtils.keyword = ""; this.zenodoCommunitySearchUtils.keyword = "";
if (!Session.isLoggedIn()) { this.zenodoCommunitySearchUtils.status = this.errorCodes.LOADING;
this._router.navigate(['/user-info'], { if (this.community.communityId != null && this.community.communityId != '') {
queryParams: { this._zenodoCommunitieService.getZenodoCommunities(this.properties, this.properties.zenodoCommunities + "?page=" + this.zenodoCommunitySearchUtils.page + "&size=" + this.rowsOnPage).subscribe(
"errorCode": LoginErrorCodes.NOT_VALID,
"redirectUrl": this._router.url
}
});
} else {
this.zenodoCommunitySearchUtils.status = this.errorCodes.LOADING;
if (this.communityId != null && this.communityId != '') {
this._zenodoCommunitieService.getZenodoCommunities(this.properties, this.properties.zenodoCommunities + "?page=" + this.zenodoCommunitySearchUtils.page + "&size=" + this.rowsOnPage).subscribe(
result => {
this.zenodoCommunities = result[0];
this.totalZenodoCommunities = result[1];
this.zenodoCommunitySearchUtils.totalResults = result[1];
this.zenodoCommunitySearchUtils.page = 1;
this.zenodoCommunitySearchUtils.size = this.rowsOnPage;
if (this.totalZenodoCommunities == 0) {
this.zenodoCommunitySearchUtils.status = this.errorCodes.NONE;
} else {
this.zenodoCommunitySearchUtils.status = this.errorCodes.DONE;
}
},
error => {
this.zenodoCommunitySearchUtils.status = this.errorCodes.ERROR;
}
);
}
}
}
ngOnDestroy() {
this.subscriptions.forEach(subscription => {
if (subscription instanceof Subscription) {
subscription.unsubscribe();
}
});
if(this.subResults){
this.subResults.unsubscribe();
}
}
public goTo(page: number = 1) {
if (!Session.isLoggedIn()) {
this._router.navigate(['/user-info'], {
queryParams: {
"errorCode": LoginErrorCodes.NOT_VALID,
"redirectUrl": this._router.url
}
});
} else {
this.zenodoCommunitySearchUtils.page = page;
this.zenodoCommunitySearchUtils.status = this.errorCodes.LOADING;
if(this.subResults){
this.subResults.unsubscribe();
}
this.subResults = this._zenodoCommunitieService.getZenodoCommunities(this.properties,
this.properties.zenodoCommunities + "?page=" + this.zenodoCommunitySearchUtils.page
+ "&size=" + this.rowsOnPage
+ ((this.zenodoCommunitySearchUtils.keyword) ? ("&q=" + this.zenodoCommunitySearchUtils.keyword) : "")
).subscribe(
result => { result => {
this.zenodoCommunities = result[0]; this.zenodoCommunities = result[0];
this.totalZenodoCommunities = result[1]; this.totalZenodoCommunities = result[1];
this.zenodoCommunitySearchUtils.totalResults = result[1]; this.zenodoCommunitySearchUtils.totalResults = result[1];
this.zenodoCommunitySearchUtils.page = 1;
this.zenodoCommunitySearchUtils.size = this.rowsOnPage; this.zenodoCommunitySearchUtils.size = this.rowsOnPage;
if (this.totalZenodoCommunities == 0) { if (this.totalZenodoCommunities == 0) {
this.zenodoCommunitySearchUtils.status = this.errorCodes.NONE; this.zenodoCommunitySearchUtils.status = this.errorCodes.NONE;
@ -140,6 +81,47 @@ export class AddZenodoCommunitiesComponent implements OnInit {
} }
} }
ngOnDestroy() {
this.subscriptions.forEach(subscription => {
if (subscription instanceof Subscription) {
subscription.unsubscribe();
}
});
if(this.subResults){
this.subResults.unsubscribe();
}
}
public goTo(page: number = 1) {
HelperFunctions.scroll();
this.zenodoCommunitySearchUtils.page = page;
this.zenodoCommunitySearchUtils.status = this.errorCodes.LOADING;
if(this.subResults){
this.subResults.unsubscribe();
}
this.subResults = this._zenodoCommunitieService.getZenodoCommunities(this.properties,
this.properties.zenodoCommunities + "?page=" + this.zenodoCommunitySearchUtils.page
+ "&size=" + this.rowsOnPage
+ ((this.zenodoCommunitySearchUtils.keyword) ? ("&q=" + this.zenodoCommunitySearchUtils.keyword) : "")
).subscribe(
result => {
this.zenodoCommunities = result[0];
this.totalZenodoCommunities = result[1];
this.zenodoCommunitySearchUtils.totalResults = result[1];
this.zenodoCommunitySearchUtils.size = this.rowsOnPage;
if (this.totalZenodoCommunities == 0) {
this.zenodoCommunitySearchUtils.status = this.errorCodes.NONE;
} else {
this.zenodoCommunitySearchUtils.status = this.errorCodes.DONE;
}
},
error => {
this.zenodoCommunitySearchUtils.status = this.errorCodes.ERROR;
}
);
}
totalPages(): number { totalPages(): number {
let totalPages: any = this.zenodoCommunitySearchUtils.totalResults / (this.rowsOnPage); let totalPages: any = this.zenodoCommunitySearchUtils.totalResults / (this.rowsOnPage);
if (!(Number.isInteger(totalPages))) { if (!(Number.isInteger(totalPages))) {
@ -150,73 +132,55 @@ export class AddZenodoCommunitiesComponent implements OnInit {
public addCommunity(community) { public addCommunity(community) {
if (!Session.isLoggedIn()) { this.subscriptions.push(this._manageZenodoCommunitiesService.addZCommunity(this.properties, this.community.communityId, community.id).subscribe(
this._router.navigate(['/user-info'], { data => {
queryParams: { community["openaireId"] = data.id;
"errorCode": LoginErrorCodes.NOT_VALID, this.selectedCommunities.push(community);
"redirectUrl": this._router.url UIkit.notification('Community successfully added!', {
} status: 'success',
}); timeout: 6000,
} else { pos: 'bottom-right'
this.subscriptions.push(this._manageZenodoCommunitiesService.addZCommunity(this.properties, this.communityId, community.id).subscribe( });
data => { this.zenodoCommunitiesChanged.emit({
community["openaireId"] = data.id; value: this.selectedCommunities,
this.selectedCommunities.push(community); });
UIkit.notification('Community successfully added!', { },
status: 'success', err => {
timeout: 6000, this.handleError('An error has been occurred. Try again later!');
pos: 'bottom-right' console.log(err.status);
}); }
}, ));
err => {
this.handleError('An error has been occurred. Try again later!');
console.log(err.status);
}/*,
() => {
console.info("completed ADD");
}*/
));
}
} }
public removeCommunity(comm) { public removeCommunity(comm) {
if (!Session.isLoggedIn()) { var openaireId = this.getOpenaireId(comm);
this._router.navigate(['/user-info'], { this.subscriptions.push(this._manageZenodoCommunitiesService.removeZCommunity(this.properties, this.community.communityId, openaireId,).subscribe(
queryParams: { data => {
"errorCode": LoginErrorCodes.NOT_VALID, var pos = -1;
"redirectUrl": this._router.url for (var i = 0; i < this.selectedCommunities.length; i++) {
if (this.selectedCommunities[i].id == comm.id) {
pos = i;
break;
}
}
if (pos != -1) {
this.selectedCommunities.splice(pos, 1);
} }
});
} else {
var openaireId = this.getOpenaireId(comm);
this.subscriptions.push(this._manageZenodoCommunitiesService.removeZCommunity(this.properties, this.communityId, openaireId,).subscribe(
data => {
var pos = -1;
for (var i = 0; i < this.selectedCommunities.length; i++) {
if (this.selectedCommunities[i].id == comm.id) {
pos = i;
break;
}
}
if (pos != -1) {
this.selectedCommunities.splice(pos, 1);
}
UIkit.notification('Community successfully removed!', { UIkit.notification('Community successfully removed!', {
status: 'success', status: 'success',
timeout: 6000, timeout: 6000,
pos: 'bottom-right' pos: 'bottom-right'
}); });
}, this.zenodoCommunitiesChanged.emit({
err => { value: this.selectedCommunities,
this.handleError('An error has been occurred. Try again later!'); });
console.log(err.status); },
}/*, err => {
() => { this.handleError('An error has been occurred. Try again later!');
console.info("completed remove"); console.log(err.status);
}*/ }
)); ));
}
} }
public inThelist(community: any, list): any { public inThelist(community: any, list): any {
@ -237,13 +201,8 @@ export class AddZenodoCommunitiesComponent implements OnInit {
return null; return null;
} }
public onSearchClose() { get loading() {
this.zenodoCommunitySearchUtils.keyword = this.filterForm.value; return this.zenodoCommunitySearchUtils.status == this.errorCodes.LOADING
}
public resetInput() {
this.zenodoCommunitySearchUtils.keyword = null;
this.searchInputComponent.reset()
} }
handleError(message: string) { handleError(message: string) {

View File

@ -1,72 +1,78 @@
<div page-content> <div page-content (stickyEmitter)="stickyPageHeader = $event">
<div header> <div header>
<community-info tab="zenodo-communities"></community-info> <div class="uk-flex uk-flex-middle uk-margin-top info" [class.uk-active]="stickyPageHeader">
<div class="uk-width-1-1 uk-flex uk-flex-right@m uk-flex-center uk-flex-wrap uk-flex-middle uk-grid" uk-grid> <div>
<div class="uk-flex-last@m"> <div class="uk-margin-remove uk-text-background uk-text-bold uk-h6">Admin Dashboard - Manage Zenodo Communities
<a (click)="addNew()" </div>
uk-tooltip="title:<div class='uk-padding-small'><div class='uk-margin-bottom uk-text-bold'> Search and add more Zenodo Communities</div><div>The research results of a Zenodo community specified here will be automatically linked to your community dashboard.</div></div>" <h1 class="uk-h4 uk-margin-remove">{{community.shortTitle}}</h1>
class="uk-flex uk-flex-middle uk-text-uppercase">
<button class="large uk-icon-button uk-button-secondary">
<icon name="add"></icon>
</button>
<button class="uk-button uk-button-link uk-margin-small-left uk-text-secondary">Add new zenodo
communities
</button>
</a>
</div> </div>
<div #searchInputComponent search-input [control]="filterForm" [showSearch]="false"
placeholder="Search Zenodo Communities "
[selected]="searchUtils.keyword" (closeEmitter)="onSearchClose()" (resetEmitter)="resetInput()"
[bordered]="true" colorClass="uk-text-secondary"
class="uk-width-1-3@xl uk-width-2-5@l uk-width-1-2@m uk-width-1-1"></div>
</div> </div>
<community-info tab="zenodo-communities"></community-info>
</div> </div>
<div inner> <div inner>
<div *ngIf="searchUtils.status === errorCodes.LOADING" class="uk-position-center"> <div class="uk-flex uk-flex-right@m uk-flex-center uk-flex-middle uk-grid uk-margin-top" uk-grid>
<loading></loading> <div search-input [expandable]="true" [searchControl]="filterForm" searchInputClass="outer"
placeholder="Search Zenodo Community" [disabled]="searchUtils.status === errorCodes.LOADING"
class="uk-width-1-3@xl uk-width-2-5@l uk-width-1-2@m uk-width-1-1"></div>
<div>
<button class="uk-button uk-button-default uk-flex uk-flex-middle" (click)="addNew()"
uk-tooltip="title:<div class='uk-text-bold'> Search and add more Zenodo Communities</div><div>The research results of a Zenodo community specified here will be automatically linked to your community dashboard.</div>"
[disabled]="searchUtils.status === errorCodes.LOADING || disableAdd"
[class.uk-disabled]="searchUtils.status === errorCodes.LOADING || disableAdd">
<icon name="add" [flex]="true"></icon>
<span class="uk-margin-small-left uk-text-bold uk-text-uppercase">New Zenodo Community</span>
</button>
</div>
</div> </div>
<div *ngIf="searchUtils.status != errorCodes.LOADING && previewCommunities">
<div *ngIf="masterCommunity"
class="uk-animation-fade uk-alert uk-alert-primary uk-padding-small uk-margin-large-bottom">
<div class="uk-text-large uk-margin-bottom">Main Zenodo community</div>
<preview-zenodo-community [item]="masterCommunity"></preview-zenodo-community>
</div>
<div *ngIf="previewCommunities.length == 0"
class="uk-card uk-card-default uk-padding-large uk-text-center uk-margin-bottom uk-text-bold">
<div> No zenodo communities found
</div>
</div>
<div *ngIf="previewCommunities.length > 0">
<no-load-paging *ngIf=" previewCommunities && previewCommunities.length > 0" [type]="'Zenodo Communities'"
[page]="page" [pageSize]="size" (pageChange)="page = $event.value"
[totalResults]="previewCommunities.length">
</no-load-paging>
<ul class="uk-list">
<li class="" *ngFor="let item of previewCommunities; let i = index;" <div class="uk-section uk-section-small uk-position-relative" style="min-height: 60vh">
class="uk-card uk-card-default uk-margin-bottom" <div *ngIf="searchUtils.status == errorCodes.LOADING" class="uk-position-center">
[class.uk-hidden]="i >= page * size || <loading></loading>
i < (page - 1) * size"> </div>
<div class="uk-grid uk-padding uk-grid-divider " uk-grid> <div *ngIf="searchUtils.status !== errorCodes.LOADING">
<div class="uk-width-expand@m uk-width-1-1"> <div *ngIf="previewCommunities.length == 0"
<preview-zenodo-community [item]="item"></preview-zenodo-community> class="uk-card uk-card-default uk-padding-large uk-text-center uk-margin-bottom uk-text-bold">
</div> <div>No zenodo communities found</div>
<div class="uk-text-center uk-width-auto@m uk-width-1-1"> </div>
<div class=" uk-flex uk-flex-middle uk-flex-center uk-height-1-1"> <div *ngIf="previewCommunities.length > 0">
<div class="uk-padding-small uk-padding-remove-horizontal"> <no-load-paging [type]="'content providers'"
<div (click)="removeCommunity(item)" (pageChange)="updatePage($event)"
class="uk-button action uk-flex uk-flex-middle "> [page]="page" [pageSize]="size"
<icon name="remove_circle_outline"></icon> [totalResults]="previewCommunities.length">
<span class="uk-margin-small-left">Remove community</span> </no-load-paging>
<!-- <ul class="uk-margin-medium-top uk-margin-bottom uk-list uk-list-xlarge">-->
<div class="uk-grid uk-grid-large uk-child-width-1-1 uk-margin-medium-top uk-margin-bottom" uk-grid>
<div *ngFor="let item of previewCommunities.slice((this.page - 1)*this.size, this.page*this.size); let i=index">
<div class="uk-card uk-card-default">
<div class="uk-card-body">
<preview-zenodo-community [item]="item" [master]="masterCommunity && item.id==masterCommunity.id"></preview-zenodo-community>
</div>
<div *ngIf="!masterCommunity || item.id!==masterCommunity.id" class="uk-card-footer uk-padding-remove-vertical">
<div class="uk-grid uk-grid-small uk-flex-nowrap uk-grid-divider uk-flex-right" uk-grid>
<div>
<div class="uk-padding-small uk-padding-remove-horizontal">
<button class="uk-button uk-button-link uk-flex uk-flex-middle"
(click)="removeCommunity(item)">
<icon name="remove" [flex]="true"></icon>
<span class="uk-margin-xsmall-left">Remove</span>
</button>
</div>
</div> </div>
</div> </div>
</div> </div>
</div> </div>
</div> </div>
</li> </div>
</ul> <!-- </ul>-->
<div class="uk-margin-small-top">
<paging-no-load [currentPage]="page"
[totalResults]="previewCommunities.length" [size]="size"
(pageChange)="updatePage($event)" customClasses="uk-flex-right@m uk-flex-center">
</paging-no-load>
</div>
</div>
</div> </div>
</div> </div>
</div> </div>
</div> </div>
<modal-alert #AlertModalDeleteCommunity (alertOutput)="confirmedDeleteCommunity($event)"></modal-alert> <modal-alert #AlertModalDeleteCommunity (alertOutput)="confirmedDeleteCommunity($event)" [overflowBody]="false"></modal-alert>

View File

@ -2,23 +2,23 @@ import {
Component, Component,
EventEmitter, EventEmitter,
Input, Input,
OnChanges,
OnDestroy, OnDestroy,
OnInit, OnInit,
Output, SimpleChanges, Output,
ViewChild, ViewChild,
ViewEncapsulation ViewEncapsulation
} from '@angular/core'; } from '@angular/core';
import {FormBuilder, FormControl} from '@angular/forms'; import {FormBuilder, FormControl} from '@angular/forms';
import {ActivatedRoute, Router} from '@angular/router'; import {ActivatedRoute, Router} from '@angular/router';
import {EnvProperties} from '../../openaireLibrary/utils/properties/env-properties'; import {EnvProperties} from '../../openaireLibrary/utils/properties/env-properties';
import {properties} from "../../../environments/environment";
import {ErrorCodes} from '../../openaireLibrary/utils/properties/errorCodes'; import {ErrorCodes} from '../../openaireLibrary/utils/properties/errorCodes';
import {SearchUtilsClass} from '../../openaireLibrary/searchPages/searchUtils/searchUtils.class'; import {SearchUtilsClass} from '../../openaireLibrary/searchPages/searchUtils/searchUtils.class';
import {Session} from '../../openaireLibrary/login/utils/helper.class';
import {LoginErrorCodes} from '../../openaireLibrary/login/utils/guardHelper.class';
import {ManageZenodoCommunitiesService} from '../../services/manageZenodoCommunities.service'; import {ManageZenodoCommunitiesService} from '../../services/manageZenodoCommunities.service';
import {SearchInputComponent} from '../../openaireLibrary/sharedComponents/search-input/search-input.component'; import {SearchInputComponent} from '../../openaireLibrary/sharedComponents/search-input/search-input.component';
import {Subscription} from 'rxjs'; import {Subscription} from 'rxjs';
import {CommunityInfo} from "../../openaireLibrary/connect/community/communityInfo";
import {HelperFunctions} from "../../openaireLibrary/utils/HelperFunctions.class";
declare var UIkit; declare var UIkit;
@ -29,9 +29,10 @@ declare var UIkit;
}) })
export class ManageZenodoCommunitiesComponent implements OnInit, OnDestroy { export class ManageZenodoCommunitiesComponent implements OnInit, OnDestroy {
@Input() properties: EnvProperties = null; properties: EnvProperties = properties;
@Input() communityId = null; @Input() community: CommunityInfo = null;
@Input() public loading: boolean = true;
@Input() public disableAdd: boolean = false;
@Input() searchUtils: SearchUtilsClass = null; @Input() searchUtils: SearchUtilsClass = null;
errorCodes: ErrorCodes; errorCodes: ErrorCodes;
@ -42,13 +43,17 @@ export class ManageZenodoCommunitiesComponent implements OnInit, OnDestroy {
@ViewChild('AlertModalDeleteCommunity') alertModalDeleteCommunity; @ViewChild('AlertModalDeleteCommunity') alertModalDeleteCommunity;
selectedToDelete = null; selectedToDelete = null;
@Output() toggleView: EventEmitter<any> = new EventEmitter(); @Output() addZenodoCommunity: EventEmitter<any> = new EventEmitter();
@Output() zenodoCommunitiesChanged = new EventEmitter();
page = 1; page = 1;
size = 10; size = 10;
@ViewChild('searchInputComponent') searchInputComponent: SearchInputComponent; @ViewChild('searchInputComponent') searchInputComponent: SearchInputComponent;
public filterForm: FormControl; public filterForm: FormControl;
private subscriptions: any[] = []; private subscriptions: any[] = [];
public stickyPageHeader: boolean = false;
constructor(private route: ActivatedRoute, constructor(private route: ActivatedRoute,
private _router: Router, private _router: Router,
public _fb: FormBuilder, public _fb: FormBuilder,
@ -83,7 +88,7 @@ export class ManageZenodoCommunitiesComponent implements OnInit, OnDestroy {
public filterPreviewCommunities(value: string) { public filterPreviewCommunities(value: string) {
this.previewCommunities = this.selectedCommunities.filter(community => { this.previewCommunities = this.selectedCommunities.filter(community => {
return community.title.toLowerCase().indexOf(value.toLowerCase()) != -1 return !value || community.title.toLowerCase().indexOf(value.toLowerCase()) != -1
}); });
if (this.previewCommunities.slice((this.page - 1) * this.rowsOnPage, this.page * this.rowsOnPage).length == 0) { if (this.previewCommunities.slice((this.page - 1) * this.rowsOnPage, this.page * this.rowsOnPage).length == 0) {
this.page = 1; this.page = 1;
@ -91,70 +96,54 @@ export class ManageZenodoCommunitiesComponent implements OnInit, OnDestroy {
} }
public confirmedDeleteCommunity(data: any) { public confirmedDeleteCommunity(data: any) {
if (!Session.isLoggedIn()) { this.subscriptions.push(this._manageZenodoCommunitiesService.removeZCommunity(this.properties, this.community.communityId, this.selectedToDelete.openaireId).subscribe(
this._router.navigate(['/user-info'], { data => {
queryParams: { var pos = -1;
"errorCode": LoginErrorCodes.NOT_VALID, for (var i = 0; i < this.selectedCommunities.length; i++) {
"redirectUrl": this._router.url if (this.selectedCommunities[i].id == this.selectedToDelete.id) {
pos = i;
break;
}
} }
}); if (pos != -1) {
} else { this.selectedCommunities.splice(pos, 1);
this.subscriptions.push(this._manageZenodoCommunitiesService.removeZCommunity(this.properties, this.communityId, this.selectedToDelete.openaireId).subscribe(
data => {
var pos = -1;
for (var i = 0; i < this.selectedCommunities.length; i++) {
if (this.selectedCommunities[i].id == this.selectedToDelete.id) {
pos = i;
break;
}
}
if (pos != -1) {
this.selectedCommunities.splice(pos, 1);
this.searchUtils.totalResults = this.selectedCommunities.length;
}
this.searchUtils.totalResults = this.selectedCommunities.length; this.searchUtils.totalResults = this.selectedCommunities.length;
this.filterPreviewCommunities(this.filterForm.value);
UIkit.notification('Community has been <b>successfully removed</b>!', {
status: 'success',
timeout: 6000,
pos: 'bottom-right'
});
},
err => {
this.handleError('An error has been occurred. Try again later!');
console.log(err.status);
} }
)); this.searchUtils.totalResults = this.selectedCommunities.length;
} this.filterPreviewCommunities(this.filterForm.value);
UIkit.notification('Community has been <b>successfully removed</b>!', {
status: 'success',
timeout: 6000,
pos: 'bottom-right'
});
this.zenodoCommunitiesChanged.emit({
value: this.selectedCommunities,
});
},
err => {
this.handleError('An error has been occurred. Try again later!');
console.log(err.status);
}
));
} }
public removeCommunity(comm) { public removeCommunity(comm) {
if (!Session.isLoggedIn()) { this.selectedToDelete = comm;
this._router.navigate(['/user-info'], { this.alertModalDeleteCommunity.cancelButton = true;
queryParams: { this.alertModalDeleteCommunity.okButton = true;
"errorCode": LoginErrorCodes.NOT_VALID, this.alertModalDeleteCommunity.alertTitle = "Remove zenodo community";
"redirectUrl": this._router.url let title = "";
} if (comm.title) {
}); title = comm.title;
} else {
this.selectedToDelete = comm;
this.alertModalDeleteCommunity.cancelButton = true;
this.alertModalDeleteCommunity.okButton = true;
this.alertModalDeleteCommunity.alertTitle = "Remove zenodo community?";
let title = "";
if (comm.title) {
title = comm.title;
}
this.alertModalDeleteCommunity.message = "Zenodo community";
if (title) {
this.alertModalDeleteCommunity.message += " '" + title + "' ";
}
this.alertModalDeleteCommunity.message += "will be removed from your community. Are you sure?";
this.alertModalDeleteCommunity.okButtonText = "Yes";
this.alertModalDeleteCommunity.open();
} }
this.alertModalDeleteCommunity.message = "Zenodo community";
if (title) {
this.alertModalDeleteCommunity.message += " '" + title + "' ";
}
this.alertModalDeleteCommunity.message += "will be removed from your community. Are you sure?";
this.alertModalDeleteCommunity.okButtonText = "Yes";
this.alertModalDeleteCommunity.open();
} }
@ -166,17 +155,13 @@ export class ManageZenodoCommunitiesComponent implements OnInit, OnDestroy {
return totalPages; return totalPages;
} }
public updatePage($event) {
HelperFunctions.scroll();
this.page = $event.value;
}
addNew() { addNew() {
this.toggleView.emit(null); this.addZenodoCommunity.emit();
}
public onSearchClose() {
this.searchUtils.keyword = this.filterForm.value;
}
public resetInput() {
this.searchUtils.keyword = null;
this.searchInputComponent.reset()
} }
handleError(message: string) { handleError(message: string) {

View File

@ -3,30 +3,36 @@ import {Component, Input} from '@angular/core';
@Component({ @Component({
selector: 'preview-zenodo-community', selector: 'preview-zenodo-community',
template: ` template: `
<div class="uk-grid uk-flex uk-flex-middle"> <div class="header uk-grid uk-grid-medium uk-flex-middle" uk-grid>
<a *ngIf="item.logoUrl" target="_blank" [href]="item.link" class="uk-width-auto"> <div class="uk-width-auto" *ngIf="item.logoUrl">
<img class="uk-comment-avatar" src="{{item.logoUrl}}" width="80" height="80" alt=""> <a target="_blank" [href]="item.link">
</a> <img *ngIf="item.logoUrl"
<div class="uk-width-expand"> src="{{item.logoUrl}}" width="80" height="80"
<a class="" target="_blank" href="{{item.link}}"> alt="{{item.title}}">
<span *ngIf="item.title">{{item.title}}</span> </a>
<span *ngIf="!item.title">[no name available]</span> </div>
<span class="custom-external custom-icon space"></span> <div class="uk-width-expand">
</a> <div *ngIf="master"><div class="uk-badge uk-margin-small-bottom">Main Zenodo Community</div></div>
<div class="uk-comment-meta uk-margin-small-top"> <h2 class="uk-margin-remove uk-text-break uk-inline-block uk-h6">
last update: {{item.date | date:'yyyy/MM/dd'}} <a class="custom-external uk-link uk-link-text uk-width-expand" target="_blank"
</div> href="{{item.link}}">
</div> <span *ngIf="item.title">{{item.title}}</span>
</div> <span *ngIf="!item.title">[no name available]</span>
</a>
<div *ngIf="item.description" </h2>
class="uk-comment-body uk-text-meta uk-margin-top multi-line-ellipsis lines-3 "> <div *ngIf="item.date" class="uk-text-small uk-margin-small-top">
<p>{{item.description|htmlToString}}</p> <span class="uk-text-meta">Last update: </span>{{item.date | date:'yyyy/MM/dd'}}
</div> </div>
</div>
</div>
<div class="uk-margin-top uk-text-small multi-line-ellipsis lines-3">
<div *ngIf="item.description" class="uk-margin-remove"
[innerHtml]="item.description"></div>
</div>
` `
}) })
export class PreviewZenodoCommunityComponent { export class PreviewZenodoCommunityComponent {
@Input() item; @Input() item;
@Input() master: boolean = false;
} }

View File

@ -1,8 +1,6 @@
import {Component, ElementRef, OnDestroy, OnInit, ViewChild} from '@angular/core'; import {Component, ElementRef, Input, OnDestroy, OnInit, ViewChild} from '@angular/core';
import {ActivatedRoute, Router} from '@angular/router'; import {ActivatedRoute, Router} from '@angular/router';
import {Session} from '../../openaireLibrary/login/utils/helper.class';
import {LoginErrorCodes} from '../../openaireLibrary/login/utils/guardHelper.class';
import {EnvProperties} from '../../openaireLibrary/utils/properties/env-properties'; import {EnvProperties} from '../../openaireLibrary/utils/properties/env-properties';
import {ZenodoCommunitiesService} from '../../openaireLibrary/connect/zenodoCommunities/zenodo-communities.service'; import {ZenodoCommunitiesService} from '../../openaireLibrary/connect/zenodoCommunities/zenodo-communities.service';
import {SearchZenodoCommunitiesService} from '../../openaireLibrary/connect/zenodoCommunities/searchZenodoCommunities.service'; import {SearchZenodoCommunitiesService} from '../../openaireLibrary/connect/zenodoCommunities/searchZenodoCommunities.service';
@ -12,7 +10,6 @@ import {CommunityInfo} from '../../openaireLibrary/connect/community/communityIn
import {ZenodoCommunityInfo} from '../../openaireLibrary/connect/zenodoCommunities/zenodoCommunityInfo'; import {ZenodoCommunityInfo} from '../../openaireLibrary/connect/zenodoCommunities/zenodoCommunityInfo';
import {SearchUtilsClass} from '../../openaireLibrary/searchPages/searchUtils/searchUtils.class'; import {SearchUtilsClass} from '../../openaireLibrary/searchPages/searchUtils/searchUtils.class';
import {ErrorCodes} from '../../openaireLibrary/utils/properties/errorCodes'; import {ErrorCodes} from '../../openaireLibrary/utils/properties/errorCodes';
import {HelperFunctions} from '../../openaireLibrary/utils/HelperFunctions.class';
import {Title} from '@angular/platform-browser'; import {Title} from '@angular/platform-browser';
import {properties} from '../../../environments/environment'; import {properties} from '../../../environments/environment';
import {Subscription} from 'rxjs'; import {Subscription} from 'rxjs';
@ -22,32 +19,21 @@ import {ManageZenodoCommunitiesComponent} from './manage-zenodo-communities.comp
@Component({ @Component({
selector: 'zenodo-communities', selector: 'zenodo-communities',
template: ` template: `
<div *ngIf="zenodoSearchUtils.status == errorCodes.LOADING" page-content> <manage-zenodo-communities #manage *ngIf="community && zenodoSearchUtils && zenodoSearchUtils.status != errorCodes.LOADING"
<div header> [loading]="showLoadingInRemove" [disableAdd]="add && add.loading"
<community-info tab="zenodo-communities"></community-info> [masterCommunity]=masterZenodoCommunity [selectedCommunities]=selectedCommunities
</div> [community]="community" [searchUtils]=zenodoSearchUtils (addZenodoCommunity)="openAddZenodoCommunites()"
<div inner> (zenodoCommunitiesChanged)="zenodoCommunitiesChanged($event)"></manage-zenodo-communities>
<div class="uk-position-center"> <fs-modal #fsModal>
<loading></loading> <add-zenodo-communities #add *ngIf="zenodoSearchUtils.status != errorCodes.LOADING" [masterCommunity]=masterZenodoCommunity
</div> [selectedCommunities]=selectedCommunities
</div> [community]="community" (zenodoCommunitiesChanged)="zenodoCommunitiesChanged($event)"></add-zenodo-communities>
</div>
<ng-container *ngIf="zenodoSearchUtils.status != errorCodes.LOADING">
<manage-zenodo-communities #manage *ngIf="communityId && zenodoSearchUtils" [masterCommunity]=masterZenodoCommunity [selectedCommunities]=selectedCommunities
[properties]=properties [communityId]=communityId [searchUtils]=zenodoSearchUtils
(toggleView)="toggleAction()"></manage-zenodo-communities>
</ng-container>
<fs-modal #fsModal (cancelEmitter)="toggleAction()">
<add-zenodo-communities *ngIf="zenodoSearchUtils.status != errorCodes.LOADING" [masterCommunity]=masterZenodoCommunity [selectedCommunities]=selectedCommunities
[properties]=properties [communityId]=communityId></add-zenodo-communities>
</fs-modal> </fs-modal>
` `
}) })
export class ZenodoCommunitiesComponent implements OnInit, OnDestroy { export class ZenodoCommunitiesComponent implements OnInit, OnDestroy {
public communityId: string = null; public community: CommunityInfo = null;
private community: CommunityInfo = null;
public toggle = false; public toggle = false;
public updateCommunityProjectsOnToggle = false;
public pageTitle = 'Manage zenodo communities'; public pageTitle = 'Manage zenodo communities';
masterZenodoCommunityId = null; masterZenodoCommunityId = null;
masterZenodoCommunity = null; masterZenodoCommunity = null;
@ -59,7 +45,8 @@ export class ZenodoCommunitiesComponent implements OnInit, OnDestroy {
public errorCodes: ErrorCodes = new ErrorCodes(); public errorCodes: ErrorCodes = new ErrorCodes();
subscriptions = []; subscriptions = [];
@ViewChild('fsModal', { static: true }) fullscreen: FullScreenModalComponent; @ViewChild('fsModal', { static: true }) fullscreen: FullScreenModalComponent;
@ViewChild('manage') manage: ManageZenodoCommunitiesComponent; @ViewChild(ManageZenodoCommunitiesComponent) manage: ManageZenodoCommunitiesComponent;
public showLoadingInRemove: boolean = true;
constructor(private element: ElementRef, private route: ActivatedRoute, private _router: Router, constructor(private element: ElementRef, private route: ActivatedRoute, private _router: Router,
private _zenodoCommunitieService: ZenodoCommunitiesService, private title: Title, private _zenodoCommunitieService: ZenodoCommunitiesService, private title: Title,
@ -70,55 +57,52 @@ export class ZenodoCommunitiesComponent implements OnInit, OnDestroy {
ngOnInit() { ngOnInit() {
this.zenodoSearchUtils.status = this.errorCodes.LOADING; this.zenodoSearchUtils.status = this.errorCodes.LOADING;
this.properties = properties; this.properties = properties;
this.route.params.subscribe(params => {
this.communityId = params['community'];
if (this.communityId) {
this.title.setTitle(this.communityId.toUpperCase() + ' | Zenodo Communities');
if (this.communityId != null && this.communityId !== '') {
this.subscriptions.push(this._communityService.getCommunityAsObservable().subscribe(
community => {
this.community = community;
this.masterZenodoCommunityId = this.community.zenodoCommunity;
if (this.masterZenodoCommunityId) {
this.subscriptions.push(this._zenodoCommunitieService.getZenodoCommunityById(this.properties,
this.properties.zenodoCommunities + this.masterZenodoCommunityId,
null).subscribe(
result => {
this.masterZenodoCommunity = result;
},
error => {
const emptyCommunity: ZenodoCommunityInfo = new ZenodoCommunityInfo();
emptyCommunity.id = this.masterZenodoCommunityId;
emptyCommunity.title = this.masterZenodoCommunityId;
this.masterZenodoCommunity = emptyCommunity;
// console.log("Master Zenodo community'"+this.masterZenodoCommunityId+"' couldn't be loaded");
}
));
}
this.zenodoSearchUtils.status = this.errorCodes.LOADING;
this._searchZenodoCommunitiesService.searchZCommunities(this.properties, this.communityId).subscribe(
result => {
this.selectedCommunityIds = result;
this.zenodoSearchUtils.totalResults = this.selectedCommunityIds.length;
if (this.selectedCommunityIds.length === 0) {
this.zenodoSearchUtils.status = this.errorCodes.NONE;
}
for (let i = 0; i < this.selectedCommunityIds.length; i++) {
this.getZenodoCommunityById(
this.selectedCommunityIds[i]['zenodoid'],
this.selectedCommunityIds[i]['id']);
}
}, this.subscriptions.push(this._communityService.getCommunityAsObservable().subscribe(
error => { community => {
console.log('list of zenodo communities couldn\'t be loaded'); this.community = community;
this.zenodoSearchUtils.status = this.errorCodes.DONE; this.title.setTitle(this.community.shortTitle.toUpperCase() + ' | Zenodo Communities');
} // this.handleError('System error retrieving community profile', error) this.masterZenodoCommunityId = this.community.zenodoCommunity;
); if (this.masterZenodoCommunityId) {
})); this.subscriptions.push(this._zenodoCommunitieService.getZenodoCommunityById(this.properties,
this.properties.zenodoCommunities + this.masterZenodoCommunityId,
null).subscribe(
result => {
this.masterZenodoCommunity = result;
this.selectedCommunities.unshift(this.masterZenodoCommunity);
},
error => {
const emptyCommunity: ZenodoCommunityInfo = new ZenodoCommunityInfo();
emptyCommunity.id = this.masterZenodoCommunityId;
emptyCommunity.title = this.masterZenodoCommunityId;
this.masterZenodoCommunity = emptyCommunity;
}
));
} }
} this.zenodoSearchUtils.status = this.errorCodes.LOADING;
}); this.zenodoSearchUtils.status = this.errorCodes.LOADING;
this._searchZenodoCommunitiesService.searchZCommunities(this.properties, this.community.communityId).subscribe(
result => {
this.selectedCommunityIds = result;
this.zenodoSearchUtils.totalResults = this.selectedCommunityIds.length;
if (this.selectedCommunityIds.length === 0) {
this.zenodoSearchUtils.status = this.errorCodes.NONE;
}
for (let i = 0; i < this.selectedCommunityIds.length; i++) {
this.getZenodoCommunityById(
this.selectedCommunityIds[i]['zenodoid'],
this.selectedCommunityIds[i]['id']);
}
},
error => {
console.log('list of zenodo communities couldn\'t be loaded');
this.zenodoSearchUtils.status = this.errorCodes.DONE;
}
);
})
);
this.fullscreen.title = "Search and Add Zenodo Communities"; this.fullscreen.title = "Search and Add Zenodo Communities";
this.fullscreen.okButtonText = "Done"; this.fullscreen.okButtonText = "Done";
this.fullscreen.okButton = true; this.fullscreen.okButton = true;
@ -132,26 +116,6 @@ export class ZenodoCommunitiesComponent implements OnInit, OnDestroy {
}); });
} }
public toggleAction() {
if (!Session.isLoggedIn()) {
this._router.navigate(['/user-info'], {
queryParams: {'errorCode': LoginErrorCodes.NOT_VALID, 'redirectUrl': this._router.url}
});
} else {
HelperFunctions.scroll();
this.toggle = !this.toggle;
if (this.toggle) {
this.fullscreen.open();
this.pageTitle = 'Manage zenodo communities';
} else {
this.manage.filterPreviewCommunities(this.manage.filterForm.value);
this.updateCommunityProjectsOnToggle = false;
this.pageTitle = 'Search zenodo communities';
}
}
}
getZenodoCommunityById(zenodoid, openaireId) { getZenodoCommunityById(zenodoid, openaireId) {
this.subscriptions.push(this._zenodoCommunitieService.getZenodoCommunityById(this.properties, this.subscriptions.push(this._zenodoCommunitieService.getZenodoCommunityById(this.properties,
this.properties.zenodoCommunities + zenodoid, openaireId).subscribe( this.properties.zenodoCommunities + zenodoid, openaireId).subscribe(
@ -178,4 +142,22 @@ export class ZenodoCommunitiesComponent implements OnInit, OnDestroy {
} }
)); ));
} }
public openAddZenodoCommunites() {
this.fullscreen.title = "Search and Add Zenodo Communities";
this.fullscreen.okButtonText = "Done";
this.fullscreen.back = true;
this.fullscreen.okButton = true;
this.fullscreen.open();
}
public zenodoCommunitiesChanged($event) {
this.selectedCommunities = $event.value;
this.showLoadingInRemove = false;
if (this.fullscreen.isOpen) {
this.manage.filterPreviewCommunities(this.manage.filterForm.value);
}
}
} }

View File

@ -13,19 +13,18 @@ import {ZenodoCommunitiesRoutingModule} from './zenodo-communities-routing.modul
import {CommunityInfoModule} from '../community-info/community-info.module'; import {CommunityInfoModule} from '../community-info/community-info.module';
import {SearchInputModule} from '../../openaireLibrary/sharedComponents/search-input/search-input.module'; import {SearchInputModule} from '../../openaireLibrary/sharedComponents/search-input/search-input.module';
import {IconsModule} from '../../openaireLibrary/utils/icons/icons.module'; import {IconsModule} from '../../openaireLibrary/utils/icons/icons.module';
import {IconsService} from '../../openaireLibrary/utils/icons/icons.service';
import {add, arrow_left, remove_circle_outline} from '../../openaireLibrary/utils/icons/icons';
import {NoLoadPaging} from '../../openaireLibrary/searchPages/searchUtils/no-load-paging.module'; import {NoLoadPaging} from '../../openaireLibrary/searchPages/searchUtils/no-load-paging.module';
import {LoadingModule} from '../../openaireLibrary/utils/loading/loading.module'; import {LoadingModule} from '../../openaireLibrary/utils/loading/loading.module';
import {PreviewZenodoCommunityComponent} from './preview-z-community.component'; import {PreviewZenodoCommunityComponent} from './preview-z-community.component';
import {PageContentModule} from '../../openaireLibrary/dashboard/sharedComponents/page-content/page-content.module'; import {PageContentModule} from '../../openaireLibrary/dashboard/sharedComponents/page-content/page-content.module';
import {FullScreenModalModule} from '../../openaireLibrary/utils/modal/full-screen-modal/full-screen-modal.module'; import {FullScreenModalModule} from '../../openaireLibrary/utils/modal/full-screen-modal/full-screen-modal.module';
import {HTMLToStringPipeModule} from '../../openaireLibrary/utils/pipes/HTMLToStringPipe.module'; import {HTMLToStringPipeModule} from '../../openaireLibrary/utils/pipes/HTMLToStringPipe.module';
import {PagingModule} from "../../openaireLibrary/utils/paging.module";
@NgModule({ @NgModule({
imports: [ imports: [
CommonModule, FormsModule, RouterModule, SearchZenodoCommunitiesServiceModule, ZenodoCommunitiesServiceModule, CommonModule, FormsModule, RouterModule, SearchZenodoCommunitiesServiceModule, ZenodoCommunitiesServiceModule,
AlertModalModule, ZenodoCommunitiesRoutingModule, CommunityInfoModule, PageContentModule, SearchInputModule, IconsModule, NoLoadPaging, LoadingModule, FullScreenModalModule, HTMLToStringPipeModule AlertModalModule, ZenodoCommunitiesRoutingModule, CommunityInfoModule, PageContentModule, SearchInputModule, IconsModule, NoLoadPaging, LoadingModule, FullScreenModalModule, HTMLToStringPipeModule, PagingModule
], ],
declarations: [ declarations: [
ManageZenodoCommunitiesComponent, ZenodoCommunitiesComponent, AddZenodoCommunitiesComponent, PreviewZenodoCommunityComponent ManageZenodoCommunitiesComponent, ZenodoCommunitiesComponent, AddZenodoCommunitiesComponent, PreviewZenodoCommunityComponent
@ -39,7 +38,5 @@ import {HTMLToStringPipeModule} from '../../openaireLibrary/utils/pipes/HTMLToSt
}) })
export class ZenodoCommunitiesModule { export class ZenodoCommunitiesModule {
constructor(private iconsService: IconsService) { constructor() {}
this.iconsService.registerIcons([add, arrow_left, remove_circle_outline ])
}
} }