// (C) Copyright 2015 Moodle Pty Ltd. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. import { Component, Input, Output, EventEmitter, OnInit, OnDestroy, ElementRef } from '@angular/core'; import { CoreTimeUtils } from '@services/utils/time'; /** * This directive shows a timer in format HH:MM:SS. When the countdown reaches 0, a function is called. * * Usage: * */ @Component({ selector: 'core-timer', templateUrl: 'core-timer.html', styleUrls: ['timer.scss'], }) export class CoreTimerComponent implements OnInit, OnDestroy { @Input() endTime?: string | number; // Timestamp (in seconds) when the timer should end. @Input() timerText?: string; // Text to show next to the timer. If not defined, no text shown. @Input() timeLeftClass?: string; // Name of the class to apply with each second. By default, 'core-timer-timeleft-'. @Input() align?: string; // Where to align the time and text. Defaults to 'left'. Other values: 'center', 'right'. @Output() finished = new EventEmitter(); // Will emit an event when the timer reaches 0. timeLeft?: number; // Seconds left to end. protected timeInterval?: number; protected element?: HTMLElement; constructor( protected elementRef: ElementRef, ) {} /** * Component being initialized. */ ngOnInit(): void { const timeLeftClass = this.timeLeftClass || 'core-timer-timeleft-'; const endTime = Math.round(Number(this.endTime)); const container: HTMLElement | undefined = this.elementRef.nativeElement.querySelector('.core-timer'); if (!endTime) { return; } // Check time left every 200ms. this.timeInterval = window.setInterval(() => { this.timeLeft = endTime - CoreTimeUtils.instance.timestamp(); if (this.timeLeft < 0) { // Time is up! Stop the timer and call the finish function. clearInterval(this.timeInterval); this.finished.emit(); return; } // If the time has nearly expired, change the color. if (this.timeLeft < 100 && container && !container.classList.contains(timeLeftClass + this.timeLeft)) { // Time left has changed. Remove previous classes and add the new one. container.classList.remove(timeLeftClass + (this.timeLeft + 1)); container.classList.remove(timeLeftClass + (this.timeLeft + 2)); container.classList.add(timeLeftClass + this.timeLeft); } }, 200); } /** * Component destroyed. */ ngOnDestroy(): void { clearInterval(this.timeInterval); } }