This commit is contained in:
272
WebRoot/js/jdigiclock/lib/jquery.jdigiclock.js
Normal file
272
WebRoot/js/jdigiclock/lib/jquery.jdigiclock.js
Normal file
@@ -0,0 +1,272 @@
|
||||
/*
|
||||
* jDigiClock plugin 2.1
|
||||
*
|
||||
* http://www.radoslavdimov.com/jquery-plugins/jquery-plugin-digiclock/
|
||||
*
|
||||
* Copyright (c) 2009 Radoslav Dimov
|
||||
*
|
||||
* Dual licensed under the MIT and GPL licenses:
|
||||
* http://www.opensource.org/licenses/mit-license.php
|
||||
* http://www.gnu.org/licenses/gpl.html
|
||||
*
|
||||
*/
|
||||
|
||||
|
||||
(function($) {
|
||||
$.fn.extend({
|
||||
|
||||
jdigiclock: function(options) {
|
||||
|
||||
var defaults = {
|
||||
clockImagesPath: 'images/clock/',
|
||||
weatherImagesPath: 'images/weather/',
|
||||
lang: 'en',
|
||||
am_pm: false,
|
||||
weatherLocationCode: 'EUR|BG|BU002|BOURGAS',
|
||||
weatherMetric: 'C',
|
||||
weatherUpdate: 0,
|
||||
proxyType: 'php'
|
||||
|
||||
};
|
||||
|
||||
var regional = [];
|
||||
regional['en'] = {
|
||||
monthNames: ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'],
|
||||
dayNames: ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat']
|
||||
}
|
||||
|
||||
|
||||
var options = $.extend(defaults, options);
|
||||
|
||||
return this.each(function() {
|
||||
|
||||
var $this = $(this);
|
||||
var o = options;
|
||||
$this.clockImagesPath = o.clockImagesPath;
|
||||
$this.weatherImagesPath = o.weatherImagesPath;
|
||||
$this.lang = regional[o.lang] == undefined ? regional['en'] : regional[o.lang];
|
||||
$this.am_pm = o.am_pm;
|
||||
$this.weatherLocationCode = o.weatherLocationCode;
|
||||
$this.weatherMetric = o.weatherMetric == 'C' ? 1 : 0;
|
||||
$this.weatherUpdate = o.weatherUpdate;
|
||||
$this.proxyType = o.proxyType;
|
||||
$this.currDate = '';
|
||||
$this.timeUpdate = '';
|
||||
|
||||
|
||||
var html = '<div id="plugin_container">';
|
||||
html += '<div id="digital_container">';
|
||||
html += '<div id="clock"></div>';
|
||||
html += '</div>';
|
||||
html += '<div id="forecast_container"></div>';
|
||||
html += '</div>';
|
||||
|
||||
$this.html(html);
|
||||
|
||||
$this.displayClock($this);
|
||||
|
||||
$this.displayWeather($this);
|
||||
|
||||
var panel_pos = ($('#plugin_container > div').length - 1) * 500;
|
||||
var next = function() {
|
||||
$('#right_arrow').unbind('click', next);
|
||||
$('#plugin_container > div').filter(function(i) {
|
||||
$(this).animate({'left': (i * 500) - 500 + 'px'}, 400, function() {
|
||||
if (i == 0) {
|
||||
$(this).appendTo('#plugin_container').css({'left':panel_pos + 'px'});
|
||||
}
|
||||
$('#right_arrow').bind('click', next);
|
||||
});
|
||||
});
|
||||
};
|
||||
$('#right_arrow').bind('click', next);
|
||||
|
||||
var prev = function() {
|
||||
$('#left_arrow').unbind('click', prev);
|
||||
$('#plugin_container > div:last').prependTo('#plugin_container').css({'left':'-500px'});
|
||||
$('#plugin_container > div').filter(function(i) {
|
||||
$(this).animate({'left': i * 500 + 'px'}, 400, function() {
|
||||
$('#left_arrow').bind('click', prev);
|
||||
});
|
||||
});
|
||||
};
|
||||
$('#left_arrow').bind('click', prev);
|
||||
|
||||
});
|
||||
}
|
||||
});
|
||||
|
||||
|
||||
$.fn.displayClock = function(el) {
|
||||
$.fn.getTime(el);
|
||||
setTimeout(function() {$.fn.displayClock(el)}, $.fn.delay());
|
||||
}
|
||||
|
||||
$.fn.displayWeather = function(el) {
|
||||
$.fn.getWeather(el);
|
||||
if (el.weatherUpdate > 0) {
|
||||
setTimeout(function() {$.fn.displayWeather(el)}, (el.weatherUpdate * 60 * 1000));
|
||||
}
|
||||
}
|
||||
|
||||
$.fn.delay = function() {
|
||||
var now = new Date();
|
||||
var delay = (60 - now.getSeconds()) * 1000;
|
||||
|
||||
return delay;
|
||||
}
|
||||
|
||||
$.fn.getTime = function(el) {
|
||||
var now = new Date();
|
||||
var old = new Date();
|
||||
old.setTime(now.getTime() - 60000);
|
||||
|
||||
var now_hours, now_minutes, old_hours, old_minutes, timeOld = '';
|
||||
now_hours = now.getHours();
|
||||
now_minutes = now.getMinutes();
|
||||
old_hours = old.getHours();
|
||||
old_minutes = old.getMinutes();
|
||||
|
||||
if (el.am_pm) {
|
||||
var am_pm = now_hours > 11 ? 'pm' : 'am';
|
||||
now_hours = ((now_hours > 12) ? now_hours - 12 : now_hours);
|
||||
old_hours = ((old_hours > 12) ? old_hours - 12 : old_hours);
|
||||
}
|
||||
|
||||
now_hours = ((now_hours < 10) ? "0" : "") + now_hours;
|
||||
now_minutes = ((now_minutes < 10) ? "0" : "") + now_minutes;
|
||||
old_hours = ((old_hours < 10) ? "0" : "") + old_hours;
|
||||
old_minutes = ((old_minutes < 10) ? "0" : "") + old_minutes;
|
||||
// date
|
||||
el.currDate = el.lang.dayNames[now.getDay()] + ', ' + now.getDate() + ' ' + el.lang.monthNames[now.getMonth()];
|
||||
// time update
|
||||
el.timeUpdate = el.currDate + ', ' + now_hours + ':' + now_minutes;
|
||||
|
||||
var firstHourDigit = old_hours.substr(0,1);
|
||||
var secondHourDigit = old_hours.substr(1,1);
|
||||
var firstMinuteDigit = old_minutes.substr(0,1);
|
||||
var secondMinuteDigit = old_minutes.substr(1,1);
|
||||
|
||||
timeOld += '<div id="hours"><div class="line"></div>';
|
||||
timeOld += '<div id="hours_bg"><img src="' + el.clockImagesPath + 'clockbg1.png" /></div>';
|
||||
timeOld += '<img src="' + el.clockImagesPath + firstHourDigit + '.png" id="fhd" class="first_digit" />';
|
||||
timeOld += '<img src="' + el.clockImagesPath + secondHourDigit + '.png" id="shd" class="second_digit" />';
|
||||
timeOld += '</div>';
|
||||
timeOld += '<div id="minutes"><div class="line"></div>';
|
||||
if (el.am_pm) {
|
||||
timeOld += '<div id="am_pm"><img src="' + el.clockImagesPath + am_pm + '.png" /></div>';
|
||||
}
|
||||
timeOld += '<div id="minutes_bg"><img src="' + el.clockImagesPath + 'clockbg1.png" /></div>';
|
||||
timeOld += '<img src="' + el.clockImagesPath + firstMinuteDigit + '.png" id="fmd" class="first_digit" />';
|
||||
timeOld += '<img src="' + el.clockImagesPath + secondMinuteDigit + '.png" id="smd" class="second_digit" />';
|
||||
timeOld += '</div>';
|
||||
|
||||
el.find('#clock').html(timeOld);
|
||||
|
||||
// set minutes
|
||||
if (secondMinuteDigit != '9') {
|
||||
firstMinuteDigit = firstMinuteDigit + '1';
|
||||
}
|
||||
|
||||
if (old_minutes == '59') {
|
||||
firstMinuteDigit = '511';
|
||||
}
|
||||
|
||||
setTimeout(function() {
|
||||
$('#fmd').attr('src', el.clockImagesPath + firstMinuteDigit + '-1.png');
|
||||
$('#minutes_bg img').attr('src', el.clockImagesPath + 'clockbg2.png');
|
||||
},200);
|
||||
setTimeout(function() { $('#minutes_bg img').attr('src', el.clockImagesPath + 'clockbg3.png')},250);
|
||||
setTimeout(function() {
|
||||
$('#fmd').attr('src', el.clockImagesPath + firstMinuteDigit + '-2.png');
|
||||
$('#minutes_bg img').attr('src', el.clockImagesPath + 'clockbg4.png');
|
||||
},400);
|
||||
setTimeout(function() { $('#minutes_bg img').attr('src', el.clockImagesPath + 'clockbg5.png')},450);
|
||||
setTimeout(function() {
|
||||
$('#fmd').attr('src', el.clockImagesPath + firstMinuteDigit + '-3.png');
|
||||
$('#minutes_bg img').attr('src', el.clockImagesPath + 'clockbg6.png');
|
||||
},600);
|
||||
|
||||
setTimeout(function() {
|
||||
$('#smd').attr('src', el.clockImagesPath + secondMinuteDigit + '-1.png');
|
||||
$('#minutes_bg img').attr('src', el.clockImagesPath + 'clockbg2.png');
|
||||
},200);
|
||||
setTimeout(function() { $('#minutes_bg img').attr('src', el.clockImagesPath + 'clockbg3.png')},250);
|
||||
setTimeout(function() {
|
||||
$('#smd').attr('src', el.clockImagesPath + secondMinuteDigit + '-2.png');
|
||||
$('#minutes_bg img').attr('src', el.clockImagesPath + 'clockbg4.png');
|
||||
},400);
|
||||
setTimeout(function() { $('#minutes_bg img').attr('src', el.clockImagesPath + 'clockbg5.png')},450);
|
||||
setTimeout(function() {
|
||||
$('#smd').attr('src', el.clockImagesPath + secondMinuteDigit + '-3.png');
|
||||
$('#minutes_bg img').attr('src', el.clockImagesPath + 'clockbg6.png');
|
||||
},600);
|
||||
|
||||
setTimeout(function() {$('#fmd').attr('src', el.clockImagesPath + now_minutes.substr(0,1) + '.png')},800);
|
||||
setTimeout(function() {$('#smd').attr('src', el.clockImagesPath + now_minutes.substr(1,1) + '.png')},800);
|
||||
setTimeout(function() { $('#minutes_bg img').attr('src', el.clockImagesPath + 'clockbg1.png')},850);
|
||||
|
||||
// set hours
|
||||
if (now_minutes == '00') {
|
||||
|
||||
if (el.am_pm) {
|
||||
if (now_hours == '00') {
|
||||
firstHourDigit = firstHourDigit + '1';
|
||||
now_hours = '12';
|
||||
} else if (now_hours == '01') {
|
||||
firstHourDigit = '001';
|
||||
secondHourDigit = '111';
|
||||
} else {
|
||||
firstHourDigit = firstHourDigit + '1';
|
||||
}
|
||||
} else {
|
||||
if (now_hours != '10') {
|
||||
firstHourDigit = firstHourDigit + '1';
|
||||
}
|
||||
|
||||
if (now_hours == '20') {
|
||||
firstHourDigit = '1';
|
||||
}
|
||||
|
||||
if (now_hours == '00') {
|
||||
firstHourDigit = firstHourDigit + '1';
|
||||
secondHourDigit = secondHourDigit + '11';
|
||||
}
|
||||
}
|
||||
|
||||
setTimeout(function() {
|
||||
$('#fhd').attr('src', el.clockImagesPath + firstHourDigit + '-1.png');
|
||||
$('#hours_bg img').attr('src', el.clockImagesPath + 'clockbg2.png');
|
||||
},200);
|
||||
setTimeout(function() { $('#hours_bg img').attr('src', el.clockImagesPath + 'clockbg3.png')},250);
|
||||
setTimeout(function() {
|
||||
$('#fhd').attr('src', el.clockImagesPath + firstHourDigit + '-2.png');
|
||||
$('#hours_bg img').attr('src', el.clockImagesPath + 'clockbg4.png');
|
||||
},400);
|
||||
setTimeout(function() { $('#hours_bg img').attr('src', el.clockImagesPath + 'clockbg5.png')},450);
|
||||
setTimeout(function() {
|
||||
$('#fhd').attr('src', el.clockImagesPath + firstHourDigit + '-3.png');
|
||||
$('#hours_bg img').attr('src', el.clockImagesPath + 'clockbg6.png');
|
||||
},600);
|
||||
|
||||
setTimeout(function() {
|
||||
$('#shd').attr('src', el.clockImagesPath + secondHourDigit + '-1.png');
|
||||
$('#hours_bg img').attr('src', el.clockImagesPath + 'clockbg2.png');
|
||||
},200);
|
||||
setTimeout(function() { $('#hours_bg img').attr('src', el.clockImagesPath + 'clockbg3.png')},250);
|
||||
setTimeout(function() {
|
||||
$('#shd').attr('src', el.clockImagesPath + secondHourDigit + '-2.png');
|
||||
$('#hours_bg img').attr('src', el.clockImagesPath + 'clockbg4.png');
|
||||
},400);
|
||||
setTimeout(function() { $('#hours_bg img').attr('src', el.clockImagesPath + 'clockbg5.png')},450);
|
||||
setTimeout(function() {
|
||||
$('#shd').attr('src', el.clockImagesPath + secondHourDigit + '-3.png');
|
||||
$('#hours_bg img').attr('src', el.clockImagesPath + 'clockbg6.png');
|
||||
},600);
|
||||
|
||||
setTimeout(function() {$('#fhd').attr('src', el.clockImagesPath + now_hours.substr(0,1) + '.png')},800);
|
||||
setTimeout(function() {$('#shd').attr('src', el.clockImagesPath + now_hours.substr(1,1) + '.png')},800);
|
||||
setTimeout(function() { $('#hours_bg img').attr('src', el.clockImagesPath + 'clockbg1.png')},850);
|
||||
}
|
||||
}
|
||||
})(jQuery);
|
||||
Reference in New Issue
Block a user