| Current Path : /var/www/html/components/com_jssupportticket/include/js/ |
| Current File : /var/www/html/components/com_jssupportticket/include/js/circle.js |
jQuery(document).ready(function() {
var prefs = {
element: ".circlebar"
};
jQuery('.circlebar').each(function() {
prefs.element = jQuery(this);
new Circlebar(prefs);
});
});
function Circlebar(prefs) {
this.element = jQuery(prefs.element);
this.element.append('<div class="spinner-holder-one animate-0-25-a"><div class="spinner-holder-two animate-0-25-b"><div class="loader-spinner" style=""></div></div></div><div class="spinner-holder-one animate-25-50-a"><div class="spinner-holder-two animate-25-50-b"><div class="loader-spinner"></div></div></div><div class="spinner-holder-one animate-50-75-a"><div class="spinner-holder-two animate-50-75-b"><div class="loader-spinner"></div></div></div><div class="spinner-holder-one animate-75-100-a"><div class="spinner-holder-two animate-75-100-b"><div class="loader-spinner"></div></div></div>');
this.value, this.maxValue, this.counter, this.dialWidth, this.size, this.fontSize, this.fontColor, this.skin, this.triggerPercentage, this.type, this.timer;
// var attribs = this.element.find("div")[0].parentNode.dataset;
var attribs = this.element[0].dataset,
that = this;
this.initialise = function() {
that.value = parseInt(attribs.circleStarttime) || parseInt(prefs.startTime) || 0;
that.maxValue = parseInt(attribs.circleMaxvalue) || parseInt(prefs.maxValue) || 0;
that.counter = parseInt(attribs.circleCounter) || parseInt(prefs.counter) || 1000;
that.dialWidth = parseInt(attribs.circleDialwidth) || parseInt(prefs.dialWidth) || 5;
that.size = attribs.circleSize || prefs.size || "150px";
that.fontSize = attribs.circleFontsize || prefs.fontSize || "20px";
that.fontColor = attribs.circleFontcolor || prefs.fontColor || "rgb(135, 206, 235)";
that.skin = attribs.circleSkin || prefs.skin || " ";
that.triggerPercentage = attribs.circleTriggerpercentage || prefs.triggerPercentage || false;
that.type = attribs.circleType || prefs.type || "timer";
that.element.addClass(that.skin).addClass('loader');
that.element.find(".loader-bg").css("border-width", that.dialWidth + "px");
that.element.find(".loader-spinner").css("border-width", that.dialWidth + "px");
that.element.css({ "width": that.size, "height": that.size });
that.element.find(".loader-bg .text")
.css({ "font-size": that.fontSize, "color": that.fontColor });
};
this.initialise();
this.renderProgress = function(progress) {
progress = Math.floor(progress);
var angle = 0;
if (progress < 25) {
angle = -90 + (progress / 100) * 360;
that.element.find(".animate-0-25-b").css("transform", "rotate(" + angle + "deg)");
if (that.triggerPercentage) {
that.element.addClass('circle-loaded-0');
}
} else if (progress >= 25 && progress < 50) {
angle = -90 + ((progress - 25) / 100) * 360;
that.element.find(".animate-0-25-b").css("transform", "rotate(0deg)");
that.element.find(".animate-25-50-b").css("transform", "rotate(" + angle + "deg)");
if (that.triggerPercentage) {
that.element.removeClass('circle-loaded-0').addClass('circle-loaded-25');
}
} else if (progress >= 50 && progress < 75) {
angle = -90 + ((progress - 50) / 100) * 360;
that.element.find(".animate-25-50-b, .animate-0-25-b").css("transform", "rotate(0deg)");
that.element.find(".animate-50-75-b").css("transform", "rotate(" + angle + "deg)");
if (that.triggerPercentage) {
that.element.removeClass('circle-loaded-25').addClass('circle-loaded-50');
}
} else if (progress >= 75 && progress <= 100) {
angle = -90 + ((progress - 75) / 100) * 360;
that.element.find(".animate-50-75-b, .animate-25-50-b, .animate-0-25-b")
.css("transform", "rotate(0deg)");
that.element.find(".animate-75-100-b").css("transform", "rotate(" + angle + "deg)");
if (that.triggerPercentage) {
that.element.removeClass('circle-loaded-50').addClass('circle-loaded-75');
}
}
};
this.textFilter = function() {
var percentage = 0,
date = 0,
text = that.element.find(".text");
if (that.type == "progress") {
function setDeceleratingTimeout(factor, times) {
var internalCallback = function(counter) {
return function() {
if (that.value < that.maxValue && that.value < 100) {
that.value += 1;
that.renderProgress(that.value);
//text[0].dataset.value = that.value;
text.html(Math.floor(that.value) + "%");
setTimeout(internalCallback, ++counter * factor);
}
}
}(times, 0);
setTimeout(internalCallback, factor);
};
setDeceleratingTimeout(0.1, 100);
}
}
this.textFilter();
this.setValue = function(val) {
text = that.element.find(".text");
that.value = val;
that.renderProgress(that.value);
text[0].dataset.value = that.value;
text.html(that.value);
}
}
(function(jQuery) {
jQuery.fn.Circlebar = function(prefs) {
prefs.element = this.selector;
new Circlebar(prefs);
};
})(jQuery);