Files
EasySoft-ZenTaoPMS/module/block/js/dashboard.js
2017-04-19 10:58:04 +08:00

196 lines
5.9 KiB
JavaScript

/**
* Delete block.
*
* @param int $index
* @access public
* @return void
*/
function deleteBlock(index)
{
$.getJSON(createLink('block', 'delete', 'index=' + index + '&module=' + module), function(data)
{
if(data.result != 'success')
{
alert(data.message);
return false;
}
checkEmpty();
})
}
/**
* Sort blocks.
*
* @param object $orders format is {'block2' : 1, 'block1' : 2, oldOrder : newOrder}
* @access public
* @return void
*/
function sortBlocks(orders)
{
var ordersMap = [];
$.each(orders, function(blockId, order) {ordersMap.push({id: blockId, order: order});});
ordersMap.sort(function(a, b) {return a.order - b.order;});
var newOrders = $.map(ordersMap, function(order, idx) {return order.id});
$.getJSON(createLink('block', 'sort', 'orders=' + newOrders.join(',') + '&module=' + module), function(data)
{
// if(data.result == 'success') $.zui.messager.success(config.ordersSaved);
});
}
/**
* Check dashboard wether is empty
* @access public
* @return void
*/
function checkEmpty()
{
var $dashboard = $('#dashboard');
var hasBlocks = !!$dashboard.children('.row').children().length;
$dashboard.find('.dashboard-empty-message').toggleClass('hide', hasBlocks);
if(!hasBlocks) $dashboard.find('.dashboard-actions').addClass('hide');
}
/**
* Resize block
* @param object $event
* @access public
* @return void
*/
function resizeBlock(event)
{
var blockID = event.element.find('.panel').data('id');
var data = event.type == 'vertical' ? event.height : event.grid;
$.getJSON(createLink('block', 'resize', 'id=' + blockID + '&type=' + event.type + '&data=' + data), function(data)
{
if(data.result !== 'success') event.revert();
});
initTableHeader();
}
/**
* Init table header
* @access public
* @return void
*/
function initTableHeader()
{
$('#dashboard .panel-block').each(function()
{
var $panel = $(this);
var $table = $panel.find('.table:first');
if(!$table.length || !$table.children('thead').length) return;
var isFixed = $panel.find('.panel-body').height() < $table.outerHeight();
$panel.toggleClass('with-fixed-header', isFixed);
var $header = $panel.children('.table-header-fixed').toggle(isFixed);
if(!isFixed)
{
$table.find('thead').css('visibility', 'visible');
return;
}
var tableWidth = $table.width();
if(!$header.length)
{
$header = $('<div class="table-header-fixed" style="position: absolute; left: 0; top: 0; right: 0;"><table class="table table-fixed"></table></div>').css('right', $panel.width() - tableWidth).css('min-width', tableWidth);
var $oldTableHead = $table.find('thead');
$oldTableHead.find('th').each(function(idx)
{
$(this).attr('data-idx', idx);
});
$header.find('.table').addClass($table.attr('class')).append($oldTableHead.css('visibility', 'hidden').clone().css('visibility', 'visible'));
$panel.addClass('with-fixed-header').append($header);
var $heading = $panel.children('.panel-heading');
if($heading.length) $header.css('top', $heading.outerHeight());
if($table.hasClass('tablesorter'))
{
$header.on('mousedown mouseup', 'th[data-idx]', function(e)
{
var $th = $(this);
var $targetTh = $oldTableHead.find('th[data-idx="' + $th.data('idx') + '"]').trigger(e);
if(e.type === 'mouseup')
{
var updateTh = function()
{
$header.find('thead').empty().append($oldTableHead.find('tr').clone());
};
setTimeout(updateTh, 10);
setTimeout(updateTh, 200);
}
});
}
}
else
{
var $fixedTh = $header.css('min-width', tableWidth).css('right', $panel.width() - tableWidth).find('thead > tr > th');
$table.find('thead > tr > th').each(function(idx)
{
$fixedTh.eq(idx).width($(this).width());
});
}
});
}
/**
* Check refresh progress
* @param object $dashboard
* @access public
* @return void
*/
function checkRefreshProgress($dashboard, doneCallback)
{
if($dashboard.find('.panel-loading').length) setTimeout(function() {checkRefreshProgress($dashboard, doneCallback);}, 500);
else doneCallback();
}
/**
* Hidden block.
*
* @param index $index
* @access public
* @return void
*/
function hiddenBlock(index)
{
$.getJSON(createLink('block', 'delete', 'index=' + index + '&module=' + module + '&type=hidden'), function(data)
{
if(data.result != 'success')
{
alert(data.message);
return false;
}
$('#dashboard #block' + index).addClass('hidden');
})
}
$(function()
{
var $dashboard = $('#dashboard').dashboard(
{
height : 240,
draggable : !useGuest,
shadowType : false,
afterOrdered : sortBlocks,
afterPanelRemoved : deleteBlock,
sensitive : true,
panelRemovingTip : config.confirmRemoveBlock,
resizable : !useGuest,
onResize : resizeBlock,
afterRefresh : function(e)
{
var $sortTable = e.$panel.find('.tablesorter');
if($sortTable.length) $sortTable.sortTable();
initTableHeader();
}
});
// $dashboard.find('ul.dashboard-actions').addClass('hide').children('li').addClass('right').appendTo($('#modulemenu > .nav'));
$dashboard.find('[data-toggle=tooltip]').tooltip({container: 'body'});
checkEmpty();
initTableHeader();
});