Merge "Add a Row check to enable/disable checkbox on ajax updates."
This commit is contained in:
commit
f960cdf731
@ -561,6 +561,12 @@ class Row(html.HTMLElement):
|
|||||||
"obj_id": self.table.get_object_id(self.datum)})
|
"obj_id": self.table.get_object_id(self.datum)})
|
||||||
return "%s?%s" % (table_url, params)
|
return "%s?%s" % (table_url, params)
|
||||||
|
|
||||||
|
def can_be_selected(self, datum):
|
||||||
|
"""By default if multiselect enabled return True. You can remove the
|
||||||
|
checkbox after an ajax update here if required.
|
||||||
|
"""
|
||||||
|
return True
|
||||||
|
|
||||||
def get_data(self, request, obj_id):
|
def get_data(self, request, obj_id):
|
||||||
"""Fetches the updated data for the row based on the object id
|
"""Fetches the updated data for the row based on the object id
|
||||||
passed in. Must be implemented by a subclass to allow AJAX updating.
|
passed in. Must be implemented by a subclass to allow AJAX updating.
|
||||||
@ -594,11 +600,13 @@ class Cell(html.HTMLElement):
|
|||||||
"""Fetches the data to be displayed in this cell."""
|
"""Fetches the data to be displayed in this cell."""
|
||||||
table = row.table
|
table = row.table
|
||||||
if column.auto == "multi_select":
|
if column.auto == "multi_select":
|
||||||
widget = forms.CheckboxInput(check_test=lambda value: False)
|
data = ""
|
||||||
# Convert value to string to avoid accidental type conversion
|
if row.can_be_selected(datum):
|
||||||
data = widget.render('object_ids',
|
widget = forms.CheckboxInput(check_test=lambda value: False)
|
||||||
unicode(table.get_object_id(datum)),
|
# Convert value to string to avoid accidental type conversion
|
||||||
{'class': 'table-row-multi-select'})
|
data = widget.render('object_ids',
|
||||||
|
unicode(table.get_object_id(datum)),
|
||||||
|
{'class': 'table-row-multi-select'})
|
||||||
table._data_cache[column][table.get_object_id(datum)] = data
|
table._data_cache[column][table.get_object_id(datum)] = data
|
||||||
elif column.auto == "form_field":
|
elif column.auto == "form_field":
|
||||||
widget = column.form_field
|
widget = column.form_field
|
||||||
|
@ -65,6 +65,11 @@ TEST_DATA_5 = (
|
|||||||
'down', 'optional_1'),
|
'down', 'optional_1'),
|
||||||
)
|
)
|
||||||
|
|
||||||
|
TEST_DATA_6 = (
|
||||||
|
FakeObject('1', 'object_1', 'DELETED', 'down'),
|
||||||
|
FakeObject('2', 'object_2', 'CREATED', 'up'),
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
class MyLinkAction(tables.LinkAction):
|
class MyLinkAction(tables.LinkAction):
|
||||||
name = "login"
|
name = "login"
|
||||||
@ -95,6 +100,13 @@ class MyColumn(tables.Column):
|
|||||||
pass
|
pass
|
||||||
|
|
||||||
|
|
||||||
|
class MyRowSelectable(tables.Row):
|
||||||
|
ajax = True
|
||||||
|
|
||||||
|
def can_be_selected(self, datum):
|
||||||
|
return datum.value != 'DELETED'
|
||||||
|
|
||||||
|
|
||||||
class MyRow(tables.Row):
|
class MyRow(tables.Row):
|
||||||
ajax = True
|
ajax = True
|
||||||
|
|
||||||
@ -198,6 +210,15 @@ class MyTable(tables.DataTable):
|
|||||||
row_actions = (MyAction, MyLinkAction, MyBatchAction, MyToggleAction)
|
row_actions = (MyAction, MyLinkAction, MyBatchAction, MyToggleAction)
|
||||||
|
|
||||||
|
|
||||||
|
class MyTableSelectable(MyTable):
|
||||||
|
class Meta:
|
||||||
|
name = "my_table"
|
||||||
|
columns = ('id', 'name', 'value', 'status')
|
||||||
|
row_class = MyRowSelectable
|
||||||
|
status_columns = ["status"]
|
||||||
|
multi_select = True
|
||||||
|
|
||||||
|
|
||||||
class MyTableNotAllowedInlineEdit(MyTable):
|
class MyTableNotAllowedInlineEdit(MyTable):
|
||||||
name = tables.Column(get_name,
|
name = tables.Column(get_name,
|
||||||
verbose_name="Verbose Name",
|
verbose_name="Verbose Name",
|
||||||
@ -1013,6 +1034,63 @@ class DataTableTests(test.TestCase):
|
|||||||
self.assertEqual(list(req._messages)[0].message,
|
self.assertEqual(list(req._messages)[0].message,
|
||||||
u"Downed Item: N/A")
|
u"Downed Item: N/A")
|
||||||
|
|
||||||
|
def test_table_column_can_be_selected(self):
|
||||||
|
self.table = MyTableSelectable(self.request, TEST_DATA_6)
|
||||||
|
#non selectable row
|
||||||
|
row = self.table.get_rows()[0]
|
||||||
|
#selectable
|
||||||
|
row1 = self.table.get_rows()[1]
|
||||||
|
|
||||||
|
id_col = self.table.columns['id']
|
||||||
|
name_col = self.table.columns['name']
|
||||||
|
value_col = self.table.columns['value']
|
||||||
|
# transform
|
||||||
|
self.assertEqual(row.cells['id'].data, '1') # Standard attr access
|
||||||
|
self.assertEqual(row.cells['name'].data, 'custom object_1') # Callable
|
||||||
|
# name and verbose_name
|
||||||
|
self.assertEqual(unicode(id_col), "Id")
|
||||||
|
self.assertEqual(unicode(name_col), "Verbose Name")
|
||||||
|
self.assertIn("sortable", name_col.get_final_attrs().get('class', ""))
|
||||||
|
# hidden
|
||||||
|
self.assertEqual(id_col.hidden, True)
|
||||||
|
self.assertIn("hide", id_col.get_final_attrs().get('class', ""))
|
||||||
|
self.assertEqual(name_col.hidden, False)
|
||||||
|
self.assertNotIn("hide", name_col.get_final_attrs().get('class', ""))
|
||||||
|
# link, link_classes and get_link_url
|
||||||
|
self.assertIn('href="http://example.com/"', row.cells['value'].value)
|
||||||
|
self.assertIn('class="link-modal"', row.cells['value'].value)
|
||||||
|
self.assertIn('href="/auth/login/"', row.cells['status'].value)
|
||||||
|
# classes
|
||||||
|
self.assertEqual(value_col.get_final_attrs().get('class', ""),
|
||||||
|
"green blue sortable anchor normal_column")
|
||||||
|
|
||||||
|
self.assertQuerysetEqual(row.get_cells(),
|
||||||
|
['<Cell: multi_select, my_table__row__1>',
|
||||||
|
'<Cell: id, my_table__row__1>',
|
||||||
|
'<Cell: name, my_table__row__1>',
|
||||||
|
'<Cell: value, my_table__row__1>',
|
||||||
|
'<Cell: status, my_table__row__1>',
|
||||||
|
])
|
||||||
|
#can_be_selected = False
|
||||||
|
self.assertTrue(row.get_cells()[0].data == "")
|
||||||
|
#can_be_selected = True
|
||||||
|
self.assertIn('checkbox', row1.get_cells()[0].data)
|
||||||
|
#status
|
||||||
|
cell_status = row.cells['status'].status
|
||||||
|
self.assertEqual(row.cells['status'].get_status_class(cell_status),
|
||||||
|
'status_down')
|
||||||
|
# status_choices
|
||||||
|
id_col.status = True
|
||||||
|
id_col.status_choices = (('1', False), ('2', True))
|
||||||
|
cell_status = row.cells['id'].status
|
||||||
|
self.assertEqual(cell_status, False)
|
||||||
|
self.assertEqual(row.cells['id'].get_status_class(cell_status),
|
||||||
|
'status_down')
|
||||||
|
# Ensure data is not cached on the column across table instances
|
||||||
|
self.table = MyTable(self.request, TEST_DATA_6)
|
||||||
|
row = self.table.get_rows()[0]
|
||||||
|
self.assertTrue("down" in row.cells['status'].value)
|
||||||
|
|
||||||
|
|
||||||
class SingleTableView(table_views.DataTableView):
|
class SingleTableView(table_views.DataTableView):
|
||||||
table_class = MyTable
|
table_class = MyTable
|
||||||
|
Loading…
Reference in New Issue
Block a user