Revision d3cfcce0
Added by Katja Luther over 1 year ago
eu.etaxonomy.taxeditor.editor/src/main/java/eu/etaxonomy/taxeditor/editor/e4/TaxonEditorInputDataChangeBehaviourE4_.java | ||
---|---|---|
1 |
/** |
|
2 |
* Copyright (C) 2007 EDIT |
|
3 |
* European Distributed Institute of Taxonomy |
|
4 |
* http://www.e-taxonomy.eu |
|
5 |
* |
|
6 |
* The contents of this file are subject to the Mozilla Public License Version 1.1 |
|
7 |
* See LICENSE.TXT at the top of this package for the full license terms. |
|
8 |
*/ |
|
9 |
|
|
10 |
package eu.etaxonomy.taxeditor.editor.e4; |
|
11 |
|
|
12 |
import eu.etaxonomy.cdm.persistence.hibernate.CdmDataChangeMap; |
|
13 |
import eu.etaxonomy.taxeditor.model.AbstractDataChangeBehaviour_; |
|
14 |
|
|
15 |
/** |
|
16 |
* @author pplitzner |
|
17 |
* @date Aug 24, 2017 |
|
18 |
*/ |
|
19 |
public class TaxonEditorInputDataChangeBehaviourE4_ extends |
|
20 |
AbstractDataChangeBehaviour_ { |
|
21 |
|
|
22 |
private TaxonEditorInputE4 source; |
|
23 |
|
|
24 |
public TaxonEditorInputDataChangeBehaviourE4_(TaxonEditorInputE4 taxonEditorInput) { |
|
25 |
source = taxonEditorInput; |
|
26 |
} |
|
27 |
|
|
28 |
@Override |
|
29 |
public void reactOnDataChange(CdmDataChangeMap events) { |
|
30 |
//source.update(events); |
|
31 |
|
|
32 |
} |
|
33 |
} |
eu.etaxonomy.taxeditor.editor/src/main/java/eu/etaxonomy/taxeditor/editor/key/e4/KeyEditorDataChangeBehaviourE4_.java | ||
---|---|---|
1 |
/** |
|
2 |
* Copyright (C) 2007 EDIT |
|
3 |
* European Distributed Institute of Taxonomy |
|
4 |
* http://www.e-taxonomy.eu |
|
5 |
* |
|
6 |
* The contents of this file are subject to the Mozilla Public License Version 1.1 |
|
7 |
* See LICENSE.TXT at the top of this package for the full license terms. |
|
8 |
*/ |
|
9 |
|
|
10 |
package eu.etaxonomy.taxeditor.editor.key.e4; |
|
11 |
|
|
12 |
import java.util.Vector; |
|
13 |
|
|
14 |
import eu.etaxonomy.cdm.model.description.PolytomousKey; |
|
15 |
import eu.etaxonomy.cdm.persistence.hibernate.CdmDataChangeEvent; |
|
16 |
import eu.etaxonomy.cdm.persistence.hibernate.CdmDataChangeEvent.EventType; |
|
17 |
import eu.etaxonomy.cdm.persistence.hibernate.CdmDataChangeMap; |
|
18 |
import eu.etaxonomy.taxeditor.editor.key.polytomous.PolytomousKeyEditorInput; |
|
19 |
import eu.etaxonomy.taxeditor.editor.key.polytomous.e4.PolytomousKeyListEditorE4; |
|
20 |
import eu.etaxonomy.taxeditor.model.AbstractDataChangeBehaviour_; |
|
21 |
|
|
22 |
/** |
|
23 |
* @author n.hoffmann |
|
24 |
* @created May 5, 2011 |
|
25 |
*/ |
|
26 |
public class KeyEditorDataChangeBehaviourE4_ extends AbstractDataChangeBehaviour_ { |
|
27 |
|
|
28 |
private final PolytomousKeyListEditorE4 source; |
|
29 |
private PolytomousKeyEditorInput input; |
|
30 |
|
|
31 |
public KeyEditorDataChangeBehaviourE4_(PolytomousKeyListEditorE4 keyEditor) { |
|
32 |
source = keyEditor; |
|
33 |
} |
|
34 |
|
|
35 |
@Override |
|
36 |
public void reactOnDataChange(CdmDataChangeMap changeEvents) { |
|
37 |
input = source.getEditorInput(); |
|
38 |
|
|
39 |
if(changeEvents.sizeByEventType(EventType.UPDATE) > 0){ |
|
40 |
reactOnUpdate(changeEvents.getEvents(EventType.UPDATE)); |
|
41 |
} |
|
42 |
} |
|
43 |
|
|
44 |
@Override |
|
45 |
public void reactOnUpdate(Vector<CdmDataChangeEvent> events){ |
|
46 |
|
|
47 |
for(CdmDataChangeEvent event : events){ |
|
48 |
|
|
49 |
// update editor title |
|
50 |
if(event.getEntity() instanceof PolytomousKey){ |
|
51 |
if(input.getKey().equals(event.getEntity())){ |
|
52 |
// set the name of the editor window |
|
53 |
source.setPartName(); |
|
54 |
} |
|
55 |
} |
|
56 |
} |
|
57 |
} |
|
58 |
} |
eu.etaxonomy.taxeditor.navigation/src/main/java/eu/etaxonomy/taxeditor/navigation/key/polytomous/e4/PolytomousKeyViewPartDataChangeBehaviorE4_.java | ||
---|---|---|
1 |
/** |
|
2 |
* Copyright (C) 2007 EDIT |
|
3 |
* European Distributed Institute of Taxonomy |
|
4 |
* http://www.e-taxonomy.eu |
|
5 |
* |
|
6 |
* The contents of this file are subject to the Mozilla Public License Version 1.1 |
|
7 |
* See LICENSE.TXT at the top of this package for the full license terms. |
|
8 |
*/ |
|
9 |
|
|
10 |
package eu.etaxonomy.taxeditor.navigation.key.polytomous.e4; |
|
11 |
|
|
12 |
import org.eclipse.core.runtime.IProgressMonitor; |
|
13 |
import org.eclipse.core.runtime.IStatus; |
|
14 |
import org.eclipse.core.runtime.Status; |
|
15 |
import org.eclipse.core.runtime.jobs.Job; |
|
16 |
import org.eclipse.swt.widgets.Display; |
|
17 |
|
|
18 |
import eu.etaxonomy.cdm.model.common.CdmBase; |
|
19 |
import eu.etaxonomy.cdm.model.description.PolytomousKey; |
|
20 |
import eu.etaxonomy.cdm.persistence.hibernate.CdmDataChangeEvent; |
|
21 |
import eu.etaxonomy.cdm.persistence.hibernate.CdmDataChangeEvent.EventType; |
|
22 |
import eu.etaxonomy.cdm.persistence.hibernate.CdmDataChangeMap; |
|
23 |
import eu.etaxonomy.taxeditor.model.AbstractDataChangeBehaviour_; |
|
24 |
import eu.etaxonomy.taxeditor.navigation.l10n.Messages; |
|
25 |
|
|
26 |
/** |
|
27 |
* |
|
28 |
* @author pplitzner |
|
29 |
* @since Sep 28, 2017 |
|
30 |
* |
|
31 |
*/ |
|
32 |
public class PolytomousKeyViewPartDataChangeBehaviorE4_ extends |
|
33 |
AbstractDataChangeBehaviour_ { |
|
34 |
|
|
35 |
private static final String UPDATING_POLYTOMOUS_KEY_VIEWER = Messages.PolytomousKeyViewPartDataChangeBehavior_UPDATE; |
|
36 |
private final PolytomousKeyViewPartE4 source; |
|
37 |
|
|
38 |
public PolytomousKeyViewPartDataChangeBehaviorE4_( |
|
39 |
PolytomousKeyViewPartE4 polytomousKeyViewPart) { |
|
40 |
source = polytomousKeyViewPart; |
|
41 |
} |
|
42 |
|
|
43 |
@Override |
|
44 |
public void reactOnDataChange(CdmDataChangeMap changeEvents) { |
|
45 |
if(isRelevant(changeEvents)){ |
|
46 |
final Display display = Display.getCurrent(); |
|
47 |
Job job = new Job(UPDATING_POLYTOMOUS_KEY_VIEWER) { |
|
48 |
|
|
49 |
@Override |
|
50 |
protected IStatus run(IProgressMonitor monitor) { |
|
51 |
monitor.beginTask(UPDATING_POLYTOMOUS_KEY_VIEWER, 3); |
|
52 |
monitor.worked(1); |
|
53 |
|
|
54 |
// clear the session completely |
|
55 |
monitor.subTask(Messages.PolytomousKeyViewPartDataChangeBehavior_CLEAR); |
|
56 |
display.asyncExec(new Runnable() { |
|
57 |
@Override |
|
58 |
public void run() { |
|
59 |
// source.getConversationHolder().clear(); |
|
60 |
} |
|
61 |
}); |
|
62 |
// FIXME completely clearing the session is a brute force approach. |
|
63 |
// It would be much more elegant to clear only those elements that have been changed. |
|
64 |
// I could not get that to work but we should consider workin on this because we might |
|
65 |
// run into serious performance issues, especially when it comes to large trees |
|
66 |
// |
|
67 |
// at least, we moved this to a job so it can run in a background thred |
|
68 |
// seems to improve the situation but not sure if final solution |
|
69 |
monitor.worked(1); |
|
70 |
|
|
71 |
monitor.subTask(Messages.PolytomousKeyViewPartDataChangeBehavior_REFRESH); |
|
72 |
|
|
73 |
display.asyncExec(new Runnable() { |
|
74 |
@Override |
|
75 |
public void run() { |
|
76 |
source.refresh(); |
|
77 |
} |
|
78 |
}); |
|
79 |
|
|
80 |
|
|
81 |
|
|
82 |
monitor.worked(1); |
|
83 |
monitor.done(); |
|
84 |
return Status.OK_STATUS; |
|
85 |
} |
|
86 |
}; |
|
87 |
|
|
88 |
job.setPriority(Job.SHORT); |
|
89 |
job.schedule(); |
|
90 |
|
|
91 |
} |
|
92 |
} |
|
93 |
|
|
94 |
private boolean isRelevant(CdmDataChangeMap changeEvents) { |
|
95 |
for(CdmDataChangeEvent event : changeEvents.getAllEvents()){ |
|
96 |
EventType eventType = event.getEventType(); |
|
97 |
CdmBase eventEntity = event.getEntity(); |
|
98 |
|
|
99 |
// all poyltomous key changes are relevant |
|
100 |
if((eventType == EventType.INSERT || eventType == EventType.DELETE || eventType == EventType.UPDATE) |
|
101 |
&& eventEntity instanceof PolytomousKey){ |
|
102 |
return true; |
|
103 |
} |
|
104 |
} |
|
105 |
return false; |
|
106 |
} |
|
107 |
} |
eu.etaxonomy.taxeditor.navigation/src/main/java/eu/etaxonomy/taxeditor/navigation/navigator/e4/TaxonNavigatorDataChangeBehaviorE4_.java | ||
---|---|---|
1 |
/** |
|
2 |
* Copyright (C) 2007 EDIT |
|
3 |
* European Distributed Institute of Taxonomy |
|
4 |
* http://www.e-taxonomy.eu |
|
5 |
* |
|
6 |
* The contents of this file are subject to the Mozilla Public License Version 1.1 |
|
7 |
* See LICENSE.TXT at the top of this package for the full license terms. |
|
8 |
*/ |
|
9 |
|
|
10 |
package eu.etaxonomy.taxeditor.navigation.navigator.e4; |
|
11 |
|
|
12 |
import java.util.HashSet; |
|
13 |
import java.util.Set; |
|
14 |
|
|
15 |
import org.eclipse.core.runtime.IProgressMonitor; |
|
16 |
import org.eclipse.core.runtime.IStatus; |
|
17 |
import org.eclipse.core.runtime.Status; |
|
18 |
import org.eclipse.core.runtime.jobs.Job; |
|
19 |
import org.eclipse.swt.widgets.Display; |
|
20 |
|
|
21 |
import eu.etaxonomy.cdm.hibernate.HibernateProxyHelper; |
|
22 |
import eu.etaxonomy.cdm.model.common.CdmBase; |
|
23 |
import eu.etaxonomy.cdm.model.name.TaxonName; |
|
24 |
import eu.etaxonomy.cdm.model.taxon.ITaxonTreeNode; |
|
25 |
import eu.etaxonomy.cdm.model.taxon.Taxon; |
|
26 |
import eu.etaxonomy.cdm.persistence.hibernate.CdmDataChangeEvent; |
|
27 |
import eu.etaxonomy.cdm.persistence.hibernate.CdmDataChangeEvent.EventType; |
|
28 |
import eu.etaxonomy.cdm.persistence.hibernate.CdmDataChangeMap; |
|
29 |
import eu.etaxonomy.taxeditor.model.AbstractDataChangeBehaviour_; |
|
30 |
import eu.etaxonomy.taxeditor.model.IDataChangeBehavior; |
|
31 |
import eu.etaxonomy.taxeditor.navigation.l10n.Messages; |
|
32 |
|
|
33 |
/** |
|
34 |
* <p>TaxonNavigatorDataChangeBehavior class.</p> |
|
35 |
* |
|
36 |
* @author n.hoffmann |
|
37 |
* @created 01.04.2009 |
|
38 |
* @version 1.0 |
|
39 |
*/ |
|
40 |
public class TaxonNavigatorDataChangeBehaviorE4_ extends AbstractDataChangeBehaviour_ implements |
|
41 |
IDataChangeBehavior { |
|
42 |
|
|
43 |
private static final String UPDATING_TAXON_NAVIGATOR = Messages.TaxonNavigatorDataChangeBehavior_UPDATE_NAVIGATOR; |
|
44 |
|
|
45 |
private final TaxonNavigatorE4 source; |
|
46 |
|
|
47 |
private Set<CdmBase> staleObjects; |
|
48 |
|
|
49 |
/** |
|
50 |
* <p>Constructor for TaxonNavigatorDataChangeBehavior.</p> |
|
51 |
* |
|
52 |
* @param taxonNavigator a {@link eu.etaxonomy.taxeditor.navigation.navigator.TaxonNavigator} object. |
|
53 |
*/ |
|
54 |
public TaxonNavigatorDataChangeBehaviorE4_(TaxonNavigatorE4 taxonNavigator) { |
|
55 |
source = taxonNavigator; |
|
56 |
} |
|
57 |
|
|
58 |
/* (non-Javadoc) |
|
59 |
* @see eu.etaxonomy.taxeditor.store.model.IDataChangeBehavior#isRelevant(java.lang.Object, eu.etaxonomy.cdm.persistence.hibernate.CdmCrudEvent) |
|
60 |
*/ |
|
61 |
/** |
|
62 |
* <p>isRelevant</p> |
|
63 |
* |
|
64 |
* @param events a {@link eu.etaxonomy.cdm.persistence.hibernate.CdmDataChangeMap} object. |
|
65 |
* @return a boolean. |
|
66 |
*/ |
|
67 |
public boolean isRelevant(CdmDataChangeMap events) { |
|
68 |
|
|
69 |
// TODO react only on insert/update/delete of taxon and synonym objects |
|
70 |
// and on update of name objects |
|
71 |
boolean relevant = false; |
|
72 |
staleObjects = new HashSet<CdmBase>(); |
|
73 |
|
|
74 |
for(CdmDataChangeEvent event : events.getAllEvents()){ |
|
75 |
EventType eventType = event.getEventType(); |
|
76 |
CdmBase eventEntity = event.getEntity(); |
|
77 |
|
|
78 |
Set<CdmBase> affectedObjects = event.getAffectedObjects(); |
|
79 |
if(affectedObjects != null) { |
|
80 |
for(CdmBase cb : affectedObjects) { |
|
81 |
staleObjects.add(HibernateProxyHelper.deproxy(cb)); |
|
82 |
} |
|
83 |
} |
|
84 |
|
|
85 |
// all tree node changes are relevant |
|
86 |
if((eventType == EventType.INSERT || eventType == EventType.DELETE || eventType == EventType.UPDATE) |
|
87 |
&& event.getEntity() instanceof ITaxonTreeNode){ |
|
88 |
return true; |
|
89 |
} |
|
90 |
|
|
91 |
if (eventType == EventType.DELETE){ |
|
92 |
return true; |
|
93 |
} |
|
94 |
|
|
95 |
|
|
96 |
|
|
97 |
if(eventType == EventType.UPDATE && event.getEntity() instanceof Taxon){ |
|
98 |
TaxonName name = null; |
|
99 |
if(eventEntity instanceof Taxon){ |
|
100 |
name = ((Taxon) eventEntity).getName(); |
|
101 |
}else{ |
|
102 |
continue; |
|
103 |
} |
|
104 |
|
|
105 |
// Set<IEditorPart> openEditors = NavigationUtil.getOpenEditors(); |
|
106 |
/*for(IEditorPart editor : openEditors){ |
|
107 |
|
|
108 |
if(name.equals(((TaxonEditorInput) editor.getEditorInput()).getTaxon().getName())){ |
|
109 |
return true; |
|
110 |
} |
|
111 |
}*/ |
|
112 |
} |
|
113 |
|
|
114 |
// if(eventType == EventType.UPDATE){ |
|
115 |
// relevant = true; |
|
116 |
// CdmBase entity = event.getEntity(); |
|
117 |
// if((entity instanceof TaxonNameBase) |
|
118 |
// || (entity instanceof Taxon) |
|
119 |
// || (entity instanceof Synonym)){ |
|
120 |
// staleObjects.add(entity); |
|
121 |
// } |
|
122 |
// } |
|
123 |
} |
|
124 |
|
|
125 |
return false; |
|
126 |
|
|
127 |
// @deprecated |
|
128 |
// react on everything except load |
|
129 |
// if(events.sizeByEventType(EventType.INSERT) > 0){ |
|
130 |
// return true; |
|
131 |
// }else if(events.sizeByEventType(EventType.UPDATE) > 0){ |
|
132 |
// return true; |
|
133 |
// }else if(events.sizeByEventType(EventType.DELETE) > 0){ |
|
134 |
// return true; |
|
135 |
// }else{ |
|
136 |
// return false; |
|
137 |
// } |
|
138 |
} |
|
139 |
|
|
140 |
/** {@inheritDoc} */ |
|
141 |
@Override |
|
142 |
public void reactOnDataChange(CdmDataChangeMap events) { |
|
143 |
if(isRelevant(events)){ |
|
144 |
|
|
145 |
final Display display = Display.getCurrent(); |
|
146 |
Job job = new Job(UPDATING_TAXON_NAVIGATOR) { |
|
147 |
|
|
148 |
@Override |
|
149 |
protected IStatus run(IProgressMonitor monitor) { |
|
150 |
monitor.beginTask(UPDATING_TAXON_NAVIGATOR, 3); |
|
151 |
monitor.worked(1); |
|
152 |
|
|
153 |
// clear the session completely |
|
154 |
monitor.subTask(Messages.TaxonNavigatorDataChangeBehavior_CLEAR_SESSION); |
|
155 |
display.asyncExec(new Runnable() { |
|
156 |
@Override |
|
157 |
public void run() { |
|
158 |
//TODO: check wether we can remove this |
|
159 |
|
|
160 |
//source.getConversationHolder().clear(); |
|
161 |
} |
|
162 |
}); |
|
163 |
// FIXME completely clearing the session is a brute force approach. |
|
164 |
// It would be much more elegant to clear only those elements that have been changed. |
|
165 |
// I could not get that to work but we should consider workin on this because we might |
|
166 |
// run into serious performance issues, especially when it comes to large trees |
|
167 |
// |
|
168 |
// at least, we moved this to a job so it can run in a background thred |
|
169 |
// seems to improve the situation but not sure if final solution |
|
170 |
monitor.worked(1); |
|
171 |
|
|
172 |
monitor.subTask(Messages.TaxonNavigatorDataChangeBehavior_REFRESH_VIEWER); |
|
173 |
|
|
174 |
display.asyncExec(new Runnable() { |
|
175 |
@Override |
|
176 |
public void run() { |
|
177 |
if(staleObjects != null && staleObjects.size() > 0) { |
|
178 |
source.refresh(staleObjects); |
|
179 |
} else { |
|
180 |
source.refresh(); |
|
181 |
} |
|
182 |
} |
|
183 |
}); |
|
184 |
|
|
185 |
|
|
186 |
|
|
187 |
monitor.worked(1); |
|
188 |
monitor.done(); |
|
189 |
return Status.OK_STATUS; |
|
190 |
} |
|
191 |
}; |
|
192 |
|
|
193 |
job.setPriority(Job.SHORT); |
|
194 |
job.schedule(); |
|
195 |
|
|
196 |
} |
|
197 |
} |
|
198 |
} |
eu.etaxonomy.taxeditor.store/src/main/java/eu/etaxonomy/taxeditor/model/AbstractDataChangeBehaviour_.java | ||
---|---|---|
1 |
/** |
|
2 |
* Copyright (C) 2007 EDIT |
|
3 |
* European Distributed Institute of Taxonomy |
|
4 |
* http://www.e-taxonomy.eu |
|
5 |
* |
|
6 |
* The contents of this file are subject to the Mozilla Public License Version 1.1 |
|
7 |
* See LICENSE.TXT at the top of this package for the full license terms. |
|
8 |
*/ |
|
9 |
|
|
10 |
package eu.etaxonomy.taxeditor.model; |
|
11 |
|
|
12 |
import java.util.Vector; |
|
13 |
|
|
14 |
import eu.etaxonomy.cdm.persistence.hibernate.CdmDataChangeEvent; |
|
15 |
import eu.etaxonomy.cdm.persistence.hibernate.CdmDataChangeMap; |
|
16 |
|
|
17 |
/** |
|
18 |
* Reactions on specific EventyTypes are overridden here for convenience. |
|
19 |
* |
|
20 |
* @author n.hoffmann |
|
21 |
* @created 09.04.2009 |
|
22 |
* @version 1.0 |
|
23 |
*/ |
|
24 |
public abstract class AbstractDataChangeBehaviour_ implements IDataChangeBehavior { |
|
25 |
|
|
26 |
/* (non-Javadoc) |
|
27 |
* @see eu.etaxonomy.taxeditor.store.model.IDataChangeBehavior#reactOnDataChange(java.lang.Object, java.util.List) |
|
28 |
*/ |
|
29 |
/** {@inheritDoc} */ |
|
30 |
public abstract void reactOnDataChange(CdmDataChangeMap events); |
|
31 |
|
|
32 |
/** |
|
33 |
* {@inheritDoc} |
|
34 |
* |
|
35 |
* Implementors should overwrite this method if needed |
|
36 |
* @see eu.etaxonomy.taxeditor.model.IDataChangeBehavior#reactOnDelete(java.lang.Object, eu.etaxonomy.cdm.persistence.hibernate.CdmDataChangeEvent) |
|
37 |
*/ |
|
38 |
public void reactOnDelete(Vector<CdmDataChangeEvent> event) {} |
|
39 |
|
|
40 |
/** |
|
41 |
* {@inheritDoc} |
|
42 |
* |
|
43 |
* Implementors should overwrite this method if needed |
|
44 |
* @see eu.etaxonomy.taxeditor.model.IDataChangeBehavior#reactOnInsert(java.lang.Object, eu.etaxonomy.cdm.persistence.hibernate.CdmDataChangeEvent) |
|
45 |
*/ |
|
46 |
public void reactOnInsert(Vector<CdmDataChangeEvent> event) {} |
|
47 |
|
|
48 |
/** |
|
49 |
* {@inheritDoc} |
|
50 |
* |
|
51 |
* Implementors should overwrite this method if needed |
|
52 |
* @see eu.etaxonomy.taxeditor.model.IDataChangeBehavior#reactOnUpdate(java.lang.Object, eu.etaxonomy.cdm.persistence.hibernate.CdmDataChangeEvent) |
|
53 |
*/ |
|
54 |
public void reactOnUpdate(Vector<CdmDataChangeEvent> event) {} |
|
55 |
} |
Also available in: Unified diff
ref #10186: remove datachangeBehaviour classes