mirror of
https://github.com/zitadel/zitadel.git
synced 2025-12-04 02:12:28 +00:00
121 lines
5.0 KiB
HTML
121 lines
5.0 KiB
HTML
<cnsl-create-layout
|
|
title="{{ id ? ('IDP.DETAIL.TITLE' | translate) : ('IDP.CREATE.TITLE' | translate) }}"
|
|
(closed)="close()"
|
|
>
|
|
<div class="identity-provider-create-content">
|
|
<div class="title-row">
|
|
<img class="idp-logo dark" src="./assets/images/idp/github-dark.svg" alt="github" />
|
|
<img class="idp-logo light" src="./assets/images/idp/github.svg" alt="github" />
|
|
<h1>{{ 'IDP.CREATE.GITHUB.TITLE' | translate }}</h1>
|
|
<ng-container *ngIf="exists$ | async">
|
|
<div
|
|
*ngIf="{ isNotActive: (activateLink$ | async) } as idp"
|
|
class="cnsl-state-dot"
|
|
[matTooltip]="(idp.isNotActive ? 'IDP.STATES.2' : 'IDP.STATES.1') | translate"
|
|
[ngClass]="{ active: !idp.isNotActive, inactive: !!idp.isNotActive }"
|
|
></div>
|
|
</ng-container>
|
|
<mat-spinner diameter="25" *ngIf="loading" color="primary"></mat-spinner>
|
|
</div>
|
|
|
|
<cnsl-provider-next
|
|
[configureProvider]="(justCreated$ | async) === ''"
|
|
[configureTitle]="'DESCRIPTIONS.SETTINGS.IDPS.CALLBACK.TITLE' | translate: { provider: 'GitHub' }"
|
|
[configureDescription]="'DESCRIPTIONS.SETTINGS.IDPS.CALLBACK.DESCRIPTION' | translate: { provider: 'GitHub' }"
|
|
configureLink="https://zitadel.com/docs/guides/integrate/identity-providers/github#github-configuration"
|
|
[autofillLink]="autofillLink$ | async"
|
|
[activateLink]="activateLink$ | async"
|
|
[copyUrls]="copyUrls$ | async"
|
|
[expanded]="!!(expandWhatNow$ | async)"
|
|
(activate)="activate()"
|
|
></cnsl-provider-next>
|
|
|
|
<p class="identity-provider-desc cnsl-secondary-text">
|
|
{{ !provider ? ('IDP.CREATE.GITHUB.DESCRIPTION' | translate) : ('IDP.DETAIL.DESCRIPTION' | translate) }}
|
|
</p>
|
|
|
|
<form [formGroup]="form" (ngSubmit)="submitForm()">
|
|
<div class="identity-provider-content">
|
|
<cnsl-form-field class="formfield">
|
|
<cnsl-label>{{ 'IDP.CLIENTID' | translate }}</cnsl-label>
|
|
<input cnslInput formControlName="clientId" />
|
|
</cnsl-form-field>
|
|
|
|
<mat-checkbox
|
|
class="update-secret-checkbox"
|
|
*ngIf="provider"
|
|
[(ngModel)]="updateClientSecret"
|
|
[ngModelOptions]="{ standalone: true }"
|
|
>{{ 'IDP.UPDATECLIENTSECRET' | translate }}</mat-checkbox
|
|
>
|
|
|
|
<cnsl-form-field *ngIf="!provider || (provider && updateClientSecret)" class="formfield">
|
|
<cnsl-label>{{ 'IDP.CLIENTSECRET' | translate }}</cnsl-label>
|
|
<input cnslInput formControlName="clientSecret" />
|
|
</cnsl-form-field>
|
|
|
|
<div class="identity-provider-optional-h-wrapper">
|
|
<h2>{{ 'IDP.OPTIONAL' | translate }}</h2>
|
|
<button (click)="showOptional = !showOptional" type="button" mat-icon-button>
|
|
<mat-icon *ngIf="showOptional">keyboard_arrow_up</mat-icon
|
|
><mat-icon *ngIf="!showOptional">keyboard_arrow_down</mat-icon>
|
|
</button>
|
|
</div>
|
|
<div *ngIf="showOptional">
|
|
<div class="idp-scopes">
|
|
<div class="flex-line">
|
|
<cnsl-form-field class="formfield">
|
|
<cnsl-label>{{ 'IDP.SCOPESLIST' | translate }}</cnsl-label>
|
|
|
|
<input
|
|
cnslInput
|
|
[matChipInputFor]="chipScopesList"
|
|
[matChipInputSeparatorKeyCodes]="separatorKeysCodes"
|
|
[matChipInputAddOnBlur]="true"
|
|
(matChipInputTokenEnd)="addScope($event)"
|
|
/>
|
|
</cnsl-form-field>
|
|
<button class="scope-add-button" (click)="addScope($any($event))" mat-icon-button>
|
|
<mat-icon>add</mat-icon>
|
|
</button>
|
|
</div>
|
|
|
|
<cnsl-form-field class="formfield">
|
|
<mat-chip-grid #chipScopesList aria-label="scope selection">
|
|
<mat-chip-row class="chip" *ngFor="let scope of scopesList?.value" removable (removed)="removeScope(scope)">
|
|
{{ scope }} <mat-icon matChipRemove>cancel</mat-icon>
|
|
</mat-chip-row>
|
|
</mat-chip-grid>
|
|
</cnsl-form-field>
|
|
</div>
|
|
|
|
<cnsl-form-field class="formfield">
|
|
<cnsl-label>{{ 'IDP.NAME' | translate }}</cnsl-label>
|
|
<input cnslInput formControlName="name" />
|
|
<span class="name-hint cnsl-secondary-text" cnslHint>{{ 'IDP.NAMEHINT' | translate }}</span>
|
|
</cnsl-form-field>
|
|
|
|
<cnsl-provider-options
|
|
[initialOptions]="provider?.config?.options"
|
|
(optionsChanged)="options = $event"
|
|
></cnsl-provider-options>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="identity-provider-create-actions">
|
|
<button
|
|
color="primary"
|
|
mat-raised-button
|
|
class="continue-button"
|
|
[disabled]="form.invalid || form.disabled"
|
|
type="submit"
|
|
>
|
|
<span *ngIf="{ exists: (exists$ | async) } as idp">{{
|
|
(!!idp.exists ? 'ACTIONS.SAVE' : 'ACTIONS.CREATE') | translate
|
|
}}</span>
|
|
</button>
|
|
</div>
|
|
</form>
|
|
</div>
|
|
</cnsl-create-layout>
|