179 lines
5.3 KiB
TypeScript
179 lines
5.3 KiB
TypeScript
import { Component, OnInit, ViewChild } from '@angular/core';
|
|
import { Validators, FormBuilder, FormGroup } from '@angular/forms';
|
|
import { ApiService } from '../providers/api-service';
|
|
|
|
|
|
@Component({
|
|
templateUrl: 'account-edit.component.html',
|
|
})
|
|
export class AccountEditComponent implements OnInit {
|
|
settingForm: FormGroup;
|
|
settingOrganisationForm: FormGroup;
|
|
settingCustomerForm: FormGroup;
|
|
accountType: any;
|
|
// @ViewChild('fileInput') fileInput;
|
|
submitStatus: any;
|
|
submitStatusError = 'Error received, please try again.';
|
|
|
|
constructor(
|
|
private formBuilder: FormBuilder,
|
|
private api: ApiService,
|
|
) {
|
|
this.settingForm = this.formBuilder.group({
|
|
email : ['', [Validators.required]],
|
|
postcode : ['', [Validators.required]],
|
|
password : ['', [Validators.required]],
|
|
new_password : [''],
|
|
});
|
|
this.settingOrganisationForm = this.formBuilder.group({
|
|
name : ['', [Validators.required]],
|
|
street_name : ['', [Validators.required]],
|
|
town : ['', [Validators.required]],
|
|
sector : ['', [Validators.required]],
|
|
});
|
|
this.settingCustomerForm = this.formBuilder.group({
|
|
full_name : ['', [Validators.required]],
|
|
display_name : ['', [Validators.required]],
|
|
});
|
|
this.accountType = localStorage.getItem('usertype');
|
|
}
|
|
|
|
ngOnInit(): void {
|
|
this.api.accountFullLoad().subscribe(
|
|
result => {
|
|
console.log(result);
|
|
this.settingForm.patchValue({
|
|
email: result.email,
|
|
postcode: result.postcode,
|
|
password: '',
|
|
new_password: '',
|
|
});
|
|
this.settingOrganisationForm.patchValue({
|
|
name: result.name,
|
|
street_name: result.street_name,
|
|
town: result.town,
|
|
sector: result.sector,
|
|
});
|
|
this.settingCustomerForm.patchValue({
|
|
full_name: result.full_name,
|
|
display_name: result.display_name,
|
|
});
|
|
this.api.setUserInfo( result.email, result.display_name || result.name );
|
|
},
|
|
error => {
|
|
console.log( error._body );
|
|
}
|
|
);
|
|
}
|
|
|
|
onSubmitOrganisation() {
|
|
console.log(this.settingForm.valid);
|
|
if (!this.settingForm.valid && !this.settingOrganisationForm.valid) {
|
|
console.log('Not Valid!');
|
|
this.submitStatus = 'validation_failed';
|
|
console.log(this.submitStatus);
|
|
return;
|
|
}
|
|
|
|
const settingForm = this.settingForm.value;
|
|
const settingOrganisationForm = this.settingOrganisationForm.value;
|
|
|
|
// image upload code
|
|
// const fi = this.fileInput.nativeElement;
|
|
// const data = new FormData();
|
|
|
|
// if (fi.files && fi.files[0]) {
|
|
// const fileToUpload = fi.files[0];
|
|
// data.append('file', fileToUpload);
|
|
// }
|
|
|
|
const submitData = {
|
|
email: settingForm.email,
|
|
postcode: settingForm.postcode,
|
|
password: settingForm.password,
|
|
new_password: settingForm.new_password,
|
|
name: settingOrganisationForm.name,
|
|
street_name: settingOrganisationForm.street_name,
|
|
town: settingOrganisationForm.town,
|
|
sector: settingOrganisationForm.sector,
|
|
};
|
|
|
|
// data.append('form', JSON.stringify(submitData));
|
|
|
|
console.log(submitData);
|
|
this.api
|
|
.accountEditUpdate(submitData)
|
|
.subscribe(
|
|
result => {
|
|
this.submitStatus = 'success';
|
|
},
|
|
error => {
|
|
console.log('Edit Error');
|
|
console.log(error);
|
|
try {
|
|
this.submitStatusError = '"' + error.error.error + '" Error, ' + error.error.message;
|
|
} catch (e) {
|
|
this.submitStatusError = 'There was a server error, please try again later.';
|
|
}
|
|
this.submitStatus = 'send_failed';
|
|
}
|
|
);
|
|
}
|
|
|
|
onSubmitCustomer() {
|
|
console.log(this.settingForm.valid);
|
|
if (!this.settingForm.valid && !this.settingCustomerForm.valid) {
|
|
console.log('Not Valid!');
|
|
this.submitStatus = 'validation_failed';
|
|
return;
|
|
}
|
|
|
|
const settingForm = this.settingForm.value;
|
|
const settingCustomerForm = this.settingCustomerForm.value;
|
|
|
|
// image upload code
|
|
// const fi = this.fileInput.nativeElement;
|
|
const data = new FormData();
|
|
|
|
// if (fi.files && fi.files[0]) {
|
|
// const fileToUpload = fi.files[0];
|
|
// data.append('file', fileToUpload);
|
|
// }
|
|
|
|
const submitData = {
|
|
email: settingForm.email,
|
|
postcode: settingForm.postcode,
|
|
password: settingForm.password,
|
|
new_password: settingForm.new_password,
|
|
full_name: settingCustomerForm.full_name,
|
|
display_name: settingCustomerForm.display_name,
|
|
};
|
|
|
|
// data.append('form', JSON.stringify(submitData));
|
|
|
|
this.api
|
|
.accountEditUpdate(submitData)
|
|
.subscribe(
|
|
result => {
|
|
console.log('data submitted!');
|
|
this.submitStatus = 'success';
|
|
console.log(this.submitStatus);
|
|
},
|
|
error => {
|
|
console.log('Edit Error');
|
|
console.log(error);
|
|
try {
|
|
console.log(error.error);
|
|
const jsonError = error.json();
|
|
console.log('boop');
|
|
this.submitStatusError = '"' + jsonError.error + '" Error, ' + jsonError.message;
|
|
} catch (e) {
|
|
this.submitStatusError = 'There was a server error, please try again later.';
|
|
}
|
|
this.submitStatus = 'send_failed';
|
|
console.log(this.submitStatus);
|
|
}
|
|
);
|
|
}
|
|
|
|
}
|