mirror of
https://github.com/zitadel/zitadel.git
synced 2025-04-16 03:51:34 +00:00

* 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>
50 lines
1.6 KiB
TypeScript
50 lines
1.6 KiB
TypeScript
import { animate, animation, keyframes, style, transition, trigger, useAnimation } from '@angular/animations';
|
|
import { SelectionModel } from '@angular/cdk/collections';
|
|
import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';
|
|
import { Timestamp } from 'google-protobuf/google/protobuf/timestamp_pb';
|
|
|
|
const rotate = animation([
|
|
animate(
|
|
'{{time}} cubic-bezier(0.785, 0.135, 0.15, 0.86)',
|
|
keyframes([
|
|
style({
|
|
transform: 'rotate(0deg)',
|
|
}),
|
|
style({
|
|
transform: 'rotate(360deg)',
|
|
}),
|
|
]),
|
|
),
|
|
]);
|
|
@Component({
|
|
selector: 'app-refresh-table',
|
|
templateUrl: './refresh-table.component.html',
|
|
styleUrls: ['./refresh-table.component.scss'],
|
|
animations: [
|
|
trigger('rotate', [
|
|
transition('* => *', [useAnimation(rotate, { params: { time: '1s' } })]),
|
|
]),
|
|
],
|
|
})
|
|
export class RefreshTableComponent implements OnInit {
|
|
@Input() public selection: SelectionModel<any> = new SelectionModel<any>(true, []);
|
|
@Input() public timestamp!: Timestamp.AsObject;
|
|
@Input() public dataSize: number = 0;
|
|
@Input() public emitRefreshAfterTimeoutInMs: number = 0;
|
|
@Input() public loading: boolean = false;
|
|
@Output() public refreshed: EventEmitter<void> = new EventEmitter();
|
|
|
|
ngOnInit(): void {
|
|
if (this.emitRefreshAfterTimeoutInMs) {
|
|
setTimeout(() => {
|
|
this.emitRefresh();
|
|
}, this.emitRefreshAfterTimeoutInMs);
|
|
}
|
|
}
|
|
|
|
emitRefresh(): void {
|
|
this.selection.clear();
|
|
return this.refreshed.emit();
|
|
}
|
|
}
|