You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
162 lines
5.7 KiB
162 lines
5.7 KiB
"use strict";
|
|
/**
|
|
* downCount: Simple Countdown clock with offset
|
|
* Author: Sonny T. <hi@sonnyt.com>, sonnyt.com
|
|
*/
|
|
|
|
|
|
(function ($) {
|
|
|
|
$.fn.downCount = function (options, callback) {
|
|
var settings = $.extend({
|
|
date: null,
|
|
offset: null
|
|
}, options);
|
|
|
|
// Throw error if date is not set
|
|
if (!settings.date) {
|
|
$.error('Date is not defined.');
|
|
}
|
|
|
|
// Throw error if date is set incorectly
|
|
if (!Date.parse(settings.date)) {
|
|
$.error('Incorrect date format, it should look like this, 12/24/2012 12:00:00.');
|
|
}
|
|
|
|
// Save container
|
|
var container = this;
|
|
|
|
/**
|
|
* Change client's local date to match offset timezone
|
|
* @return {Object} Fixed Date object.
|
|
*/
|
|
|
|
var secCount = -1;
|
|
var minCount = -1;
|
|
|
|
var timeZone = +0;
|
|
if ($('.site-config').attr('data-date-timezone') && ($('.site-config').attr('data-date-timezone') != '')) {
|
|
timeZone = $('.site-config').attr('data-date-timezone');
|
|
}
|
|
|
|
var currentDate = function () {
|
|
// get client's current date
|
|
var date = new Date();
|
|
|
|
// turn date to utc
|
|
// var utc = date.getTime() + (date.getTimezoneOffset() * 60000) - (360000*100);
|
|
var utc = date.getTime() + (date.getTimezoneOffset() * 60000) - (360000 * 100) + (360000 * 10) * timeZone;
|
|
|
|
// var utc = date.getTime() + (date.getTimezoneOffset() * 60000);
|
|
|
|
// set new Date object
|
|
var new_date = new Date(utc + (3600000 * settings.offset))
|
|
|
|
return new_date;
|
|
};
|
|
|
|
/**
|
|
* Main downCount function that calculates everything
|
|
*/
|
|
function countdown() {
|
|
var target_date = new Date(settings.date), // set target date
|
|
current_date = currentDate(); // get fixed current date
|
|
|
|
// difference of dates
|
|
var difference = target_date - current_date;
|
|
|
|
// if difference is negative than it's pass the target date
|
|
if (difference < 0) {
|
|
// stop timer
|
|
clearInterval(interval);
|
|
|
|
if (callback && typeof callback === 'function') callback();
|
|
|
|
return;
|
|
}
|
|
|
|
// basic math variables
|
|
// var _second = 1000,
|
|
var _second = 1000,
|
|
_minute = _second * 60,
|
|
_hour = _minute * 60,
|
|
_day = _hour * 24;
|
|
var _centi = _second / 100;
|
|
|
|
// calculate dates
|
|
var days = Math.floor(difference / _day),
|
|
hours = Math.floor((difference % _day) / _hour),
|
|
minutes = Math.floor((difference % _hour) / _minute),
|
|
seconds = Math.floor((difference % _minute) / _second),
|
|
centis = Math.floor((difference % _minute) / _centi);
|
|
|
|
// fix dates so that it will show two digets
|
|
days = (String(days).length >= 2) ? days : '0' + days;
|
|
hours = (String(hours).length >= 2) ? hours : '0' + hours;
|
|
minutes = (String(minutes).length >= 2) ? minutes : '0' + minutes;
|
|
seconds = (String(seconds).length >= 2) ? seconds : '0' + seconds;
|
|
|
|
// based on the date change the refrence wording
|
|
var ref_days = (days === 1) ? 'day' : 'days',
|
|
ref_hours = (hours === 1) ? 'hour' : 'hours',
|
|
ref_minutes = (minutes === 1) ? 'minute' : 'minutes',
|
|
ref_seconds = (seconds === 1) ? 'second' : 'seconds';
|
|
if (centis == 0) {
|
|
centis = 6000;
|
|
}
|
|
if (seconds == 0) {
|
|
seconds = 60;
|
|
}
|
|
if (seconds % 60 == 0) {
|
|
secCount--;
|
|
}
|
|
|
|
if (minutes == 0) {
|
|
minutes = 60;
|
|
}
|
|
if ((minutes % 60 == 0) && (seconds == 59)) {
|
|
minCount--;
|
|
}
|
|
|
|
// set to DOM class or css according to position
|
|
container.find('.days').text(days);
|
|
container.find('.hours').text(hours);
|
|
container.find('.minutes').text(minutes);
|
|
container.find('.seconds').text(seconds);
|
|
|
|
container.find('.days_ref').text(ref_days);
|
|
container.find('.hours_ref').text(ref_hours);
|
|
container.find('.minutes_ref').text(ref_minutes);
|
|
container.find('.seconds_ref').text(ref_seconds);
|
|
|
|
var minRot = (360 * minCount) + minutes * 6 + 'deg';
|
|
var secRot = (360 * secCount) + seconds * 6 + 'deg';
|
|
container.find('.c-minute').css({
|
|
'transform': 'rotate(' + minRot + ')',
|
|
'-webkit-transform': 'rotate(' + minRot + ')',
|
|
'-ms-transform': 'rotate(' + minRot + ')',
|
|
'-moz-transform': 'rotate(' + minRot + ')'
|
|
});
|
|
container.find('.c-second').css({
|
|
'transform': 'rotate(' + secRot + ')',
|
|
'-webkit-transform': 'rotate(' + secRot + ')',
|
|
'-ms-transform': 'rotate(' + secRot + ')',
|
|
'-moz-transform': 'rotate(' + secRot + ')'
|
|
});
|
|
|
|
// set knob value
|
|
|
|
$(".second .knob").val(centis).trigger("change");
|
|
};
|
|
|
|
// start
|
|
// var interval = setInterval(countdown, 1000);
|
|
// var interval = setInterval(countdown, 1000*0.1);
|
|
if ($(".clock-container").length || $(".alt-clock").length) {
|
|
var interval = setInterval(countdown, 250 * 1);
|
|
} else {
|
|
var interval = setInterval(countdown, 250 * 1);
|
|
}
|
|
};
|
|
|
|
})(jQuery);
|
|
|