Revision 08af4f8a
Added by Cherian Mathew almost 9 years ago
src/main/java/eu/etaxonomy/cdm/vaadin/util/CdmVaadinOperation.java | ||
---|---|---|
9 | 9 |
*/ |
10 | 10 |
package eu.etaxonomy.cdm.vaadin.util; |
11 | 11 |
|
12 |
import java.util.ArrayList; |
|
13 |
import java.util.Date; |
|
14 |
import java.util.List; |
|
15 |
|
|
12 | 16 |
import org.apache.log4j.Logger; |
13 | 17 |
|
14 | 18 |
import com.vaadin.ui.UI; |
... | ... | |
27 | 31 |
private int pollInterval = -1; |
28 | 32 |
private CdmProgressComponent progressComponent; |
29 | 33 |
|
34 |
private boolean opDone = false; |
|
35 |
|
|
36 |
List<CdmChangeEvent> events = new ArrayList<CdmChangeEvent>(); |
|
37 |
|
|
38 |
private Date now = new java.util.Date(); |
|
39 |
|
|
30 | 40 |
public CdmVaadinOperation(int pollInterval, CdmProgressComponent progressComponent) { |
31 | 41 |
this.pollInterval = pollInterval; |
32 | 42 |
this.progressComponent = progressComponent; |
43 |
|
|
44 |
UI.getCurrent().setPollInterval(pollInterval); |
|
45 |
|
|
46 |
// comment out below for debugging |
|
47 |
// logger.warn(new Timestamp(now.getTime()) + " : set polling interval to " + pollInterval); |
|
33 | 48 |
// UI.getCurrent().addPollListener(new UIEvents.PollListener() { |
34 | 49 |
// @Override |
35 | 50 |
// public void poll(UIEvents.PollEvent event) { |
36 |
// logger.warn("polling");
|
|
51 |
// logger.warn( new Timestamp(now.getTime()) + " : polling");
|
|
37 | 52 |
// } |
38 | 53 |
// }); |
39 | 54 |
} |
... | ... | |
42 | 57 |
|
43 | 58 |
} |
44 | 59 |
|
60 |
|
|
61 |
|
|
45 | 62 |
public void setProgress(final String progressText) { |
46 | 63 |
if(progressComponent == null) { |
47 | 64 |
return; |
... | ... | |
58 | 75 |
progressComponent.setProgress(progressText); |
59 | 76 |
} |
60 | 77 |
|
78 |
|
|
61 | 79 |
} |
62 | 80 |
|
63 | 81 |
public void setProgress(final String progressText, final float progress) { |
... | ... | |
98 | 116 |
@Override |
99 | 117 |
public void run() { |
100 | 118 |
|
101 |
UI.getCurrent().setPollInterval(pollInterval); |
|
102 |
//logger.warn("set polling interval to " + UI.getCurrent().getPollInterval()); |
|
103 |
|
|
104 |
|
|
105 | 119 |
final boolean success = execute(); |
106 |
//logger.warn("ran execute");
|
|
120 |
//logger.warn(new Timestamp(now.getTime()) + " : ran execute");
|
|
107 | 121 |
endProgress(); |
122 |
|
|
108 | 123 |
if(isAsync()) { |
109 | 124 |
UI.getCurrent().access(new Runnable() { |
110 | 125 |
@Override |
111 | 126 |
public void run() { |
112 | 127 |
try { |
128 |
if(success) { |
|
129 |
fireDelayedEvents(); |
|
130 |
} |
|
113 | 131 |
postOpUIUpdate(success); |
114 |
//logger.warn("ran postOpUIUpdate ");
|
|
132 |
//logger.warn(new Timestamp(now.getTime()) + " : ran postOpUIUpdate ");
|
|
115 | 133 |
} finally { |
116 | 134 |
UI.getCurrent().setPollInterval(-1); |
117 |
//logger.warn("set polling interval to " + UI.getCurrent().getPollInterval()); |
|
135 |
opDone = true; |
|
136 |
//logger.warn(new Timestamp(now.getTime()) + " : switched off pollling"); |
|
118 | 137 |
} |
119 | 138 |
} |
120 | 139 |
}); |
... | ... | |
128 | 147 |
|
129 | 148 |
public void postOpUIUpdate(boolean isOpSuccess) {} |
130 | 149 |
|
131 |
public void fireEvent(CdmChangeEvent event) { |
|
132 |
if(isAsync()) { |
|
133 |
CdmVaadinSessionUtilities.getCurrentCdmDataChangeService().fireChangeEvent(event, true); |
|
134 |
} else { |
|
135 |
CdmVaadinSessionUtilities.getCurrentCdmDataChangeService().fireChangeEvent(event, false); |
|
150 |
public void fireEvent(CdmChangeEvent event, boolean async) { |
|
151 |
CdmVaadinSessionUtilities.getCurrentCdmDataChangeService().fireChangeEvent(event, async); |
|
152 |
} |
|
153 |
|
|
154 |
public void registerDelayedEvent(CdmChangeEvent event) { |
|
155 |
events.add(event); |
|
156 |
} |
|
157 |
|
|
158 |
private void fireDelayedEvents() { |
|
159 |
for(CdmChangeEvent event : events) { |
|
160 |
fireEvent(event, false); |
|
136 | 161 |
} |
162 |
events.clear(); |
|
137 | 163 |
} |
138 | 164 |
|
139 | 165 |
public boolean isAsync() { |
Also available in: Unified diff
ConceptRelationshipComposite: added enabling / disabling of edit / delete buttons and firing event when edit concept relationship dialog is opened
EditConceptRelationshipComposite : fixed problems with async calls , adapted to updated operation class, added show in dialog method
NewTaxonBaseComposite : adapted to updated operation class
StatusComposite : added methods to update taxa table ui
D3ConceptRelationshipTree : added possibility to display one to one relationships
EditConceptRelationshipPresenter, EditConceptRelationshipPresenterTest : added method to get data to setup composite
CdmBaseUI, CdmVaadinSessionUtilities : using new basic events
CdmSpringContextHelper : fixed connection bug by closing connection after getting database metadata
CdmVaadinOperation : fixed problems with async calls
ConceptRelationshipView : setup ui changes for status composite depending on whether it is a primary of secondary composite
d3.conceptrelationshiptree_connector.js : added selected node capability