All files / src/app/extensions/rating/formly/rating-stars-field rating-stars-field.component.ts

100% Statements 8/8
50% Branches 1/2
100% Functions 3/3
100% Lines 6/6

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 241x 1x 1x                       1x   10x       5x      
import { ChangeDetectionStrategy, Component } from '@angular/core';
import { FieldType, FieldTypeConfig } from '@ngx-formly/core';
import { range } from 'lodash-es';
 
import { RatingFilledType } from '../../shared/product-rating-star/product-rating-star.component';
 
/**
 * Type that will render 5 stars to rate a product.
 */
@Component({
  selector: 'ish-rating-stars-field',
  templateUrl: './rating-stars-field.component.html',
  changeDetection: ChangeDetectionStrategy.OnPush,
})
export class RatingStarsFieldComponent extends FieldType<FieldTypeConfig> {
  get stars(): RatingFilledType[] {
    return range(1, 6).map(index => (index <= this.field?.formControl.value ? 'full' : 'empty'));
  }
 
  setStars(stars: number) {
    this.field.formControl.setValue(stars);
  }
}