Skip to main content

A simple start and stop timer counter in angularjs

     AngularJs using to create a start and stop counting timer functionality application. This application is need the following directive like $interval and $filter, We create default time object is display current timer clock functions.

        A timer counter is have three functionality as below that start, stop and reset. A start function is called to start the $interval directive to active so now counter is begin, This moment you are unable to proceed a reset logic. 

       Stop function is is call to $interval belongs one of the method like cancel, This method make corresponding active interval prose is stop it. Reset function is call to reset all scope value is to be zero.

HTML:

<div ng-app="timerApp">
    <div ng-controller="timerController">
        Current Time : {{time}} <br/>
        <hr/>       
        <Button ng-click="timer_start()">Start</Button>
        <Button ng-click="timer_stop()">Stop</Button>
        <Button ng-click="timer_reset()" ng-disabled="isStartStatus">Reset</Button>
        <span>{{timerCount}}</span>
    </div>
</div>

AngularJS:

var app = angular.module("timerApp", []);
app.controller("timerController",['$scope','$interval','$filter', function($scope, $interval, $filter){   
    $interval(function(){  
        $scope.time = $filter('date')(new Date(),"hh:mm:ss a", 'UTC')
    },1000,0,null);
   
    $scope.minutesleft = 0;
    $scope.secondsleft = 0;   
    $scope.hoursleft = 0;
    $scope.millisecondsleft = 0;
    $scope.timerCount = $scope.hoursleft + ":" + $scope.minutesleft + ":" + $scope.secondsleft + ":" +            $scope.millisecondsleft;

    $scope.isStartStatus = true;
    /**/
    var promise;
    $scope.timer_start = function(){        
        $scope.isStartStatus = true;
       promise =   $interval(function(){
           $scope.millisecondsleft = $scope.millisecondsleft+1;
             if($scope.millisecondsleft>100){
                 $scope.secondsleft = $scope.secondsleft+1;
                 $scope.millisecondsleft = 0;
                 if($scope.secondsleft>60){
                    $scope.minutesleft = $scope.minutesleft+1;
                     $scope.secondsleft = 0;
                     if($scope.minutesleft>60){
                        $scope.hoursleft = $scope.hoursleft+1;
                        $scope.minutesleft = 0;
                         if($scope.hoursleft==24){
                             $scope.hoursleft = 0;
                         }
                     }
                 }
             }
                       
           $scope.timerCount = $scope.hoursleft + ":" + $scope.minutesleft + ":" + $scope.secondsleft + ":" +            $scope.millisecondsleft;
            
   },10,0,null); 
 };
    $scope.timer_stop = function(){
        $scope.isStartStatus = false;
        $interval.cancel(promise);
    }
   
    $scope.timer_reset = function(){
        $scope.minutesleft = 0;
        $scope.secondsleft = 0;   
        $scope.hoursleft = 0;
        $scope.millisecondsleft = 0;
         $scope.timerCount = $scope.hoursleft + ":" + $scope.minutesleft + ":" + $scope.secondsleft + ":" +            $scope.millisecondsleft;
    }
   
}]);


Result:

Demo

Comments

Popular posts from this blog

How has lockdown impacted Indian farmers?

How has lockdown impacted Indian farmers?             Generally compare to other sectors it's not major impacted by our Indian farmers but we acceptable minor impacts. Here we separate major two farming cultures one is mono farming culture another one poly farming culture. Mono farming :             The major impacts from our Indian farmer for monoculture. Here I have briefly explained what are the things we had faced our local farmers. Here I explain two different crops type: Daily crops : * We harvest more than 100-kilo grams daily crops like brinjal but we unable to sell those in local markets. * We are unable to reach urban markets. * We don't have enough transport facilities. * We unable buy require fertilizer and other complements * In the early stage we are facing manpower shortage but later it's not an issue. * We unable to do value-added products. * Waste is very high for somedays Se...

How to use ng-href directive in AngularJS

ng-Href Directive                  ng-Href directive is hyper link markup to a text in angularJs. This hyperlink will change able to implement dynamic url {{hash}} value. Hash value to assign in a controller to happened user click event fire to assign dynamic url. This Value is undefined means it will return to 404 page. ng-Href directive Example  HTML:      <div ng-app="anchor">     <div ng-controller="anchorController">         <a ng-href="http://www.google.com" ng-click="show($event)">Anchor Tag</a>     </div>   </div> Javascript :  var anch = angular.module('anchor', []); anch.controller('anchorController',['$scope', '$window', function($scope, $window){     $scope.show = function(obj) {       $window.open(obj.target.href);     } }]); Result :  Dem...

Google's Neverending Big Adventure

Google's Neverending Big Adventure   Why would Google want to send its Street View cameras into a vast crack in the Earth where there's nary a street to be found? It can't be as simple as "because it can." There must be some financial motive. Perhaps -- but monetization "is not how Google typically thinks about it," said tech analyst Greg Sterling. "This is part of the logic of Google's mission to map the real world in a complete way." In its ongoing effort to create the perfect map of the world at ground level, Google took a trek into the Grand Canyon this week. Although this is part of its Google Maps Street View project, there are of course no streets in the national park. Google Street View Product Manager Ryan Falor Google Street View Product Manager Ryan Falor controls the Trekker with his Android device. Earlier this month, Google announced that it had doubled the number of special collections in its Street View catalo...