<ion-header> <ion-navbar> <ion-title>{{ 'core.login.reconnect' | translate }}</ion-title> </ion-navbar> </ion-header> <ion-content padding class="core-center-view"> <div class="box"> <div *ngIf="site" text-wrap text-center [ngClass]="{'item-avatar-center': site.avatar}"> <ion-avatar *ngIf="site.avatar"> <!-- Show user avatar. --> <img [src]="site.avatar" class="avatar" core-external-content [siteId]="site.id" alt="{{ 'core.pictureof' | translate:{$a: site.fullname} }}" role="presentation" onError="this.src='assets/img/user-avatar.png'"> </ion-avatar> <!-- Show site logo or a default image. --> <img *ngIf="!site.avatar && logoUrl" [src]="logoUrl" core-external-content [siteId]="site.id" role="presentation"> <img *ngIf="!site.avatar && !logoUrl" src="assets/img/login_logo.png" class="login-logo" role="presentation"> <!-- If no sitename show big siteurl. --> <p *ngIf="!siteName" class="item-heading core-siteurl">{{siteUrl}}</p> <!-- If sitename, show big sitename and small siteurl. --> <p *ngIf="siteName" class="item-heading core-sitename"><core-format-text [text]="siteName"></core-format-text></p> <p *ngIf="siteName" class="core-siteurl">{{siteUrl}}</p> <p *ngIf="!isLoggedOut"> <ion-icon padding name="alert"></ion-icon> {{ 'core.login.reconnectdescription' | translate }} </p> </div> <ion-list> <ion-item padding text-wrap class="core-username"> <p class="item-heading">{{ 'core.login.username' | translate }}</p> <p>{{username}}</p> </ion-item> <form [formGroup]="credForm" (ngSubmit)="login()"> <ion-item> <core-show-password item-content [name]="'password'"> <ion-input class="core-ioninput-password" name="password" type="password" placeholder="{{ 'core.login.password' | translate }}" formControlName="password" core-show-password core-auto-focus></ion-input> </core-show-password> </ion-item> <ion-grid> <ion-row> <ion-col> <a ion-button block color="light" (click)="cancel()">{{ 'core.login.cancel' | translate }}</a> </ion-col> <ion-col> <button ion-button block [disabled]="!credForm.valid">{{ 'core.login.loginbutton' | translate }}</button> </ion-col> </ion-row> </ion-grid> </form> </ion-list> <!-- Identity providers. --> <ion-list *ngIf="identityProviders && identityProviders.length" padding-top> <ion-list-header text-wrap>{{ 'core.login.potentialidps' | translate }}</ion-list-header> <button ion-item *ngFor="let provider of identityProviders" text-wrap class="core-oauth-icon" (click)="oauthClicked(provider)" title="{{provider.name}}"> <img [src]="provider.iconurl" alt="{{provider.name}}" item-start> {{provider.name}} </button> </ion-list> </div> </ion-content>