My HTML looks like this -
<form name="add_stepform" [formGroup]="ActionTypeForm" novalidate>
      <cdk-virtual-scroll-viewport [itemSize]="100" class="stepViewPort">
        <div [@fadeInOut] class="TestSteps example-item" 
             *cdkVirtualFor="let step of listOfSteps;TemplateCacheSize:0 let i=index">
          <div formArrayName="steps">
            <div [formGroupName]="i">
               <div class="form-group">
                  <label class="font16">Step Description</label>
                  <input id="stepDescription" type="text"
                    formControlName="stepDescription" class="form-control"
                    placeholder="ex: about the application" >
                    <mat-error *ngIf="stepDescription.errors?.required">
                        Description Required<br>
                    </mat-error>
                </div>
              </div>
           </div>
        </div>
     </cdk-virtual-scroll-viewport></form>
.ts file -
this.ActionTypeForm = new FormGroup({
  steps: new FormArray([this.testSteps()])})
testSteps() {
return new FormGroup({
  stepDescription: new FormControl('', [Validators.required)}
  get stepDescription(){
  return ((<FormArray>this.ActionTypeForm.get('steps')).controls)[0].get('stepDescription')
}
but its validating only first step description .. So any idea how to dynamically using index value ??

<mat-error>Description Required<br></mat-error>else you can use in the .html or pass as argument the "i" to a functionstep.get('stepDescription').errors?.requiredorActionTypeForm.get('steps').at(i).get('stepDescription').errors?.required