109 lines
5.7 KiB
HTML
109 lines
5.7 KiB
HTML
<div page-content (stickyEmitter)="stickyEmitter.emit($event)">
|
|
<div header>
|
|
<ng-content></ng-content>
|
|
</div>
|
|
<div inner>
|
|
<div *ngIf="loadActive || loadPending" class="uk-position-center">
|
|
<loading></loading>
|
|
</div>
|
|
<div class="uk-grid uk-margin-medium-bottom uk-margin-top" uk-grid>
|
|
<div class="uk-flex uk-flex-left@m uk-flex-center uk-width-expand">
|
|
<ul class="uk-subnav uk-subnav-pill">
|
|
<li [class.uk-active]="showCurrent" (click)="showCurrent = true">
|
|
<a class="uk-text-capitalize">{{role}}s</a>
|
|
</li>
|
|
<li [class.uk-active]="!showCurrent" (click)="showCurrent = false">
|
|
<a>Pending {{role}}s</a>
|
|
</li>
|
|
</ul>
|
|
</div>
|
|
<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 *ngIf="showCurrent" [disabled]="loadActive" search-input class="uk-width-expand@l uk-width-1-1"
|
|
[searchControl]="filterForm.get('active')" [expandable]="true" [placeholder]="'Search ' + role + 's'" searchInputClass="outer">
|
|
</div>
|
|
<div *ngIf="!showCurrent" [disabled]="loadPending" search-input class="uk-width-expand@l uk-width-1-1"
|
|
[searchControl]="filterForm.get('pending')" [expandable]="true" [placeholder]="'Search invitations'" searchInputClass="outer">
|
|
</div>
|
|
<div>
|
|
<button *ngIf="exists" class="uk-button uk-button-default uk-flex uk-flex-middle" [attr.uk-tooltip]="inviteDisableMessage"
|
|
[disabled]="loadPending || !!inviteDisableMessage" (click)="openInviteModal()">
|
|
<icon name="person_add" [flex]="true" type="filled"></icon>
|
|
<span class="uk-margin-small-left uk-text-bold uk-text-uppercase">Invite {{role}}</span>
|
|
</button>
|
|
<button *ngIf="!exists && isPortalAdmin" class="uk-button uk-button-default uk-flex uk-flex-middle"
|
|
(click)="openCreateRoleModal()">
|
|
<icon name="person_add" [flex]="true" type="filled"></icon>
|
|
<span class="uk-margin-small-left uk-text-bold uk-text-uppercase">Create Group</span>
|
|
</button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div *ngIf="!loadActive && !loadPending" class="uk-section uk-section-small">
|
|
<div *ngIf="(showCurrent && showActive.length == 0) || (!showCurrent && showPending.length == 0)"
|
|
class="uk-card uk-card-default uk-padding-large uk-text-center uk-margin-bottom uk-text-bold">
|
|
<div *ngIf="showCurrent">No {{role}}s found</div>
|
|
<div *ngIf="!showCurrent">No pending {{role}} invitations found</div>
|
|
</div>
|
|
<div *ngIf="(showCurrent && showActive.length > 0) || (!showCurrent && showPending.length > 0)">
|
|
<no-load-paging *ngIf="showCurrent" [type]="(showActive.length > 1)?(role + 's'):role"
|
|
(pageChange)="updateActivePage($event)"
|
|
[page]="activePage" [pageSize]="pageSize"
|
|
[totalResults]="showActive.length">
|
|
</no-load-paging>
|
|
<no-load-paging *ngIf="!showCurrent" [type]="role + ' ' + (showPending.length > 1?'invitations':'invitation')"
|
|
(pageChange)="updatePendingPage($event)"
|
|
[page]="pendingPage" [pageSize]="pageSize"
|
|
[totalResults]="showPending.length">
|
|
</no-load-paging>
|
|
<div class="uk-grid uk-grid-large uk-child-width-1-1@s uk-child-width-1-2@m uk-margin-top" uk-grid>
|
|
<div *ngFor="let item of (showCurrent)?(currentActivePage):(currentPendingPage)">
|
|
<div class="uk-card uk-card-default">
|
|
<div class="uk-card-body">
|
|
<span class="uk-text-bold uk-text-large">{{(showCurrent) ? item.email : item}}</span>
|
|
</div>
|
|
<div *ngIf="isCurator || !showCurrent" class="uk-card-footer uk-flex uk-flex-right">
|
|
<button (click)="openDeleteModal(item)" class="uk-button uk-button-link uk-flex uk-flex-middle" [disabled]="role === 'member' && item.isManager"
|
|
[attr.uk-tooltip]="(role === 'member' && item.isManager)?'This user is a manager and cannot be removed.':null">
|
|
<icon name="delete" [flex]="true" type="filled"></icon>
|
|
<span class="uk-margin-small-left uk-text-bold uk-text-uppercase">{{showCurrent ? 'Delete' : 'Cancel invitation'}}</span>
|
|
</button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<modal-alert #inviteModal (alertOutput)="invite()" [overflowBody]="false" classTitle="uk-background-primary uk-light"
|
|
[okDisabled]="invited && invited.invalid">
|
|
<div *ngIf="message" class="uk-margin-medium-bottom uk-text-small">
|
|
<div [innerHTML]="message | safeHtml"></div>
|
|
</div>
|
|
<div *ngIf="invited">
|
|
<div input [formInput]="invited"
|
|
placeholder="Email"></div>
|
|
</div>
|
|
</modal-alert>
|
|
<modal-alert #deleteModal [overflowBody]="false" (alertOutput)="deleteActive()" classTitle="uk-background-primary uk-light">
|
|
<div *ngIf="selectedUser">
|
|
Are you sure you want to remove <span class="uk-text-bold">{{selectedUser}}</span> from {{role}}s?
|
|
</div>
|
|
</modal-alert>
|
|
<modal-alert #deletePendingModal [overflowBody]="false" (alertOutput)="deletePending()" classTitle="uk-background-primary uk-light">
|
|
<div *ngIf="selectedUser">
|
|
Are you sure you want to cancel {{role}} invitation of <span class="uk-text-bold">{{selectedUser}}</span>?
|
|
</div>
|
|
</modal-alert>
|
|
<modal-alert #createRoleModal [overflowBody]="false" (alertOutput)="createGroup()" classTitle="uk-background-primary uk-light"
|
|
[okDisabled]="roleFb && roleFb.invalid">
|
|
<div *ngIf="roleFb">
|
|
<div class="uk-grid" uk-grid [formGroup]="roleFb">
|
|
<div input [formInput]="roleFb.get('name')"
|
|
placeholder="Name" class="uk-width-1-1"></div>
|
|
<div input [formInput]="roleFb.get('description')" type="textarea"
|
|
placeholder="Description" class="uk-width-1-1"></div>
|
|
</div>
|
|
</div>
|
|
</modal-alert>
|