mirror of
https://github.com/DSpace/dspace-angular.git
synced 2025-10-07 01:54:15 +00:00
112 lines
3.4 KiB
TypeScript
112 lines
3.4 KiB
TypeScript
import {
|
|
AsyncPipe,
|
|
NgFor,
|
|
NgIf,
|
|
} from '@angular/common';
|
|
import {
|
|
ChangeDetectionStrategy,
|
|
Component,
|
|
Input,
|
|
OnInit,
|
|
} from '@angular/core';
|
|
import {
|
|
select,
|
|
Store,
|
|
} from '@ngrx/store';
|
|
import { TranslateModule } from '@ngx-translate/core';
|
|
import uniqBy from 'lodash/uniqBy';
|
|
import { Observable } from 'rxjs';
|
|
import { map } from 'rxjs/operators';
|
|
|
|
import { AuthService } from '../../core/auth/auth.service';
|
|
import { AuthMethod } from '../../core/auth/models/auth.method';
|
|
import { AuthMethodType } from '../../core/auth/models/auth.method-type';
|
|
import {
|
|
getAuthenticationError,
|
|
getAuthenticationMethods,
|
|
isAuthenticated,
|
|
isAuthenticationLoading,
|
|
} from '../../core/auth/selectors';
|
|
import { CoreState } from '../../core/core-state.model';
|
|
import { hasValue } from '../empty.util';
|
|
import { ThemedLoadingComponent } from '../loading/themed-loading.component';
|
|
import { LogInContainerComponent } from './container/log-in-container.component';
|
|
import { rendersAuthMethodType } from './methods/log-in.methods-decorator';
|
|
|
|
@Component({
|
|
selector: 'ds-base-log-in',
|
|
templateUrl: './log-in.component.html',
|
|
styleUrls: ['./log-in.component.scss'],
|
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
standalone: true,
|
|
imports: [NgIf, ThemedLoadingComponent, NgFor, LogInContainerComponent, AsyncPipe, TranslateModule],
|
|
})
|
|
export class LogInComponent implements OnInit {
|
|
|
|
/**
|
|
* A boolean representing if LogInComponent is in a standalone page
|
|
* @type {boolean}
|
|
*/
|
|
@Input() isStandalonePage: boolean;
|
|
|
|
/**
|
|
* Method to exclude from the list of authentication methods
|
|
*/
|
|
@Input() excludedAuthMethod: AuthMethodType;
|
|
/**
|
|
* Weather or not to show the register link
|
|
*/
|
|
@Input() showRegisterLink = true;
|
|
|
|
/**
|
|
* The list of authentication methods available
|
|
* @type {AuthMethod[]}
|
|
*/
|
|
public authMethods: Observable<AuthMethod[]>;
|
|
|
|
/**
|
|
* Whether user is authenticated.
|
|
* @type {Observable<string>}
|
|
*/
|
|
public isAuthenticated: Observable<boolean>;
|
|
|
|
/**
|
|
* True if the authentication is loading.
|
|
* @type {boolean}
|
|
*/
|
|
public loading: Observable<boolean>;
|
|
|
|
constructor(private store: Store<CoreState>,
|
|
private authService: AuthService,
|
|
) {
|
|
}
|
|
|
|
ngOnInit(): void {
|
|
this.authMethods = this.store.pipe(
|
|
select(getAuthenticationMethods),
|
|
map((methods: AuthMethod[]) => methods
|
|
// ignore the given auth method if it should be excluded
|
|
.filter((authMethod: AuthMethod) => authMethod.authMethodType !== this.excludedAuthMethod)
|
|
.filter((authMethod: AuthMethod) => rendersAuthMethodType(authMethod.authMethodType) !== undefined)
|
|
.sort((method1: AuthMethod, method2: AuthMethod) => method1.position - method2.position),
|
|
),
|
|
// ignore the ip authentication method when it's returned by the backend
|
|
map((authMethods: AuthMethod[]) => uniqBy(authMethods.filter(a => a.authMethodType !== AuthMethodType.Ip), 'authMethodType')),
|
|
);
|
|
|
|
// set loading
|
|
this.loading = this.store.pipe(select(isAuthenticationLoading));
|
|
|
|
// set isAuthenticated
|
|
this.isAuthenticated = this.store.pipe(select(isAuthenticated));
|
|
|
|
// Clear the redirect URL if an authentication error occurs and this is not a standalone page
|
|
this.store.pipe(select(getAuthenticationError)).subscribe((error) => {
|
|
if (hasValue(error) && !this.isStandalonePage) {
|
|
this.authService.clearRedirectUrl();
|
|
}
|
|
});
|
|
}
|
|
|
|
}
|