Revision d43de9c0
Added by Katja Luther over 10 years ago
eu.etaxonomy.taxeditor.navigation/src/main/java/eu/etaxonomy/taxeditor/navigation/navigator/TaxonNavigatorDataChangeBehavior.java | ||
---|---|---|
1 | 1 |
/** |
2 | 2 |
* Copyright (C) 2007 EDIT |
3 |
* European Distributed Institute of Taxonomy |
|
3 |
* European Distributed Institute of Taxonomy
|
|
4 | 4 |
* http://www.e-taxonomy.eu |
5 |
* |
|
5 |
*
|
|
6 | 6 |
* The contents of this file are subject to the Mozilla Public License Version 1.1 |
7 | 7 |
* See LICENSE.TXT at the top of this package for the full license terms. |
8 | 8 |
*/ |
... | ... | |
38 | 38 |
* @created 01.04.2009 |
39 | 39 |
* @version 1.0 |
40 | 40 |
*/ |
41 |
public class TaxonNavigatorDataChangeBehavior extends AbstractDataChangeBehaviour implements |
|
41 |
public class TaxonNavigatorDataChangeBehavior extends AbstractDataChangeBehaviour implements
|
|
42 | 42 |
IDataChangeBehavior { |
43 | 43 |
|
44 | 44 |
private TaxonNavigator source; |
45 | 45 |
|
46 | 46 |
private Set<CdmBase> staleObjects; |
47 |
|
|
47 |
|
|
48 | 48 |
/** |
49 | 49 |
* <p>Constructor for TaxonNavigatorDataChangeBehavior.</p> |
50 | 50 |
* |
... | ... | |
53 | 53 |
public TaxonNavigatorDataChangeBehavior(TaxonNavigator taxonNavigator) { |
54 | 54 |
source = taxonNavigator; |
55 | 55 |
} |
56 |
|
|
56 |
|
|
57 | 57 |
/* (non-Javadoc) |
58 | 58 |
* @see eu.etaxonomy.taxeditor.store.model.IDataChangeBehavior#isRelevant(java.lang.Object, eu.etaxonomy.cdm.persistence.hibernate.CdmCrudEvent) |
59 | 59 |
*/ |
... | ... | |
64 | 64 |
* @return a boolean. |
65 | 65 |
*/ |
66 | 66 |
public boolean isRelevant(CdmDataChangeMap events) { |
67 |
|
|
67 |
|
|
68 | 68 |
// TODO react only on insert/update/delete of taxon and synonym objects |
69 | 69 |
// and on update of name objects |
70 | 70 |
boolean relevant = false; |
71 | 71 |
staleObjects = new HashSet<CdmBase>(); |
72 |
|
|
72 |
|
|
73 | 73 |
for(CdmDataChangeEvent event : events.getAllEvents()){ |
74 | 74 |
EventType eventType = event.getEventType(); |
75 | 75 |
CdmBase eventEntity = event.getEntity(); |
76 |
|
|
76 |
|
|
77 | 77 |
// all tree node changes are relevant |
78 |
if((eventType == EventType.INSERT || eventType == EventType.DELETE || eventType == EventType.UPDATE) |
|
78 |
if((eventType == EventType.INSERT || eventType == EventType.DELETE || eventType == EventType.UPDATE)
|
|
79 | 79 |
&& event.getEntity() instanceof ITaxonTreeNode){ |
80 | 80 |
return true; |
81 | 81 |
} |
82 |
|
|
82 |
|
|
83 | 83 |
// name updates of the accepted taxon of open editors are relevant |
84 |
if(eventType == EventType.UPDATE){ |
|
84 |
if(eventType == EventType.UPDATE && event.getEntity() instanceof TaxonNameBase){
|
|
85 | 85 |
TaxonNameBase name = null; |
86 | 86 |
if(eventEntity instanceof TaxonNameBase){ |
87 | 87 |
name = (TaxonNameBase) eventEntity; |
... | ... | |
90 | 90 |
}else{ |
91 | 91 |
continue; |
92 | 92 |
} |
93 |
|
|
93 |
|
|
94 | 94 |
Set<IEditorPart> openEditors = NavigationUtil.getOpenEditors(); |
95 |
for(IEditorPart editor : openEditors){ |
|
96 |
|
|
95 |
/*for(IEditorPart editor : openEditors){
|
|
96 |
|
|
97 | 97 |
if(name.equals(((TaxonEditorInput) editor.getEditorInput()).getTaxon().getName())){ |
98 | 98 |
return true; |
99 | 99 |
} |
100 |
}*/ |
|
101 |
} |
|
102 |
if (eventType == EventType.DELETE){ |
|
103 |
return true; |
|
104 |
} |
|
105 |
|
|
106 |
if(eventType == EventType.UPDATE && event.getEntity() instanceof Taxon){ |
|
107 |
TaxonNameBase name = null; |
|
108 |
if(eventEntity instanceof Taxon){ |
|
109 |
name = ((Taxon) eventEntity).getName(); |
|
110 |
}else{ |
|
111 |
continue; |
|
100 | 112 |
} |
113 |
|
|
114 |
Set<IEditorPart> openEditors = NavigationUtil.getOpenEditors(); |
|
115 |
/*for(IEditorPart editor : openEditors){ |
|
116 |
|
|
117 |
if(name.equals(((TaxonEditorInput) editor.getEditorInput()).getTaxon().getName())){ |
|
118 |
return true; |
|
119 |
} |
|
120 |
}*/ |
|
101 | 121 |
} |
102 |
|
|
103 |
|
|
122 |
|
|
104 | 123 |
// if(eventType == EventType.UPDATE){ |
105 | 124 |
// relevant = true; |
106 | 125 |
// CdmBase entity = event.getEntity(); |
... | ... | |
111 | 130 |
// } |
112 | 131 |
// } |
113 | 132 |
} |
114 |
|
|
133 |
|
|
115 | 134 |
return false; |
116 |
|
|
135 |
|
|
117 | 136 |
// @deprecated |
118 | 137 |
// react on everything except load |
119 | 138 |
// if(events.sizeByEventType(EventType.INSERT) > 0){ |
... | ... | |
132 | 151 |
*/ |
133 | 152 |
/** {@inheritDoc} */ |
134 | 153 |
@Override |
135 |
public void reactOnDataChange(CdmDataChangeMap events) {
|
|
154 |
public void reactOnDataChange(CdmDataChangeMap events) {
|
|
136 | 155 |
if(isRelevant(events)){ |
137 | 156 |
|
138 | 157 |
final Display display = Display.getCurrent(); |
139 | 158 |
Job job = new Job("Updating Taxon Navigator") { |
140 |
|
|
159 |
|
|
141 | 160 |
@Override |
142 | 161 |
protected IStatus run(IProgressMonitor monitor) { |
143 | 162 |
monitor.beginTask("Updating Taxon Navigator", 3); |
144 | 163 |
monitor.worked(1); |
145 |
|
|
164 |
|
|
146 | 165 |
// clear the session completely |
147 | 166 |
monitor.subTask("Clearing Taxon Navigators session"); |
167 |
System.out.println("Clearing Taxon Navigators session"); |
|
148 | 168 |
display.asyncExec(new Runnable() { |
149 | 169 |
@Override |
150 |
public void run() {
|
|
170 |
public void run() {
|
|
151 | 171 |
source.getConversationHolder().clear(); |
152 | 172 |
} |
153 |
}); |
|
154 |
// FIXME completely clearing the session is a brute force approach. |
|
173 |
});
|
|
174 |
// FIXME completely clearing the session is a brute force approach.
|
|
155 | 175 |
// It would be much more elegant to clear only those elements that have been changed. |
156 | 176 |
// I could not get that to work but we should consider workin on this because we might |
157 | 177 |
// run into serious performance issues, especially when it comes to large trees |
... | ... | |
159 | 179 |
// at least, we moved this to a job so it can run in a background thred |
160 | 180 |
// seems to improve the situation but not sure if final solution |
161 | 181 |
monitor.worked(1); |
162 |
|
|
182 |
|
|
163 | 183 |
monitor.subTask("Refreshing viewer"); |
164 |
|
|
184 |
|
|
165 | 185 |
display.asyncExec(new Runnable() { |
166 | 186 |
@Override |
167 |
public void run() {
|
|
187 |
public void run() {
|
|
168 | 188 |
source.refresh(); |
169 | 189 |
} |
170 | 190 |
}); |
171 |
|
|
172 |
|
|
173 |
|
|
191 |
|
|
192 |
|
|
193 |
|
|
174 | 194 |
monitor.worked(1); |
175 | 195 |
monitor.done(); |
176 | 196 |
return Status.OK_STATUS; |
177 | 197 |
} |
178 | 198 |
}; |
179 |
|
|
199 |
|
|
180 | 200 |
job.setPriority(Job.SHORT); |
181 | 201 |
job.schedule(); |
182 |
|
|
202 |
|
|
183 | 203 |
} |
184 | 204 |
} |
185 | 205 |
} |
Also available in: Unified diff