Search
 
SCRIPT & CODE EXAMPLE
 

JAVASCRIPT

Angular patchValue dynamically

@Component({ selector: "app-edit-recipe", templateUrl: "./edit-recipe.component.html", styleUrls: ["./edit-recipe.component.css"], }) export class EditRecipeComponent implements OnInit { editRecipeF!: FormGroup; recipeId: any; selectedRecipe!: Recipe; constructor( private formBuilder: FormBuilder, private recipesService: RecipesService, private route: ActivatedRoute ) {} ngOnInit() { this.recipeId = this.route.snapshot.params["id"]; this.editRecipeF = this.formBuilder.group({ recipeDetails: this.formBuilder.group({ title: ["", Validators.required], imageUrl: ["", Validators.required], duration: ["", Validators.required], calories: ["", Validators.required], }), ingredients: this.formBuilder.array([this.createIngFormGroup()]), }); this.recipesService.fetchRecipeDetails(this.recipeId).subscribe( (selectedRecipeDetails) => { this.selectedRecipe = selectedRecipeDetails; this.editRecipeF.patchValue({ recipeDetails: { title: this.selectedRecipe.title, imageUrl: this.selectedRecipe.imageUrl, duration: this.selectedRecipe.duration, calories: this.selectedRecipe.calories, }, }); const ing = this.editRecipeF.get("ingredients") as FormArray; for (let ingredient of this.selectedRecipe.ingredients) { ing.patchValue([ { name: ingredient.ingName, qty: ingredient.ingQty, qtyUnit: ingredient.ingQtyUnit, imageUrl: ingredient.ingImageUrl, }, ]); } }, (error) => { console.log(error); } ); } private createIngFormGroup() { return new FormGroup({ name: new FormControl("", Validators.required), qty: new FormControl("", Validators.required), qtyUnit: new FormControl("", Validators.required), imageUrl: new FormControl("", Validators.required), }); } public getControls() { return (<FormArray>this.editRecipeF.get("ingredients")).controls; } public onAddIngredients() { const ingredients = this.editRecipeF.get("ingredients") as FormArray; ingredients.push(this.createIngFormGroup()); } public onSubmitEditRecipeForm() { if (this.editRecipeF.valid) { console.log(this.editRecipeF.value); this.recipesService .editRecipe(this.editRecipeF.value, this.recipeId) .subscribe( (success) => {}, (error) => { console.log(error); } ); } } }
Comment

PREVIOUS NEXT
Code Example
Javascript :: puppeteer set up code 
Javascript :: of rxjs 
Javascript :: javascript breakpoint 
Javascript :: click binding angular 8 
Javascript :: lodash sum 
Javascript :: jq storage object on refresh 
Javascript :: flutter inject javascript in flutter webview 
Javascript :: search node in tree javascript 
Javascript :: if and else shorthand 
Javascript :: ng-true-value 
Javascript :: javascript return 
Javascript :: How to change height of bottom material tab navigator from react-naviagtion 
Javascript :: axios get array of urls 
Javascript :: ajax call to load a page on scrolling 
Javascript :: rows().remove 
Javascript :: empty object is falsy 
Javascript :: javascript addeventlistener click only works once 
Javascript :: lowercase 
Javascript :: spread and rest operator javascript 
Javascript :: get all objects from s3 bucket nodejs 
Javascript :: javscript loop array 
Javascript :: nodejs get cpu count 
Javascript :: node-fetch graphql 
Javascript :: jQuery - Remove 
Javascript :: react router params and render 
Javascript :: redux-logger 
Javascript :: await javascript 
Javascript :: electronjs 
Javascript :: pre html 
Javascript :: undefined 
ADD CONTENT
Topic
Content
Source link
Name
9+5 =