Search code examples
htmlangularangular-forms

How to add validations to a radio button in angular


This is my form in angular.

hotel.component.html:

<div class="container-sm">

  <div class="bg-light jumbotron text-center">
    <h2>Hotel</h2>

  </div>
<form [formGroup]="form" (submit)="onSubmit()" class="mb-3">

    <div class="col">
      <label class="form-label fw-bold">Ammenities:</label>
      <div class="d-flex">
        <div class="form-check me-4">

          <label class="form-check-label"><input class="form-check-input" type="radio" name="option" value="Pool" formControlName="option"> Pool </label>
        </div>
        <div class="form-check">
          <label class="form-check-label"><input class="form-check-input" type="radio" name="option" value="Laundry" formControlName="option"> Laundry </label>
        </div>
      </div>
    <div *ngIf="form.controls['option'].touched && form.controls['option'].invalid">
      <div *ngIf="form.controls['option'].hasError('required')" class="error">Please select an option</div>
    </div>
    </div>


  <div class="row">
    <div class="col">
      <div class="btn-group">
        <button  type="submit" class="btn btn-primary mr-1">Submit</button>
      </div>
    </div>
  </div>
</form>
</div>
<br>
<br>


hotel.component.ts:


import { Component } from '@angular/core';
import { CommonModule, Location } from '@angular/common';

import { FormGroup, FormBuilder,FormControl, Validators, FormArray } from '@angular/forms';

export class HotelComponent {
//
  form: FormGroup;

  constructor(private fb: FormBuilder) {


    this.form = this.fb.group({
      option: ['', Validators.required],
    });
  }

  onSubmit() {
    if (this.form.valid) {
        console.log(option);

          
        }
     }
}


Just a simple form with a radio and a submit button. If user tries to submit the form without selecting any options, the error message should be shown. Right now ,no error message appears when I click on submit without selecting ana option.

Can someone tell me how to make the validation work?


Solution

  • You have added a condition that if your control is touched and invalid then only show the error. Talking about this condition which needs to be fixed:

    <div *ngIf="form.controls['option'].touched && form.controls['option'].invalid">
          <div *ngIf="form.controls['option'].hasError('required')" class="error">Please select an option</div>
    </div>
    

    To fix this issue either you can mark your control touched or remove touched condition from your HTML code. form.controls['option'].touched

    Component side to mark control tocuhed:

     this.form = this.fb.group({
          option: ['', Validators.required],
        });
     this.form.controls['option'].markAsTouched();
    

    Moreover if you want to disable button if none of the options are selected then you can use this contion on button:

    [disabled]="form.invalid"