Skip to content

Commit

Permalink
ajout des champs supplémentaires issus de la config dans le form user
Browse files Browse the repository at this point in the history
  • Loading branch information
jbrieuclp committed Oct 4, 2023
1 parent 2e6c5e0 commit b0c9403
Show file tree
Hide file tree
Showing 3 changed files with 21 additions and 58 deletions.
2 changes: 1 addition & 1 deletion backend/geonature/core/users/routes.py
Original file line number Diff line number Diff line change
Expand Up @@ -138,7 +138,7 @@ def get_role(id_role):
fields = user_fields.copy()
if g.current_user == user:
fields.add("email")
fields.add('champs_addi')
fields.add("champs_addi")
return user.as_dict(fields=fields)


Expand Down
7 changes: 2 additions & 5 deletions frontend/src/app/userModule/user.component.html
Original file line number Diff line number Diff line change
@@ -1,6 +1,3 @@
{{form.value|json}}
{{form.disabled|json}}
<button type="button" (click)="console()">console</button>
<div class="card card-page center-in-div">
<div class="card-header">
<h3 class="underlined main-color">Mes informations</h3>
Expand Down Expand Up @@ -82,9 +79,9 @@ <h3 class="underlined main-color">Mes informations</h3>
</div>

<pnx-dynamic-form-generator
[autoGenerated]="true"
[myFormGroup]="form.get('champs_addi')"
[formsDefinition]="FORM_CONFIG"
[formsDefinition]="additionalFieldsForm"
[autoGenerated]="true"
>
</pnx-dynamic-form-generator>

Expand Down
70 changes: 18 additions & 52 deletions frontend/src/app/userModule/user.component.ts
Original file line number Diff line number Diff line change
@@ -1,67 +1,48 @@
import { Component, OnInit, AfterViewInit } from '@angular/core';
import { UntypedFormGroup, UntypedFormBuilder, Validators, ValidatorFn, AbstractControl } from '@angular/forms';
import { BehaviorSubject } from 'rxjs';
import { UntypedFormGroup, UntypedFormBuilder, Validators } from '@angular/forms';
import { AppConfig } from '@geonature_config/app.config';
import { AuthService } from '@geonature/components/auth/auth.service';
// import { RoleFormService } from './services/form.service';
// import { UserDataService } from './services/user-data.service';
import { UserDataService } from './services/user-data.service';
import { DataFormService } from '@geonature_common/form/data-form.service';

export interface Role {
id_role?: string;
nom_role?: string;
prenom_role?: string;
identifiant?: string;
remarques?: string;
pass_plus?: string;
email?: string;
id_organisme?: string;
nom_complet?: string;
}

@Component({
selector: 'pnx-user',
templateUrl: './user.component.html',
styleUrls: ['./user.component.scss'],
})
export class UserComponent implements OnInit, AfterViewInit {

private role: BehaviorSubject<Role> = new BehaviorSubject(null);
private roleForm: UntypedFormGroup;

form: UntypedFormGroup;
public FORM_CONFIG = AppConfig.ACCOUNT_MANAGEMENT.ACCOUNT_FORM;
additionalFieldsForm: Array<any>;

constructor(
private authService: AuthService,
private fb: UntypedFormBuilder,
// private roleFormService: RoleFormService,
// private userService: UserDataService,
private userService: UserDataService,
private dataService: DataFormService
) {}

ngOnInit() {
//recupération des infos custom depuis la config de GN
this.additionalFieldsForm = [...AppConfig.ACCOUNT_MANAGEMENT.ACCOUNT_FORM]
.map(form_element => {
//on desactive les elements customs
form_element['disable'] = true;
return form_element;
});
this.initForm();

this.form.disable();
}

ngAfterViewInit() {
//patch du formulaire à partir des infos de l'utilisateur connecté
this.dataService.getRole(this.authService.getCurrentUser().id_role)
.subscribe((user) => {
this.form.patchValue(user)
console.log(this.form.value)
});

.subscribe((user) => this.form.patchValue(user));
}
console() {
console.log(this.form)
this.form.disable();

}
initForm() {
// this.form = this.getForm(this.authService.getCurrentUser().id_role);

this.form = this.fb.group({
identifiant: ['', Validators.required],
nom_role: ['', Validators.required],
Expand All @@ -75,34 +56,19 @@ console.log(this.form)
});
}

// getForm(role: number): UntypedFormGroup {
// return this.roleFormService.getForm(role);
// }

private getRole(role: number) {
this.dataService.getRole(role).subscribe((res) => {
this.roleForm.patchValue(res);

});
}

save() {
if (this.form.valid) {
// const finalForm = Object.assign({}, this.form.value);
// // concatenate two forms
// if (AppConfig.ACCOUNT_MANAGEMENT.ACCOUNT_FORM.length > 0) {
// finalForm['champs_addi'] = this.dynamicFormGroup.value;
// }
// this.userService.putRole(this.form.value).subscribe((res) => this.form.disable());
this.userService.putRole(this.form.value)
.subscribe((res) => this.form.disable());
}
}

cancel() {
// this.initForm();
// this.form.disable();
this.initForm();
this.form.disable();
}

enableForm() {
// this.form.enable();
this.form.enable();
}
}

0 comments on commit b0c9403

Please sign in to comment.