Home Angular Angular 15 Flight Booking Form with Validations Working Example

Angular 15 Flight Booking Form with Validations Working Example

by therichpost
Published: Updated: 0 comments
Angular 15 Flight Booking Form with Validations Working Example

Hello to all, welcome to therichpost.com. In this post, I will tell you, Angular 15 Flight Booking Form with Validations Working Example.

Guys with this we will cover below things:

  1. Angular 15 Reactive Form Implelemtnation.
  2. Reactive forms validation email with valid format.
  3. Reactive form checkbox validation.
  4. Angular15 Reactive Form Responsiveness with Bootstrap 5.
Working Live Demo
Angular 15 Flight Booking Form with Validations Working Example
Angular 15 Flight Booking Form with Validations Working Example

Angular15 came and if you are new then you must check below link:

  1. Angular 15 Tutorials

Here is the code snippet and please use carefully:

1. Very first guys, here are common basics steps to add angular 15 application on your machine and also we must have latest nodejs version(14.17.0) installed for angular 15:

npm install -g @angular/cli

ng new angularform // Set Angular 15 Application on your pc

cd angularform // Go inside project folder

2. Now run below commands to set bootstrap 5 modules into our angular 15 application for responsiveness (optional):

npm install bootstrap

npm i @popperjs/core

3. Now friends we just need to add below code into angularform/angular.json file (optional):

"styles": [
              ...
              "node_modules/bootstrap/dist/css/bootstrap.min.css"
          ],
"scripts": [
              ...
               "node_modules/bootstrap/dist/js/bootstrap.min.js"
           ]

4. Now guys we will add below code into our angularform/src/app/app.module.ts file:

...
import { ReactiveFormsModule } from '@angular/forms';

@NgModule({
...
  imports: [
   ...
    ReactiveFormsModule,
   
  ],
  providers: [],
  bootstrap: [AppComponent]
})
export class AppModule { }

5. Now guys we will add below code into our angularform/src/app/app.component.ts file:

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

@Component({
  selector: 'app-root',
  templateUrl: './app.component.html',
  styleUrls: ['./app.component.css']
})
export class AppComponent {
  //Form variables
registerForm:any = FormGroup;
submitted = false;
constructor( private formBuilder: FormBuilder){}
//Add user form actions
get f() { return this.registerForm.controls; }
onSubmit() {
  
  this.submitted = true;
  // stop here if form is invalid
  if (this.registerForm.invalid) {
      return;
  }
  //True if all the fields are filled
  if(this.submitted)
  {
    alert("Great!!");
  }
 
}
  ngOnInit() {
    //Add form validations
     this.registerForm = this.formBuilder.group({
      ffrom: ['', [Validators.required]],
      fto: ['', [Validators.required]],
      dparting: ['', [Validators.required]],
      returning: ['', [Validators.required]],
      adults: ['', [Validators.required]],
      children: ['', [Validators.required]],
      travel: ['', [Validators.required]],
      roundtripopt: ['', [Validators.required]],
      
      });
  }
}

6. Finally we will add below code into our angularform/src/app/app.component.html file:

<div class="container">
    <div class="card p-4 mt-5">
        <form [formGroup]="registerForm" (ngSubmit)="onSubmit()">
            <div class="row g-3">
            
                    <div class="col-12 mb-4">
                        <h4>Flight Booking</h4>
                        <span class="text-muted">Please make the payment to start enjoying all the features of our premium plan as soon as possible</span>
                    </div>
                    <div class="col-12">
                        <div class="form-check form-check-inline mb-3">
                            <input class="form-check-input" type="radio" name="inlineRadioOptions" id="Roundtrip" value="option1" formControlName="roundtripopt"  [ngClass]="{ 'is-invalid': submitted && f.roundtripopt.errors }">
                            <label class="form-check-label" for="Roundtrip">Roundtrip</label>
                            <div *ngIf="submitted && f.roundtripopt.errors" class="invalid-feedback mb" style="display: table;position: absolute;left: 16px;top: 150px;margin-bottom: 5px;">
                                <div *ngIf="f.roundtripopt.errors.required">Roundtrip is required.</div>
                             </div>
                        </div>
                        <div class="form-check form-check-inline">
                            <input class="form-check-input" type="radio" name="inlineRadioOptions" id="Oneway" value="option2" formControlName="roundtripopt"  [ngClass]="{ 'is-invalid': submitted && f.roundtripopt.errors }">
                            <label class="form-check-label" for="Oneway">One way</label>
                        </div>
                        <div class="form-check form-check-inline">
                            <input class="form-check-input" type="radio" name="inlineRadioOptions" id="MultiCity" value="option3" formControlName="roundtripopt"  [ngClass]="{ 'is-invalid': submitted && f.roundtripopt.errors }">
                            <label class="form-check-label" for="MultiCity">Multi-City</label>
                           
                        </div>
                        
                    </div>
                    <div class="col-lg-6 col-md-12">
                        <div class="form-floating">
                            <input type="text" placeholder="FLYING FROM" formControlName="ffrom" class="form-control" [ngClass]="{ 'is-invalid': submitted && f.ffrom.errors }">
                            <div *ngIf="submitted && f.ffrom.errors" class="invalid-feedback">
                                <div *ngIf="f.ffrom.errors.required">FLYING FROM is required.</div>
                             </div>
                            <label>FLYING FROM</label>
                        </div>
                    </div>
                    <div class="col-lg-6 col-md-12">
                        <div class="form-floating">
                            <input type="text" placeholder="FLYING TO" formControlName="fto" class="form-control" [ngClass]="{ 'is-invalid': submitted && f.fto.errors }">
                            <div *ngIf="submitted && f.fto.errors" class="invalid-feedback">
                                <div *ngIf="f.fto.errors.required">FLYING TO is required.</div>
                             </div>
                            <label>FLYING TO</label>
                        </div>
                    </div>
                    <div class="col-lg-6 col-md-12">
                        <div class="form-floating">
                            <input type="date" placeholder="DEPARTING" formControlName="dparting" class="form-control" [ngClass]="{ 'is-invalid': submitted && f.dparting.errors }">
                            <div *ngIf="submitted && f.dparting.errors" class="invalid-feedback">
                                <div *ngIf="f.dparting.errors.required">DEPARTING is required.</div>
                             </div>
                            <label>DEPARTING</label>
                        </div>
                    </div>
                    <div class="col-lg-6 col-md-12">
                        <div class="form-floating">
                            <input type="date" placeholder="RETURNING" formControlName="returning" class="form-control" [ngClass]="{ 'is-invalid': submitted && f.returning.errors }">
                            <div *ngIf="submitted && f.returning.errors" class="invalid-feedback">
                                <div *ngIf="f.returning.errors.required">RETURNING is required.</div>
                             </div>
                            <label>RETURNING</label>
                        </div>
                    </div>
                    <div class="col-lg-4 col-md-12">
                        <div class="form-floating">
                            <select class="form-select" formControlName="adults"  [ngClass]="{ 'is-invalid': submitted && f.adults.errors }">
                            <option selected="" hidden="">Open this select menu</option>
                            <option value="1">One</option>
                            <option value="2">Two</option>
                            <option value="3">Three</option>
                            </select>
                            <div *ngIf="submitted && f.adults.errors" class="invalid-feedback">
                                <div *ngIf="f.adults.errors.required">ADULTS is required.</div>
                             </div>
                            <label>ADULTS(18+)</label>
                        </div>
                    </div>
                    <div class="col-lg-4 col-md-12">
                        <div class="form-floating">
                            <select class="form-select" formControlName="children"  [ngClass]="{ 'is-invalid': submitted && f.children.errors }">
                            <option selected="" hidden="">Open this select menu</option>
                            <option value="1">One</option>
                            <option value="2">Two</option>
                            <option value="3">Three</option>
                            </select>
                            <div *ngIf="submitted && f.children.errors" class="invalid-feedback">
                                <div *ngIf="f.children.errors.required">CHILDREN is required.</div>
                             </div>
                            <label>CHILDREN(0-17)</label>
                        </div>
                    </div>
                    <div class="col-lg-4 col-md-12">
                        <div class="form-floating">
                            <select class="form-select" formControlName="travel"  [ngClass]="{ 'is-invalid': submitted && f.travel.errors }">
                            <option selected="" hidden="">Open this select menu</option>
                            <option value="1">Economy</option>
                            <option value="2">Premium</option>
                            <option value="3">Business</option>
                            </select>
                            <div *ngIf="submitted && f.travel.errors" class="invalid-feedback">
                                <div *ngIf="f.travel.errors.required">TRAVEL is required.</div>
                             </div>
                            <label>TRAVEL CLASS</label>
                        </div>
                    </div>
                    <div class="col-12 mt-4">
                        <button class="btn btn-primary text-uppercase" type="submit">SHOWN FLIGHTS<i class="fa fa-plane ms-3"></i></button>
                    </div>
                
            </div>
        </form>
    </div>
</div>

7. Now we will add below font awesome icons link into our angularform/src/index.html file:

<!doctype html>
<html lang="en">
<head>
 ...
  
  <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.0.3/css/font-awesome.css"/>
</head>

Now we are done friends and please run ng serve command to check the output in browser(locahost:4200) and if you have any kind of query then please do comment below.

Note: Friends, I just tell the basic setup and things, you can change the code according to your requirements. For better understanding please watch video above.

Guys I will appreciate that if you will tell your views for this post. Nothing matters if your views will be good or bad.

Jassa

Thanks

You may also like

Leave a Comment

This site uses Akismet to reduce spam. Learn how your comment data is processed.