mirror of
https://github.com/zitadel/zitadel.git
synced 2025-01-08 18:37:39 +00:00
fix(console): org create missing module, layout (#2870)
* fix: org create module * rm comment
This commit is contained in:
parent
278a278a5b
commit
db355facee
@ -63,6 +63,15 @@ const routes: Routes = [
|
|||||||
roles: ['iam.read', 'iam.write'],
|
roles: ['iam.read', 'iam.write'],
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
path: 'org/create',
|
||||||
|
component: OrgCreateComponent,
|
||||||
|
canActivate: [AuthGuard, RoleGuard],
|
||||||
|
data: {
|
||||||
|
roles: ['(org.create)?(iam.write)?'],
|
||||||
|
},
|
||||||
|
loadChildren: () => import('./pages/org-create/org-create.module').then((m) => m.OrgCreateModule),
|
||||||
|
},
|
||||||
{
|
{
|
||||||
path: 'org',
|
path: 'org',
|
||||||
loadChildren: () => import('./pages/orgs/orgs.module').then((m) => m.OrgsModule),
|
loadChildren: () => import('./pages/orgs/orgs.module').then((m) => m.OrgsModule),
|
||||||
@ -71,15 +80,6 @@ const routes: Routes = [
|
|||||||
roles: ['org.read'],
|
roles: ['org.read'],
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
{
|
|
||||||
path: 'org/create',
|
|
||||||
component: OrgCreateComponent,
|
|
||||||
canActivate: [RoleGuard],
|
|
||||||
data: {
|
|
||||||
roles: ['(org.create)?(iam.write)?'],
|
|
||||||
},
|
|
||||||
loadChildren: () => import('./pages/org-create/org-create.module').then((m) => m.OrgCreateModule),
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
path: 'actions',
|
path: 'actions',
|
||||||
loadChildren: () => import('./pages/actions/actions.module').then((m) => m.ActionsModule),
|
loadChildren: () => import('./pages/actions/actions.module').then((m) => m.ActionsModule),
|
||||||
|
@ -11,6 +11,7 @@ import { MatDialogModule } from '@angular/material/dialog';
|
|||||||
import { MatIconModule } from '@angular/material/icon';
|
import { MatIconModule } from '@angular/material/icon';
|
||||||
import { MatProgressBarModule } from '@angular/material/progress-bar';
|
import { MatProgressBarModule } from '@angular/material/progress-bar';
|
||||||
import { MatProgressSpinnerModule } from '@angular/material/progress-spinner';
|
import { MatProgressSpinnerModule } from '@angular/material/progress-spinner';
|
||||||
|
import { MatSelectModule } from '@angular/material/select';
|
||||||
import { MatSidenavModule } from '@angular/material/sidenav';
|
import { MatSidenavModule } from '@angular/material/sidenav';
|
||||||
import { MatSnackBarModule } from '@angular/material/snack-bar';
|
import { MatSnackBarModule } from '@angular/material/snack-bar';
|
||||||
import { MatToolbarModule } from '@angular/material/toolbar';
|
import { MatToolbarModule } from '@angular/material/toolbar';
|
||||||
@ -130,6 +131,7 @@ const authConfig: AuthConfig = {
|
|||||||
MatSnackBarModule,
|
MatSnackBarModule,
|
||||||
AvatarModule,
|
AvatarModule,
|
||||||
WarnDialogModule,
|
WarnDialogModule,
|
||||||
|
MatSelectModule,
|
||||||
MatDialogModule,
|
MatDialogModule,
|
||||||
RegExpPipeModule,
|
RegExpPipeModule,
|
||||||
OnboardingModule,
|
OnboardingModule,
|
||||||
|
@ -3,12 +3,14 @@
|
|||||||
<button (click)="close()" mat-icon-button>
|
<button (click)="close()" mat-icon-button>
|
||||||
<mat-icon>close</mat-icon>
|
<mat-icon>close</mat-icon>
|
||||||
</button>
|
</button>
|
||||||
|
<span class="abort">{{ 'ORG.PAGES.CREATE' | translate }}</span>
|
||||||
|
<span class="abort-2">Step {{ currentCreateStep }} of {{ createSteps }}</span>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<ng-template cnslHasRole [hasRole]="['iam.write']">
|
<ng-template cnslHasRole [hasRole]="['iam.write']">
|
||||||
<mat-slide-toggle [disabled]="currentCreateStep !== 1" class="example-margin" color="primary"
|
<mat-slide-toggle [disabled]="currentCreateStep !== 1" class="example-margin" color="primary"
|
||||||
(change)="changeSelf($event)" [(ngModel)]="forSelf">
|
(change)="changeSelf($event)" [(ngModel)]="forSelf">
|
||||||
Use your personal account as organisation owner
|
{{'ORG.PAGES.USERSELFACCOUNT' | translate}}
|
||||||
</mat-slide-toggle>
|
</mat-slide-toggle>
|
||||||
|
|
||||||
<ng-container *ngIf="!forSelf">
|
<ng-container *ngIf="!forSelf">
|
||||||
@ -29,9 +31,9 @@
|
|||||||
|
|
||||||
<div class="btn-container">
|
<div class="btn-container">
|
||||||
<span class="fill-space"></span>
|
<span class="fill-space"></span>
|
||||||
<button [disabled]="orgForm.invalid" color="primary" mat-raised-button class="big-button"
|
<button [disabled]="orgForm.invalid" color="primary" mat-raised-button class="big-button" cdkFocusInitial
|
||||||
cdkFocusInitial type="submit">
|
type="submit">
|
||||||
{{'CONTINUE' | translate}}
|
{{'ACTIONS.CONTINUE' | translate}}
|
||||||
</button>
|
</button>
|
||||||
</div>
|
</div>
|
||||||
</form>
|
</form>
|
||||||
@ -99,29 +101,27 @@
|
|||||||
<mat-option *ngFor="let language of languages" [value]="language">
|
<mat-option *ngFor="let language of languages" [value]="language">
|
||||||
{{ 'LANGUAGES.'+language | translate }}
|
{{ 'LANGUAGES.'+language | translate }}
|
||||||
</mat-option>
|
</mat-option>
|
||||||
<span cnslError
|
<span cnslError *ngIf="preferredLanguage?.invalid && preferredLanguage?.errors?.required">
|
||||||
*ngIf="preferredLanguage?.invalid && preferredLanguage?.errors?.required">
|
|
||||||
{{ 'USER.VALIDATION.REQUIRED' | translate }}
|
{{ 'USER.VALIDATION.REQUIRED' | translate }}
|
||||||
</span>
|
</span>
|
||||||
</mat-select>
|
</mat-select>
|
||||||
</cnsl-form-field>
|
</cnsl-form-field>
|
||||||
|
|
||||||
<mat-checkbox class="checkbox" [(ngModel)]="usePassword"
|
<mat-checkbox class="checkbox" [(ngModel)]="usePassword" [ngModelOptions]="{standalone: true}"
|
||||||
[ngModelOptions]="{standalone: true}" (change)="initPwdValidators()">
|
(change)="initPwdValidators()">
|
||||||
{{'ORG.PAGES.USEPASSWORD' | translate}}</mat-checkbox>
|
{{'ORG.PAGES.USEPASSWORD' | translate}}</mat-checkbox>
|
||||||
|
|
||||||
<ng-container *ngIf="usePassword && pwdForm">
|
<ng-container *ngIf="usePassword && pwdForm">
|
||||||
<p class="section">{{ 'USER.CREATE.PASSWORDSECTION' | translate }}</p>
|
<p class="section">{{ 'USER.CREATE.PASSWORDSECTION' | translate }}</p>
|
||||||
|
|
||||||
<cnsl-password-complexity-view class="complexity-view" [policy]="this.policy"
|
<cnsl-password-complexity-view class="complexity-view" [policy]="this.policy" [password]="password">
|
||||||
[password]="password">
|
|
||||||
</cnsl-password-complexity-view>
|
</cnsl-password-complexity-view>
|
||||||
|
|
||||||
<form [formGroup]="pwdForm" class="pwd-form">
|
<form [formGroup]="pwdForm" class="pwd-form">
|
||||||
<cnsl-form-field class="pwd" *ngIf="password" appearance="outline">
|
<cnsl-form-field class="pwd" *ngIf="password" appearance="outline">
|
||||||
<cnsl-label>{{ 'USER.PASSWORD.NEW' | translate }}</cnsl-label>
|
<cnsl-label>{{ 'USER.PASSWORD.NEW' | translate }}</cnsl-label>
|
||||||
<input cnslInput autocomplete="off" name="firstpassword"
|
<input cnslInput autocomplete="off" name="firstpassword" formControlName="password"
|
||||||
formControlName="password" type="password" />
|
type="password" />
|
||||||
|
|
||||||
<span cnslError *ngIf="password?.errors?.required">
|
<span cnslError *ngIf="password?.errors?.required">
|
||||||
{{ 'USER.VALIDATION.REQUIRED' | translate }}
|
{{ 'USER.VALIDATION.REQUIRED' | translate }}
|
||||||
@ -130,8 +130,8 @@
|
|||||||
</cnsl-form-field>
|
</cnsl-form-field>
|
||||||
<cnsl-form-field class="pwd" *ngIf="confirmPassword" appearance="outline">
|
<cnsl-form-field class="pwd" *ngIf="confirmPassword" appearance="outline">
|
||||||
<cnsl-label>{{ 'USER.PASSWORD.CONFIRM' | translate }}</cnsl-label>
|
<cnsl-label>{{ 'USER.PASSWORD.CONFIRM' | translate }}</cnsl-label>
|
||||||
<input cnslInput autocomplete="off" name="confirmPassword"
|
<input cnslInput autocomplete="off" name="confirmPassword" formControlName="confirmPassword"
|
||||||
formControlName="confirmPassword" type="password" />
|
type="password" />
|
||||||
|
|
||||||
<span cnslError *ngIf="confirmPassword?.errors?.required">
|
<span cnslError *ngIf="confirmPassword?.errors?.required">
|
||||||
{{ 'USER.VALIDATION.REQUIRED' | translate }}
|
{{ 'USER.VALIDATION.REQUIRED' | translate }}
|
||||||
@ -144,8 +144,8 @@
|
|||||||
</ng-container>
|
</ng-container>
|
||||||
</div>
|
</div>
|
||||||
<div class="btn-container">
|
<div class="btn-container">
|
||||||
<button color="primary" class="small-button" type="button" (click)="previous()"
|
<button color="primary" class="small-button" type="button" (click)="previous()" mat-stroked-button>{{
|
||||||
mat-stroked-button>{{ 'ACTIONS.BACK' | translate }}</button>
|
'ACTIONS.BACK' | translate }}</button>
|
||||||
<span class="fill-space"></span>
|
<span class="fill-space"></span>
|
||||||
<button color="primary" class="big-button" (click)="finish()"
|
<button color="primary" class="big-button" (click)="finish()"
|
||||||
[disabled]="orgForm.invalid || userForm.invalid || ((usePassword && pwdForm) ? pwdForm?.invalid : false)"
|
[disabled]="orgForm.invalid || userForm.invalid || ((usePassword && pwdForm) ? pwdForm?.invalid : false)"
|
||||||
@ -171,8 +171,8 @@
|
|||||||
|
|
||||||
<div class="btn-container">
|
<div class="btn-container">
|
||||||
<span class="fill-space"></span>
|
<span class="fill-space"></span>
|
||||||
<button [disabled]="orgForm.invalid" color="primary" mat-raised-button class="big-button"
|
<button [disabled]="orgForm.invalid" color="primary" mat-raised-button class="big-button" cdkFocusInitial
|
||||||
cdkFocusInitial type="submit">
|
type="submit">
|
||||||
{{'CREATE' | translate}}
|
{{'CREATE' | translate}}
|
||||||
</button>
|
</button>
|
||||||
</div>
|
</div>
|
||||||
|
@ -44,9 +44,7 @@ function passwordConfirmValidator(c: AbstractControl): any {
|
|||||||
style({ height: '0', opacity: 0 }),
|
style({ height: '0', opacity: 0 }),
|
||||||
animate('150ms ease-in-out', style({ height: '*', opacity: 1 })),
|
animate('150ms ease-in-out', style({ height: '*', opacity: 1 })),
|
||||||
]),
|
]),
|
||||||
transition(':leave', [
|
transition(':leave', [animate('150ms ease-in-out', style({ height: '0', opacity: 0 }))]),
|
||||||
animate('150ms ease-in-out', style({ height: '0', opacity: 0 })),
|
|
||||||
]),
|
|
||||||
]),
|
]),
|
||||||
],
|
],
|
||||||
})
|
})
|
||||||
@ -72,7 +70,10 @@ export class OrgCreateComponent {
|
|||||||
private mgmtService: ManagementService,
|
private mgmtService: ManagementService,
|
||||||
private authService: GrpcAuthService,
|
private authService: GrpcAuthService,
|
||||||
) {
|
) {
|
||||||
this.authService.isAllowed(['iam.write']).pipe(take(1)).subscribe((allowed) => {
|
this.authService
|
||||||
|
.isAllowed(['iam.write'])
|
||||||
|
.pipe(take(1))
|
||||||
|
.subscribe((allowed) => {
|
||||||
if (allowed) {
|
if (allowed) {
|
||||||
this.forSelf = false;
|
this.forSelf = false;
|
||||||
}
|
}
|
||||||
@ -123,7 +124,7 @@ export class OrgCreateComponent {
|
|||||||
// this.router.navigate(['/org', 'overview']);
|
// this.router.navigate(['/org', 'overview']);
|
||||||
// }
|
// }
|
||||||
})
|
})
|
||||||
.catch(error => {
|
.catch((error) => {
|
||||||
this.toast.showError(error);
|
this.toast.showError(error);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@ -152,7 +153,7 @@ export class OrgCreateComponent {
|
|||||||
const validators: Validators[] = [Validators.required];
|
const validators: Validators[] = [Validators.required];
|
||||||
|
|
||||||
if (this.usePassword) {
|
if (this.usePassword) {
|
||||||
this.mgmtService.getDefaultPasswordComplexityPolicy().then(data => {
|
this.mgmtService.getDefaultPasswordComplexityPolicy().then((data) => {
|
||||||
if (data.policy) {
|
if (data.policy) {
|
||||||
this.policy = data.policy;
|
this.policy = data.policy;
|
||||||
|
|
||||||
@ -195,7 +196,6 @@ export class OrgCreateComponent {
|
|||||||
this.orgForm = this.fb.group({
|
this.orgForm = this.fb.group({
|
||||||
name: ['', [Validators.required]],
|
name: ['', [Validators.required]],
|
||||||
});
|
});
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
this.createSteps = 2;
|
this.createSteps = 2;
|
||||||
|
|
||||||
@ -208,14 +208,12 @@ export class OrgCreateComponent {
|
|||||||
|
|
||||||
public createOrgForSelf(): void {
|
public createOrgForSelf(): void {
|
||||||
if (this.name && this.name.value) {
|
if (this.name && this.name.value) {
|
||||||
this.mgmtService.addOrg(this.name.value).then(() => {
|
this.mgmtService
|
||||||
|
.addOrg(this.name.value)
|
||||||
|
.then(() => {
|
||||||
this.router.navigate(['/org/overview']);
|
this.router.navigate(['/org/overview']);
|
||||||
// const newOrg = org.toObject();
|
})
|
||||||
// setTimeout(() => {
|
.catch((error) => {
|
||||||
// this.authService.setActiveOrg(newOrg);
|
|
||||||
// this.router.navigate(['/org']);
|
|
||||||
// }, 1000);
|
|
||||||
}).catch(error => {
|
|
||||||
this.toast.showError(error);
|
this.toast.showError(error);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -641,6 +641,7 @@
|
|||||||
"LISTDESCRIPTION": "Wähle eine Organisation aus.",
|
"LISTDESCRIPTION": "Wähle eine Organisation aus.",
|
||||||
"ACTIVE": "Aktiv",
|
"ACTIVE": "Aktiv",
|
||||||
"CREATE": "Organisation erstellen",
|
"CREATE": "Organisation erstellen",
|
||||||
|
"USERSELFACCOUNT": "Verwenden Sie Ihr persönliches Konto als Organisationsinhaber",
|
||||||
"ORGDETAIL_TITLE": "Gebe den Namen und die Domain für die neue Organisation ein.",
|
"ORGDETAIL_TITLE": "Gebe den Namen und die Domain für die neue Organisation ein.",
|
||||||
"ORGDETAIL_TITLE_WITHOUT_DOMAIN": "Geben Sie den Namen der neuen Organisation ein.",
|
"ORGDETAIL_TITLE_WITHOUT_DOMAIN": "Geben Sie den Namen der neuen Organisation ein.",
|
||||||
"ORGDETAILUSER_TITLE": "Organisationsbesitzer hinzufügen",
|
"ORGDETAILUSER_TITLE": "Organisationsbesitzer hinzufügen",
|
||||||
|
@ -641,6 +641,7 @@
|
|||||||
"LISTDESCRIPTION": "Choose an organisation.",
|
"LISTDESCRIPTION": "Choose an organisation.",
|
||||||
"ACTIVE": "Active",
|
"ACTIVE": "Active",
|
||||||
"CREATE": "Create Organisation",
|
"CREATE": "Create Organisation",
|
||||||
|
"USERSELFACCOUNT": "Use your personal account as organisation owner",
|
||||||
"ORGDETAIL_TITLE": "Enter the name and domain of your new organisation.",
|
"ORGDETAIL_TITLE": "Enter the name and domain of your new organisation.",
|
||||||
"ORGDETAIL_TITLE_WITHOUT_DOMAIN": "Enter the name of your new organisation.",
|
"ORGDETAIL_TITLE_WITHOUT_DOMAIN": "Enter the name of your new organisation.",
|
||||||
"ORGDETAILUSER_TITLE": "Configure Organisation Owner",
|
"ORGDETAILUSER_TITLE": "Configure Organisation Owner",
|
||||||
|
@ -641,6 +641,7 @@
|
|||||||
"LISTDESCRIPTION": "Scegli un'organizzazione.",
|
"LISTDESCRIPTION": "Scegli un'organizzazione.",
|
||||||
"ACTIVE": "Attivo",
|
"ACTIVE": "Attivo",
|
||||||
"CREATE": "Creare un'organizzazione",
|
"CREATE": "Creare un'organizzazione",
|
||||||
|
"USERSELFACCOUNT": "Usa il tuo account personale come proprietario dell'organizzazione",
|
||||||
"ORGDETAIL_TITLE": "Inserisci il nome e il dominio della tua nuova organizzazione.",
|
"ORGDETAIL_TITLE": "Inserisci il nome e il dominio della tua nuova organizzazione.",
|
||||||
"ORGDETAIL_TITLE_WITHOUT_DOMAIN": "Inserisci il nome della tua nuova organizzazione.",
|
"ORGDETAIL_TITLE_WITHOUT_DOMAIN": "Inserisci il nome della tua nuova organizzazione.",
|
||||||
"ORGDETAILUSER_TITLE": "Configurare il proprietario dell'organizzazione",
|
"ORGDETAILUSER_TITLE": "Configurare il proprietario dell'organizzazione",
|
||||||
|
Loading…
x
Reference in New Issue
Block a user