File

src/components/sq-countdown/sq-countdown.component.ts

Description

Represents the SqCountdownComponent, a component for countdown.

Example :
<sq-countdown [leftTime]="10"></sq-countdown>

Metadata

Index

Methods
Inputs
Outputs

Inputs

format
Type : string
Default value : 'mm:ss'

Formats a date value, pls refer to Accepted patterns.

leftTime
Type : number
Default value : 10

Starting time to countdown (e.g., 5.5, 30) (Unit: seconds).

notify
Type : number[] | number

Should be trigger type notify event on the x second. When values is 0 will be trigger every time.

Outputs

doneEmitter
Type : EventEmitter<ReturnEvent>

Event emitter for when the countdown ends.

notifyEmitter
Type : EventEmitter<ReturnEvent>

Event emitter for when the count reaches the input notify times.

startEmitter
Type : EventEmitter<ReturnEvent>

Event emitter for when the countdown starts.

Methods

eventMap
eventMap(event: CountdownEvent)

Map the CountdownEvents to emit startEmitter, notifyEmitter or doneEmitter.

Parameters :
Name Type Optional Description
event CountdownEvent No
  • The event associated with the CountdownEvents.
Returns : void
import { Component, EventEmitter, Input, Output } from '@angular/core'
import { CountdownComponent, CountdownEvent } from 'ngx-countdown'

/**
 * Interface for the return event os emitters.
 * @interface
 */
interface ReturnEvent {
  /**
   * The time left in the countdown.
   */
  left: number
}

/**
 * Represents the SqCountdownComponent, a component for countdown.
 * 
 * @example
 * <sq-countdown [leftTime]="10"></sq-countdown>
 */
@Component({
  selector: 'sq-countdown',
  templateUrl: './sq-countdown.component.html',
  styleUrls: ['./sq-countdown.component.scss'],
  standalone: true,
  imports: [CountdownComponent],
})
export class SqCountdownComponent {
  /**
   * Starting time to countdown (e.g., 5.5, 30) (Unit: seconds).
   */
  @Input() leftTime = 10

  /**
   * Formats a date value, pls refer to [Accepted patterns](https://angular.io/api/common/DatePipe#usage-notes).
   */
  @Input() format?: string = 'mm:ss'

  /**
   * Should be trigger type `notify` event on the x second. When values is `0` will be trigger every time.
   */
  @Input() notify?: number[] | number

  /**
   * Event emitter for when the countdown starts.
   */
  @Output() startEmitter: EventEmitter<ReturnEvent> = new EventEmitter()

  /**
   * Event emitter for when the count reaches the input notify times.
   */
  @Output() notifyEmitter: EventEmitter<ReturnEvent> = new EventEmitter()

  /**
   * Event emitter for when the countdown ends.
   */
  @Output() doneEmitter: EventEmitter<ReturnEvent> = new EventEmitter()

  /**
   * Map the CountdownEvents to emit startEmitter, notifyEmitter or doneEmitter.
   * @param event - The event associated with the CountdownEvents.
   */
  eventMap(event: CountdownEvent) {
    const action = event.action as "start" | "notify" | "done"
    if (action && this[`${action}Emitter`]) {
      const returnEvent: ReturnEvent = {
        left: event.left
      }
      this[`${action}Emitter`].emit(returnEvent)
    }
  }
}
<countdown 
  [config]="{
    leftTime: leftTime, 
    format: format, 
    notify: notify
  }" 
  (event)="eventMap($event)"
/>

./sq-countdown.component.scss

::ng-deep {
  sq-countdown {
    min-width: min-content;
    countdown.count-down {
      span {
        color: var(--text_color);
      }
    }
  }
}
Legend
Html element
Component
Html element with directive

results matching ""

    No results matching ""