mirror of
https://github.com/Combodo/iTop.git
synced 2026-05-19 15:22:17 +02:00
Added the ability to reload a selection fro a paginated list.
SVN:trunk[1524]
This commit is contained in:
@@ -105,7 +105,7 @@ function sprintf(format, etc) {
|
|||||||
$(':input[name^=storedSelection]', pager).remove();
|
$(':input[name^=storedSelection]', pager).remove();
|
||||||
}
|
}
|
||||||
|
|
||||||
function updateSelection(table, pager, id, value)
|
function storeSelection(table, pager, id, value)
|
||||||
{
|
{
|
||||||
var valueToStore = value;
|
var valueToStore = value;
|
||||||
if (table.config.selectionMode == 'negative')
|
if (table.config.selectionMode == 'negative')
|
||||||
@@ -133,6 +133,12 @@ function sprintf(format, etc) {
|
|||||||
updateCounter(table, pager);
|
updateCounter(table, pager);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function loadSelection(table, pager)
|
||||||
|
{
|
||||||
|
table.config.selectionMode = $(pager).find(':input[name=selectionMode]').val();
|
||||||
|
updateCounter(table, pager);
|
||||||
|
}
|
||||||
|
|
||||||
function updateCounter(table, pager)
|
function updateCounter(table, pager)
|
||||||
{
|
{
|
||||||
var ex = $(':input[name^=storedSelection]', pager).length;
|
var ex = $(':input[name^=storedSelection]', pager).length;
|
||||||
@@ -205,53 +211,7 @@ function sprintf(format, etc) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
fixPosition(table,tableBody);
|
fixPosition(table,tableBody);
|
||||||
if (c.selectionMode == 'negative')
|
applySelection(table);
|
||||||
{
|
|
||||||
$(table).find(':checkbox[name^=selectObj]').attr('checked', true);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (table.config.select_mode == 'multiple')
|
|
||||||
{
|
|
||||||
$(table).find(':checkbox[name^=selectObj]').each(function() {
|
|
||||||
var id = parseInt(this.value, 10);
|
|
||||||
if ($('#'+id, table.config.container).length > 0)
|
|
||||||
{
|
|
||||||
if (c.selectionMode == 'positive')
|
|
||||||
{
|
|
||||||
$(this).attr('checked', true);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
$(this).attr('checked', false);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
$(table).find(':checkbox[name^=selectObj]').change(function() {
|
|
||||||
updateSelection(table, table.config.container, this.value, this.checked);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
else if (table.config.select_mode == 'single')
|
|
||||||
{
|
|
||||||
$(table).find('input[name^=selectObject]:radio').each(function() {
|
|
||||||
var id = parseInt(this.value, 10);
|
|
||||||
if ($('#'+id, table.config.container).length > 0)
|
|
||||||
{
|
|
||||||
if (c.selectionMode == 'positive')
|
|
||||||
{
|
|
||||||
$(this).attr('checked', true);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
$(this).attr('checked', false);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
$(table).find('input[name^=selectObject]:radio').change(function() {
|
|
||||||
updateSelection(table, table.config.container, this.value, this.checked);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
$(table).trigger("applyWidgets");
|
$(table).trigger("applyWidgets");
|
||||||
|
|
||||||
@@ -267,6 +227,58 @@ function sprintf(format, etc) {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function applySelection(table)
|
||||||
|
{
|
||||||
|
var c = table.config;
|
||||||
|
if (c.selectionMode == 'negative')
|
||||||
|
{
|
||||||
|
$(table).find(':checkbox[name^=selectObj]').attr('checked', true);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (table.config.select_mode == 'multiple')
|
||||||
|
{
|
||||||
|
$(table).find(':checkbox[name^=selectObj]').each(function() {
|
||||||
|
var id = parseInt(this.value, 10);
|
||||||
|
if ($('#'+id, table.config.container).length > 0)
|
||||||
|
{
|
||||||
|
if (c.selectionMode == 'positive')
|
||||||
|
{
|
||||||
|
$(this).attr('checked', true);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$(this).attr('checked', false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
$(table).find(':checkbox[name^=selectObj]').change(function() {
|
||||||
|
storeSelection(table, table.config.container, this.value, this.checked);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
else if (table.config.select_mode == 'single')
|
||||||
|
{
|
||||||
|
$(table).find('input[name^=selectObject]:radio').each(function() {
|
||||||
|
var id = parseInt(this.value, 10);
|
||||||
|
if ($('#'+id, table.config.container).length > 0)
|
||||||
|
{
|
||||||
|
if (c.selectionMode == 'positive')
|
||||||
|
{
|
||||||
|
$(this).attr('checked', true);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$(this).attr('checked', false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
$(table).find('input[name^=selectObject]:radio').change(function() {
|
||||||
|
storeSelection(table, table.config.container, this.value, this.checked);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
function renderPager(table, pager)
|
function renderPager(table, pager)
|
||||||
{
|
{
|
||||||
var c = table.config;
|
var c = table.config;
|
||||||
@@ -400,9 +412,13 @@ function sprintf(format, etc) {
|
|||||||
$(table).find(':checkbox.checkAll').removeAttr('onclick').click(function() {
|
$(table).find(':checkbox.checkAll').removeAttr('onclick').click(function() {
|
||||||
return checkAll(table, pager, this.checked);
|
return checkAll(table, pager, this.checked);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
$(table).bind('load_selection', function() {
|
||||||
|
loadSelection(table, pager);
|
||||||
|
applySelection(table);
|
||||||
|
});
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
// extend plugin scope
|
// extend plugin scope
|
||||||
|
|||||||
Reference in New Issue
Block a user