timeinterval.directive.js 7.07 KB
/*
 * Copyright © 2016 The Thingsboard Authors
 *
 * 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 './timeinterval.scss';

/* eslint-disable import/no-unresolved, import/default */

import timeintervalTemplate from './timeinterval.tpl.html';

/* eslint-enable import/no-unresolved, import/default */

export default angular.module('thingsboard.directives.timeinterval', [])
    .directive('tbTimeinterval', Timeinterval)
    .name;

/*@ngInject*/
function Timeinterval($compile, $templateCache, $translate) {

    var linker = function (scope, element, attrs, ngModelCtrl) {

        var template = $templateCache.get(timeintervalTemplate);
        element.html(template);

        scope.rendered = false;
        scope.days = 0;
        scope.hours = 0;
        scope.mins = 1;
        scope.secs = 0;

        scope.predefIntervals = [
            {
                name: $translate.instant('timeinterval.seconds-interval', {seconds: 10}, 'messageformat'),
                value: 10 * 1000
            },
            {
                name: $translate.instant('timeinterval.seconds-interval', {seconds: 30}, 'messageformat'),
                value: 30 * 1000
            },
            {
                name: $translate.instant('timeinterval.minutes-interval', {minutes: 1}, 'messageformat'),
                value: 60 * 1000
            },
            {
                name: $translate.instant('timeinterval.minutes-interval', {minutes: 2}, 'messageformat'),
                value: 2 * 60 * 1000
            },
            {
                name: $translate.instant('timeinterval.minutes-interval', {minutes: 5}, 'messageformat'),
                value: 5 * 60 * 1000
            },
            {
                name: $translate.instant('timeinterval.minutes-interval', {minutes: 10}, 'messageformat'),
                value: 10 * 60 * 1000
            },
            {
                name: $translate.instant('timeinterval.minutes-interval', {minutes: 30}, 'messageformat'),
                value: 30 * 60 * 1000
            },
            {
                name: $translate.instant('timeinterval.hours-interval', {hours: 1}, 'messageformat'),
                value: 60 * 60 * 1000
            },
            {
                name: $translate.instant('timeinterval.hours-interval', {hours: 2}, 'messageformat'),
                value: 2 * 60 * 60 * 1000
            },
            {
                name: $translate.instant('timeinterval.hours-interval', {hours: 10}, 'messageformat'),
                value: 10 * 60 * 60 * 1000
            },
            {
                name: $translate.instant('timeinterval.days-interval', {days: 1}, 'messageformat'),
                value: 24 * 60 * 60 * 1000
            },
            {
                name: $translate.instant('timeinterval.days-interval', {days: 7}, 'messageformat'),
                value: 7 * 24 * 60 * 60 * 1000
            },
            {
                name: $translate.instant('timeinterval.days-interval', {days: 30}, 'messageformat'),
                value: 30 * 24 * 60 * 60 * 1000
            }
        ];

        scope.setIntervalMs = function (intervalMs) {
            var intervalSeconds = Math.floor(intervalMs / 1000);
            scope.days = Math.floor(intervalSeconds / 86400);
            scope.hours = Math.floor((intervalSeconds % 86400) / 3600);
            scope.mins = Math.floor(((intervalSeconds % 86400) % 3600) / 60);
            scope.secs = intervalSeconds % 60;
        }

        ngModelCtrl.$render = function () {
            if (ngModelCtrl.$viewValue) {
                var intervalMs = ngModelCtrl.$viewValue;
                scope.setIntervalMs(intervalMs);
            }
            scope.rendered = true;
        }

        scope.updateView = function () {
            if (!scope.rendered) {
                return;
            }
            var value = null;
            var intervalMs = (scope.days * 86400 +
                scope.hours * 3600 +
                scope.mins * 60 +
                scope.secs) * 1000;
            if (!isNaN(intervalMs) && intervalMs > 0) {
                value = intervalMs;
                ngModelCtrl.$setValidity('tb-timeinterval', true);
            } else {
                ngModelCtrl.$setValidity('tb-timeinterval', !scope.required);
            }
            ngModelCtrl.$setViewValue(value);
        }

        scope.$watch('required', function (newRequired, prevRequired) {
            if (angular.isDefined(newRequired) && newRequired !== prevRequired) {
                scope.updateView();
            }
        });

        scope.$watch('secs', function (newSecs) {
            if (angular.isUndefined(newSecs)) {
                return;
            }
            if (newSecs < 0) {
                if ((scope.days + scope.hours + scope.mins) > 0) {
                    scope.secs = newSecs + 60;
                    scope.mins--;
                } else {
                    scope.secs = 0;
                }
            } else if (newSecs >= 60) {
                scope.secs = newSecs - 60;
                scope.mins++;
            }
            scope.updateView();
        });

        scope.$watch('mins', function (newMins) {
            if (angular.isUndefined(newMins)) {
                return;
            }
            if (newMins < 0) {
                if ((scope.days + scope.hours) > 0) {
                    scope.mins = newMins + 60;
                    scope.hours--;
                } else {
                    scope.mins = 0;
                }
            } else if (newMins >= 60) {
                scope.mins = newMins - 60;
                scope.hours++;
            }
            scope.updateView();
        });

        scope.$watch('hours', function (newHours) {
            if (angular.isUndefined(newHours)) {
                return;
            }
            if (newHours < 0) {
                if (scope.days > 0) {
                    scope.hours = newHours + 24;
                    scope.days--;
                } else {
                    scope.hours = 0;
                }
            } else if (newHours >= 24) {
                scope.hours = newHours - 24;
                scope.days++;
            }
            scope.updateView();
        });

        scope.$watch('days', function (newDays) {
            if (angular.isUndefined(newDays)) {
                return;
            }
            if (newDays < 0) {
                scope.days = 0;
            }
            scope.updateView();
        });

        $compile(element.contents())(scope);

    }

    return {
        restrict: "E",
        require: "^ngModel",
        scope: {
            required: '=ngRequired'
        },
        link: linker
    };
}