2020-07-24 09:48:58 +02:00
|
|
|
<app-refresh-table [loading]="dataSource.loading$ | async" [selection]="selection" (refreshed)="refreshPage()"
|
feat(console): user memberships, generic member create dialog, fix user autocomplete emitter (#606)
* load manager mgmtservice, user service
* add org memberships
* membership component, generic member creation
* refactor member create dialog
* project autocomplete context
* create batch managers in user component
* project context wrapper
* emit on user removal, preselect user on init
* membership avatar style, service
* auth user memberships, navigate to target
* cursor fix, avatar gen
* lint
* i18n fix
* remove role translations
* membership detail page, i18n
* fix role label i18n, after view init loader
* remove projectid from grant remove
* fix iam race condition
* refresh table ts, fix no permission project search
* change membership colors
* refresh table everywhere, replace assets, routing
* fix logo header size
* lint, fix project grant removal
* timestmp for p mem, user list, grants, p list (#615)
* npm audit
* update deps, resolve vulnerability
* fix tslint config
* update lock
* load 20 changes at once
* Update console/src/assets/i18n/de.json
Co-authored-by: Florian Forster <florian@caos.ch>
* Update console/src/assets/i18n/de.json
Co-authored-by: Florian Forster <florian@caos.ch>
* Update console/src/assets/i18n/en.json
Co-authored-by: Florian Forster <florian@caos.ch>
* membership i18n
Co-authored-by: Florian Forster <florian@caos.ch>
2020-08-24 08:48:47 +02:00
|
|
|
[dataSize]="dataSource.totalResult" [timestamp]="dataSource?.viewTimestamp">
|
2020-07-24 09:48:58 +02:00
|
|
|
<ng-template appHasRole [appHasRole]="['project.app.write']" actions>
|
2020-05-13 14:41:43 +02:00
|
|
|
<a [disabled]="disabled" class="add-button" [routerLink]="[ '/projects', projectId, 'apps', 'create']"
|
|
|
|
color="primary" mat-raised-button>
|
|
|
|
<mat-icon class="icon">add</mat-icon>{{ 'ACTIONS.NEW' | translate }}
|
|
|
|
</a>
|
|
|
|
</ng-template>
|
|
|
|
|
2020-07-24 09:48:58 +02:00
|
|
|
<div class="table-wrapper">
|
2020-07-30 16:54:15 +02:00
|
|
|
<table [dataSource]="dataSource" mat-table class="table" matSort aria-label="Elements">
|
2020-07-24 09:48:58 +02:00
|
|
|
<ng-container matColumnDef="select">
|
|
|
|
<th class="selection" mat-header-cell *matHeaderCellDef>
|
|
|
|
<mat-checkbox color="primary" (change)="$event ? masterToggle() : null"
|
|
|
|
[checked]="selection.hasValue() && isAllSelected()"
|
|
|
|
[indeterminate]="selection.hasValue() && !isAllSelected()">
|
|
|
|
</mat-checkbox>
|
|
|
|
</th>
|
|
|
|
<td class="selection" mat-cell *matCellDef="let row">
|
|
|
|
<mat-checkbox color="primary" (click)="$event.stopPropagation()"
|
|
|
|
(change)="$event ? selection.toggle(row) : null" [checked]="selection.isSelected(row)">
|
|
|
|
</mat-checkbox>
|
|
|
|
</td>
|
|
|
|
</ng-container>
|
2020-05-13 14:41:43 +02:00
|
|
|
|
2020-07-24 09:48:58 +02:00
|
|
|
<ng-container matColumnDef="name">
|
|
|
|
<th mat-header-cell *matHeaderCellDef> {{ 'PROJECT.ROLE.NAME' | translate }} </th>
|
|
|
|
<td class="pointer" [routerLink]="['/projects', projectId, 'apps', role.id ]" mat-cell
|
|
|
|
*matCellDef="let role">
|
|
|
|
{{role.name}} </td>
|
|
|
|
</ng-container>
|
2020-05-13 14:41:43 +02:00
|
|
|
|
2020-07-24 09:48:58 +02:00
|
|
|
<tr mat-header-row *matHeaderRowDef="displayedColumns"></tr>
|
|
|
|
<tr class="data-row" mat-row *matRowDef="let row; columns: displayedColumns;"></tr>
|
|
|
|
</table>
|
2020-05-13 14:41:43 +02:00
|
|
|
|
2020-07-30 16:54:15 +02:00
|
|
|
<mat-paginator class="paginator" #paginator [length]="dataSource.totalResult" [pageSize]="25"
|
2020-07-24 09:48:58 +02:00
|
|
|
[pageSizeOptions]="[25, 50, 100, 250]">
|
|
|
|
</mat-paginator>
|
|
|
|
</div>
|
|
|
|
</app-refresh-table>
|