You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 

74 lines
2.6 KiB

import { Component, AfterViewInit, ViewChild, ElementRef, Renderer2 } from '@angular/core';
import { FormGroup, Validators, FormBuilder, ValidatorFn, AbstractControl, ValidationErrors } from '@angular/forms';
import { DialogService } from '@app/core/services/dialog.service';
import { HttpService } from '@app/core/services/http.service';
import { I18nService } from '@app/core/services/i18n.service';
import { RouterService } from '@app/core/services/router.service';
@Component({
selector: 'app-initial',
templateUrl: './initial.component.html',
styleUrls: ['./initial.component.scss']
})
export class InitialComponent implements AfterViewInit {
constructor(
private _renderer: Renderer2,
private _formBuilder: FormBuilder,
private _dialogService: DialogService,
private _httpService: HttpService,
private _i18nService: I18nService,
private _routerService: RouterService
) {
this.formGroup = this._formBuilder.group({
replacement: ['', [Validators.required]],
confirm: ['', [Validators.required, this.confirmValidators]]
});
}
ngAfterViewInit(): void {
this._formElement.nativeElement.querySelectorAll('.mat-form-field-outline').forEach((item: any) => {
this._renderer.addClass(item, 'app-background-card');
this._renderer.setStyle(item, 'border-radius', '5px');
});
}
//表单
@ViewChild('form')
private _formElement: ElementRef;
public formGroup: FormGroup;
//密码确认验证
private confirmValidators: ValidatorFn = (control: AbstractControl): ValidationErrors | null => {
if (control.parent) {
return control.value != control.parent.controls['replacement'].value ? {
confirm: true
} : null;
}
};
//提交修改
public loading: boolean;
public async continue() {
this.loading = true;
const result = await this._httpService.post('users/current/password', {
replacement: this.formGroup.controls['replacement'].value
}).catch(error => {
this.loading = false;
switch (error.status) {
case 405:
this._dialogService.alert(this._i18nService.translate('layouts.auth.initial.invalid.operation'));
break;
case 422:
this._dialogService.alert(this._i18nService.translate('layouts.auth.initial.invalid.content'));
break;
}
}) !== undefined;
if (result) {
await this._httpService.delete('sessions', { reason: 'Modify Password' });
this.loading = false;
await this._dialogService.alert(this._i18nService.translate('layouts.auth.initial.success'));
this._routerService.navigate('/auth/login');
}
}
}