2022-08-04 14:29:08 +02:00
|
|
|
<div page-content>
|
2020-11-03 19:25:03 +01:00
|
|
|
<div header>
|
|
|
|
<ng-content></ng-content>
|
|
|
|
</div>
|
2022-07-13 19:25:19 +02:00
|
|
|
<div actions>
|
2023-03-09 15:07:39 +01:00
|
|
|
<div class="uk-section-xsmall uk-margin-top">
|
2022-07-14 10:29:29 +02:00
|
|
|
<div class="uk-grid" 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-right@m uk-flex-center uk-flex-middle" uk-grid>
|
|
|
|
<div *ngIf="showCurrent" [disabled]="loadActive" search-input class="uk-width-expand@l uk-width-1-1"
|
2022-07-13 19:25:19 +02:00
|
|
|
[searchControl]="filterForm.get('active')" [expandable]="true" [placeholder]="'Search ' + role + 's'" searchInputClass="outer">
|
|
|
|
</div>
|
2022-07-14 10:29:29 +02:00
|
|
|
<div *ngIf="!showCurrent" [disabled]="loadPending" search-input class="uk-width-expand@l uk-width-1-1"
|
2022-07-13 19:25:19 +02:00
|
|
|
[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" [class.uk-disabled]="loadPending || loadPending"
|
|
|
|
[disabled]="loadActive || 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>
|
2022-07-26 13:32:52 +02:00
|
|
|
<button *ngIf="!exists && isCurator" class="uk-button uk-button-default uk-flex uk-flex-middle"
|
2022-07-13 19:25:19 +02:00
|
|
|
(click)="openCreateRoleModal()">
|
2022-07-26 13:32:52 +02:00
|
|
|
<icon name="group" [flex]="true" type="filled"></icon>
|
2022-07-13 19:25:19 +02:00
|
|
|
<span class="uk-margin-small-left uk-text-bold uk-text-uppercase">Create Group</span>
|
|
|
|
</button>
|
|
|
|
</div>
|
2022-03-24 13:56:55 +01:00
|
|
|
</div>
|
2022-07-14 10:29:29 +02:00
|
|
|
</div>
|
2022-03-22 16:47:38 +01:00
|
|
|
</div>
|
2022-07-13 19:25:19 +02:00
|
|
|
</div>
|
|
|
|
<div inner>
|
2022-06-30 17:22:35 +02:00
|
|
|
<div class="uk-section uk-section-small uk-position-relative" style="min-height: 60vh">
|
2022-06-28 20:13:40 +02:00
|
|
|
<div *ngIf="loadActive || loadPending" class="uk-position-center">
|
|
|
|
<loading></loading>
|
|
|
|
</div>
|
|
|
|
<div *ngIf="!loadActive && !loadPending">
|
|
|
|
<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>
|
2023-02-09 15:30:24 +01:00
|
|
|
<div *ngIf="!showCurrent || role === 'member' || canDelete" 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) || isMe(item.id)"
|
|
|
|
[attr.uk-tooltip]="(role === 'member' && item.isManager)?'This user is a manager and cannot be removed.':
|
|
|
|
(isMe(item.id)?'You cannot remove yourself':null)">
|
2022-06-28 20:13:40 +02:00
|
|
|
<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>
|
2022-03-22 16:47:38 +01:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
2022-06-30 17:22:35 +02:00
|
|
|
<div class="uk-margin-small-top">
|
|
|
|
<paging-no-load *ngIf="showCurrent" [currentPage]="activePage"
|
|
|
|
[totalResults]="showActive.length" [size]="pageSize"
|
|
|
|
(pageChange)="updateActivePage($event)" customClasses="uk-flex-right@m uk-flex-center">
|
|
|
|
</paging-no-load>
|
|
|
|
<paging-no-load *ngIf="!showCurrent" [currentPage]="pendingPage"
|
|
|
|
[totalResults]="showPending.length" [size]="pageSize"
|
|
|
|
(pageChange)="updatePendingPage($event)" customClasses="uk-flex-right@m uk-flex-center">
|
|
|
|
</paging-no-load>
|
|
|
|
</div>
|
2022-03-22 16:47:38 +01:00
|
|
|
</div>
|
2022-06-28 20:13:40 +02:00
|
|
|
</div>
|
2020-11-03 19:25:03 +01:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
2022-06-21 12:41:44 +02:00
|
|
|
<modal-alert #inviteModal (alertOutput)="invite()" [overflowBody]="false" classTitle="uk-background-primary uk-light"
|
2023-06-26 14:09:37 +02:00
|
|
|
[okDisabled]="!valid">
|
2022-06-20 15:17:26 +02:00
|
|
|
<div *ngIf="message" class="uk-margin-medium-bottom uk-text-small">
|
|
|
|
<div [innerHTML]="message | safeHtml"></div>
|
|
|
|
</div>
|
2023-06-26 14:09:37 +02:00
|
|
|
<div *ngIf="emailsForm">
|
|
|
|
<div #emailInput input [formInput]="emailsForm" type="chips"
|
|
|
|
placeholder="Recipients" hint="Add a recipient" [visibleChips]="3"
|
|
|
|
[addExtraChips]="true" [validators]="validators" [separators]="[',']">
|
|
|
|
<div note>Separate emails with commas</div>
|
|
|
|
</div>
|
2022-06-20 15:17:26 +02:00
|
|
|
</div>
|
2020-11-03 19:25:03 +01:00
|
|
|
</modal-alert>
|
2022-06-21 12:41:44 +02:00
|
|
|
<modal-alert #deleteModal [overflowBody]="false" (alertOutput)="deleteActive()" classTitle="uk-background-primary uk-light">
|
2022-06-20 15:17:26 +02:00
|
|
|
<div *ngIf="selectedUser">
|
2020-11-03 19:25:03 +01:00
|
|
|
Are you sure you want to remove <span class="uk-text-bold">{{selectedUser}}</span> from {{role}}s?
|
|
|
|
</div>
|
|
|
|
</modal-alert>
|
2022-06-21 12:41:44 +02:00
|
|
|
<modal-alert #deletePendingModal [overflowBody]="false" (alertOutput)="deletePending()" classTitle="uk-background-primary uk-light">
|
2022-06-20 15:17:26 +02:00
|
|
|
<div *ngIf="selectedUser">
|
2020-11-03 19:25:03 +01:00
|
|
|
Are you sure you want to cancel {{role}} invitation of <span class="uk-text-bold">{{selectedUser}}</span>?
|
|
|
|
</div>
|
|
|
|
</modal-alert>
|
2022-06-21 12:41:44 +02:00
|
|
|
<modal-alert #createRoleModal [overflowBody]="false" (alertOutput)="createGroup()" classTitle="uk-background-primary uk-light"
|
|
|
|
[okDisabled]="roleFb && roleFb.invalid">
|
2022-06-20 15:17:26 +02:00
|
|
|
<div *ngIf="roleFb">
|
2020-11-03 19:25:03 +01:00
|
|
|
<div class="uk-grid" uk-grid [formGroup]="roleFb">
|
2022-04-05 14:26:26 +02:00
|
|
|
<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>
|
2020-11-03 19:25:03 +01:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</modal-alert>
|