diff options
author | Matti Tahvonen <matti.tahvonen@itmill.com> | 2011-04-12 07:48:20 +0000 |
---|---|---|
committer | Matti Tahvonen <matti.tahvonen@itmill.com> | 2011-04-12 07:48:20 +0000 |
commit | a6197b4df19e4c93fec76821a9b627b4be0d25ca (patch) | |
tree | 14f0fca5aac2a944f619012e58ad734aa8691f9c /src | |
parent | 54f73079ed9ee35f78b9f8fd481d4e2dcef9f722 (diff) | |
download | vaadin-framework-a6197b4df19e4c93fec76821a9b627b4be0d25ca.tar.gz vaadin-framework-a6197b4df19e4c93fec76821a9b627b4be0d25ca.zip |
merged [18197],[18217] from 6.5 branch
svn changeset:18218/svn branch:6.6
Diffstat (limited to 'src')
-rw-r--r-- | src/com/vaadin/terminal/gwt/client/ui/VScrollTable.java | 4 | ||||
-rw-r--r-- | src/com/vaadin/ui/Table.java | 75 |
2 files changed, 76 insertions, 3 deletions
diff --git a/src/com/vaadin/terminal/gwt/client/ui/VScrollTable.java b/src/com/vaadin/terminal/gwt/client/ui/VScrollTable.java index c16741523d..8efd582fe6 100644 --- a/src/com/vaadin/terminal/gwt/client/ui/VScrollTable.java +++ b/src/com/vaadin/terminal/gwt/client/ui/VScrollTable.java @@ -107,6 +107,7 @@ public class VScrollTable extends FlowPanel implements Table, ScrollHandler, public static final String HEADER_CLICK_EVENT_ID = "handleHeaderClick"; public static final String FOOTER_CLICK_EVENT_ID = "handleFooterClick"; public static final String COLUMN_RESIZE_EVENT_ID = "columnResize"; + public static final String COLUMN_REORDER_EVENT_ID = "columnReorder"; private static final double CACHE_RATE_DEFAULT = 2; @@ -1329,6 +1330,9 @@ public class VScrollTable extends FlowPanel implements Table, ScrollHandler, } } client.updateVariable(paintableId, "columnorder", columnOrder, false); + if (client.hasEventListeners(this, COLUMN_REORDER_EVENT_ID)) { + client.sendPendingVariableChanges(); + } } @Override diff --git a/src/com/vaadin/ui/Table.java b/src/com/vaadin/ui/Table.java index 89f50f01ab..290aa1cf09 100644 --- a/src/com/vaadin/ui/Table.java +++ b/src/com/vaadin/ui/Table.java @@ -2117,6 +2117,9 @@ public class Table extends AbstractSelect implements Action.Container, idsTemp[i] = columnIdMap.get(ids[i].toString()); } setColumnOrder(idsTemp); + if (hasListeners(ColumnReorderEvent.class)) { + fireEvent(new ColumnReorderEvent(this)); + } } catch (final Exception e) { // FIXME: Handle exception logger.log(Level.FINER, @@ -3850,7 +3853,7 @@ public class Table extends AbstractSelect implements Action.Container, new Class[] { HeaderClickEvent.class }); } catch (final java.lang.NoSuchMethodException e) { // This should never happen - throw new java.lang.RuntimeException(); + throw new java.lang.RuntimeException(e); } } @@ -3890,7 +3893,7 @@ public class Table extends AbstractSelect implements Action.Container, new Class[] { FooterClickEvent.class }); } catch (final java.lang.NoSuchMethodException e) { // This should never happen - throw new java.lang.RuntimeException(); + throw new java.lang.RuntimeException(e); } } @@ -4081,7 +4084,7 @@ public class Table extends AbstractSelect implements Action.Container, new Class[] { ColumnResizeEvent.class }); } catch (final java.lang.NoSuchMethodException e) { // This should never happen - throw new java.lang.RuntimeException(); + throw new java.lang.RuntimeException(e); } } @@ -4176,4 +4179,70 @@ public class Table extends AbstractSelect implements Action.Container, removeListener(VScrollTable.COLUMN_RESIZE_EVENT_ID, ColumnResizeEvent.class, listener); } + + /** + * This event is fired when a columns are reordered by the end user user. + */ + public static class ColumnReorderEvent extends Component.Event { + public static final Method METHOD; + + static { + try { + METHOD = ColumnReorderListener.class.getDeclaredMethod( + "columnReorder", + new Class[] { ColumnReorderEvent.class }); + } catch (final java.lang.NoSuchMethodException e) { + // This should never happen + throw new java.lang.RuntimeException(e); + } + } + + /** + * Constructor + * + * @param source + * The source of the event + */ + public ColumnReorderEvent(Component source) { + super(source); + } + + } + + /** + * Interface for listening to column reorder events. + */ + public interface ColumnReorderListener extends Serializable { + + /** + * This method is triggered when the column has been reordered + * + * @param event + */ + public void columnReorder(ColumnReorderEvent event); + } + + /** + * Adds a column reorder listener to the Table. A column reorder listener is + * called when a user reorders columns. + * + * @param listener + * The listener to attach to the Table + */ + public void addListener(ColumnReorderListener listener) { + addListener(VScrollTable.COLUMN_REORDER_EVENT_ID, + ColumnReorderEvent.class, listener, ColumnReorderEvent.METHOD); + } + + /** + * Removes a column reorder listener from the Table. + * + * @param listener + * The listener to remove + */ + public void removeListener(ColumnReorderListener listener) { + removeListener(VScrollTable.COLUMN_REORDER_EVENT_ID, + ColumnReorderEvent.class, listener); + } + } |