File

src/app/shared/directives/dimless-binary-per-second.directive.ts

Implements

OnInit

Metadata

Selector [cdDimlessBinaryPerSecond]

Index

Properties
  • Private el
Methods
Inputs
Outputs
HostListeners

Constructor

constructor(elementRef: ElementRef, control: NgControl, dimlessBinaryPerSecondPipe: DimlessBinaryPerSecondPipe, formatter: FormatterService)
Parameters :
Name Type Optional
elementRef ElementRef No
control NgControl No
dimlessBinaryPerSecondPipe DimlessBinaryPerSecondPipe No
formatter FormatterService No

Inputs

defaultUnit
Type : string

Default unit that should be used when user do not type a unit. By default, "MiB" will be used.

Example: Given defaultUnit=null, if user type 7, then model will be updated to 7MiB Given defaultUnit=k, if user type 7, then model will be updated to 7KiB

maxBytes
Type : number

Maximum size in bytes. If user enter a value greater than , the model will automatically be update to .

If is used, this value should be a power of .

Example: Given maxBytes=3145728 (3MiB), if user type 4MiB, then model will be updated to 3MiB

minBytes
Type : number

Minimum size in bytes. If user enter a value lower than , the model will automatically be update to .

If is used, this value should be a power of .

Example: Given minBytes=4096 (4KiB), if user type 1KiB, then model will be updated to 4KiB

ngDataReady
Type : EventEmitter<any>

Event emitter for letting this directive know that the data has (asynchronously) been loaded and the value needs to be adapted by this directive.

roundPower
Type : number

Value will be rounded up the nearest power of

Example: Given roundPower=2, if user type 7KiB, then model will be updated to 8KiB Given roundPower=2, if user type 5KiB, then model will be updated to 4KiB

Outputs

ngModelChange
Type : EventEmitter<any>

HostListeners

blur
Arguments : '$event.target.value'
blur(value)

Methods

ngOnInit
ngOnInit()
Returns : void
round
round(size)
Parameters :
Name Optional
size No
Returns : any
setValue
setValue(value)
Parameters :
Name Optional
value No
Returns : void

Properties

Private el
Type : HTMLInputElement
import {
  Directive,
  ElementRef,
  EventEmitter,
  HostListener,
  Input,
  OnInit,
  Output
} from '@angular/core';
import { NgControl } from '@angular/forms';

import * as _ from 'lodash';

import { DimlessBinaryPerSecondPipe } from '../pipes/dimless-binary-per-second.pipe';
import { FormatterService } from '../services/formatter.service';

@Directive({
  selector: '[cdDimlessBinaryPerSecond]'
})
export class DimlessBinaryPerSecondDirective implements OnInit {
  @Output()
  ngModelChange: EventEmitter<any> = new EventEmitter();

  /**
   * Event emitter for letting this directive know that the data has (asynchronously) been loaded
   * and the value needs to be adapted by this directive.
   */
  @Input()
  ngDataReady: EventEmitter<any>;

  /**
   * Minimum size in bytes.
   * If user enter a value lower than <minBytes>,
   * the model will automatically be update to <minBytes>.
   *
   * If <roundPower> is used, this value should be a power of <roundPower>.
   *
   * Example:
   *   Given minBytes=4096 (4KiB), if user type 1KiB, then model will be updated to 4KiB
   */
  @Input()
  minBytes: number;

  /**
   * Maximum size in bytes.
   * If user enter a value greater than <maxBytes>,
   * the model will automatically be update to <maxBytes>.
   *
   * If <roundPower> is used, this value should be a power of <roundPower>.
   *
   * Example:
   *   Given maxBytes=3145728 (3MiB), if user type 4MiB, then model will be updated to 3MiB
   */
  @Input()
  maxBytes: number;

  /**
   * Value will be rounded up the nearest power of <roundPower>
   *
   * Example:
   *   Given roundPower=2, if user type 7KiB, then model will be updated to 8KiB
   *   Given roundPower=2, if user type 5KiB, then model will be updated to 4KiB
   */
  @Input()
  roundPower: number;

  /**
   * Default unit that should be used when user do not type a unit.
   * By default, "MiB" will be used.
   *
   * Example:
   *   Given defaultUnit=null, if user type 7, then model will be updated to 7MiB
   *   Given defaultUnit=k, if user type 7, then model will be updated to 7KiB
   */
  @Input()
  defaultUnit: string;

  private el: HTMLInputElement;

  constructor(
    private elementRef: ElementRef,
    private control: NgControl,
    private dimlessBinaryPerSecondPipe: DimlessBinaryPerSecondPipe,
    private formatter: FormatterService
  ) {
    this.el = this.elementRef.nativeElement;
  }

  ngOnInit() {
    this.setValue(this.el.value);
    if (this.ngDataReady) {
      this.ngDataReady.subscribe(() => this.setValue(this.el.value));
    }
  }

  setValue(value) {
    if (/^[\d.]+$/.test(value)) {
      value += this.defaultUnit || 'm';
    }
    const size = this.formatter.toBytes(value, 0);
    const roundedSize = this.round(size);
    this.el.value = this.dimlessBinaryPerSecondPipe.transform(roundedSize);
    if (size !== null) {
      this.ngModelChange.emit(this.el.value);
      this.control.control.setValue(this.el.value);
    } else {
      this.ngModelChange.emit(null);
      this.control.control.setValue(null);
    }
  }

  round(size) {
    if (size !== null && size !== 0) {
      if (!_.isUndefined(this.minBytes) && size < this.minBytes) {
        return this.minBytes;
      }
      if (!_.isUndefined(this.maxBytes) && size > this.maxBytes) {
        return this.maxBytes;
      }
      if (!_.isUndefined(this.roundPower)) {
        const power = Math.round(Math.log(size) / Math.log(this.roundPower));
        return Math.pow(this.roundPower, power);
      }
    }
    return size;
  }

  @HostListener('blur', ['$event.target.value'])
  onBlur(value) {
    this.setValue(value);
  }
}

result-matching ""

    No results matching ""