Merge remote-tracking branch 'origin/rel-1.5-uzh' into development
This commit is contained in:
commit
4736b9208a
1 changed files with 15 additions and 0 deletions
|
@ -224,6 +224,9 @@ public class EntityTable<ROW extends ModelIdAware> {
|
|||
}
|
||||
this.table.addListener(SWT.Selection, event -> {
|
||||
if (this.multiselection != null && event.item != null) {
|
||||
if (event.item == null || event.item.isDisposed()) {
|
||||
return;
|
||||
}
|
||||
handleMultiSelection((TableItem) event.item);
|
||||
event.doit = false;
|
||||
}
|
||||
|
@ -527,6 +530,9 @@ public class EntityTable<ROW extends ModelIdAware> {
|
|||
|
||||
// first remove all rows if there are some
|
||||
this.table.removeAll();
|
||||
if (this.multiselection != null) {
|
||||
this.multiselection.clear();
|
||||
}
|
||||
|
||||
// get page data and create rows
|
||||
final Page<ROW> page = this.pageSupplier.newBuilder()
|
||||
|
@ -642,10 +648,19 @@ public class EntityTable<ROW extends ModelIdAware> {
|
|||
|
||||
@SuppressWarnings("unchecked")
|
||||
private ROW getRowData(final TableItem item) {
|
||||
if (item == null || item.isDisposed()) {
|
||||
log.warn("Selected item is null or disposed: {}", item);
|
||||
return null;
|
||||
}
|
||||
return (ROW) item.getData(TABLE_ROW_DATA);
|
||||
}
|
||||
|
||||
private EntityKey getEntityKey(final TableItem item) {
|
||||
if (item == null || item.isDisposed()) {
|
||||
log.warn("Selected item is null or disposed: {}", item);
|
||||
return null;
|
||||
}
|
||||
|
||||
final ROW rowData = getRowData(item);
|
||||
if (rowData instanceof Entity) {
|
||||
return ((Entity) rowData).getEntityKey();
|
||||
|
|
Loading…
Reference in a new issue