You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
59 lines
1.4 KiB
JavaScript
59 lines
1.4 KiB
JavaScript
11 years ago
|
"use strict";
|
||
|
/*global ajaxify, socket, templates*/
|
||
|
|
||
|
(function(ajaxify) {
|
||
|
ajaxify.widgets.reposition = function() {
|
||
|
$('body [no-widget-class]').each(function() {
|
||
|
var $this = $(this);
|
||
|
$this.removeClass();
|
||
|
$this.addClass($this.attr('no-widget-class'));
|
||
|
});
|
||
|
};
|
||
|
|
||
|
ajaxify.widgets.render = function(tpl_url, url, callback) {
|
||
|
var widgetLocations = [], numLocations;
|
||
|
|
||
|
$('#content [widget-area]').each(function() {
|
||
|
widgetLocations.push($(this).attr('widget-area'));
|
||
|
});
|
||
|
|
||
|
numLocations = widgetLocations.length;
|
||
|
|
||
|
if (!numLocations) {
|
||
|
ajaxify.widgets.reposition();
|
||
|
}
|
||
|
|
||
|
function renderWidgets(location) {
|
||
|
var area = $('#content [widget-area="' + location + '"]');
|
||
|
|
||
|
socket.emit('widgets.render', {template: tpl_url + '.tpl', url: url, location: location}, function(err, renderedWidgets) {
|
||
|
if (area.html()) {
|
||
|
area.html(templates.parse(area.html(), {widgets: renderedWidgets}))
|
||
|
.removeClass('hidden');
|
||
|
|
||
|
if (!renderedWidgets.length) {
|
||
|
ajaxify.widgets.reposition();
|
||
|
}
|
||
|
}
|
||
|
|
||
|
$('#content [widget-area] img:not(.user-img)').addClass('img-responsive');
|
||
|
checkCallback();
|
||
|
});
|
||
|
}
|
||
|
|
||
|
function checkCallback() {
|
||
|
numLocations--;
|
||
|
if (numLocations < 0 && callback) {
|
||
|
callback();
|
||
|
}
|
||
|
}
|
||
|
|
||
|
for (var i in widgetLocations) {
|
||
|
if (widgetLocations.hasOwnProperty(i)) {
|
||
|
renderWidgets(widgetLocations[i]);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
checkCallback();
|
||
|
};
|
||
|
}(ajaxify || {}));
|