Merge branch 'develop' into wset
[taxeditor.git] / eu.etaxonomy.taxeditor.navigation / src / main / java / eu / etaxonomy / taxeditor / navigation / navigator / operation / SetSecundumForSubtreeOperation.java
1 /**
2 * Copyright (C) 2017 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 package eu.etaxonomy.taxeditor.navigation.navigator.operation;
10
11 import java.util.UUID;
12
13 import org.apache.log4j.Logger;
14 import org.eclipse.core.runtime.Assert;
15 import org.eclipse.core.runtime.IAdaptable;
16 import org.eclipse.core.runtime.IProgressMonitor;
17 import org.eclipse.core.runtime.IStatus;
18 import org.eclipse.core.runtime.Status;
19 import org.eclipse.core.runtime.jobs.Job;
20 import org.eclipse.swt.widgets.Display;
21 import org.eclipse.ui.progress.IProgressConstants;
22
23 import eu.etaxonomy.cdm.api.application.CdmApplicationException;
24 import eu.etaxonomy.cdm.api.application.CdmApplicationState;
25 import eu.etaxonomy.cdm.api.application.CdmChangeEvent.Action;
26 import eu.etaxonomy.cdm.api.service.ITaxonNodeService;
27 import eu.etaxonomy.cdm.api.service.UpdateResult;
28 import eu.etaxonomy.cdm.api.service.config.SecundumForSubtreeConfigurator;
29 import eu.etaxonomy.cdm.common.monitor.IRemotingProgressMonitor;
30 import eu.etaxonomy.taxeditor.model.AbstractUtility;
31 import eu.etaxonomy.taxeditor.navigation.l10n.Messages;
32 import eu.etaxonomy.taxeditor.operation.IPostMoniteredOperationEnabled;
33 import eu.etaxonomy.taxeditor.operation.RemotingCdmUpdateOperation;
34
35 /**
36 * @author k.luther
37 * @date 10.02.2017
38 *
39 */
40 public class SetSecundumForSubtreeOperation extends RemotingCdmUpdateOperation implements IPostMoniteredOperationEnabled{
41
42 private final static String LABEL = Messages.SetSecundumForSubtreeOperation_CHANGE_SEC_OP;
43 private static final Logger logger = Logger
44 .getLogger(SetSecundumForSubtreeOperation.class);
45 UUID parentUuid;
46 SecundumForSubtreeConfigurator config;
47
48
49 /**
50 * @param label
51 * @param action
52 * @param source
53 * @param async
54 */
55 public SetSecundumForSubtreeOperation(Object source,
56 boolean async,
57 UUID taxonNodeUuid,
58 SecundumForSubtreeConfigurator config) {
59 super(LABEL, Action.Update, source, async);
60 parentUuid = taxonNodeUuid;
61 this.config = config;
62 this.updateResult = new UpdateResult();
63 }
64
65 /**
66 * {@inheritDoc}
67 */
68 @Override
69 protected UpdateResult doUpdateExecute(IProgressMonitor monitor, IAdaptable info) throws Exception {
70 // runMoniteredOperation();
71
72 Job job = createJob(monitor);
73 // configure the job
74 job.setProperty(IProgressConstants.KEEP_PROPERTY, true);
75 job.setUser(true);
76 // schedule job
77 job.schedule();
78
79 return updateResult;
80
81
82 }
83
84
85 private Job createJob(IProgressMonitor monitor){
86 Assert.isNotNull(config, "Configuration may not be null");
87
88 final Display display = Display.getDefault();
89
90 Job job = new Job(Messages.SetSecundumForSubtreeOperation_SET_SEC_TASK) {
91
92
93 @Override
94 protected IStatus run(IProgressMonitor monitor) {
95
96 try {
97 // eu.etaxonomy.cdm.common.monitor.IProgressMonitor cdmMonitor = CdmProgressMonitorAdapter.CreateMonitor(monitor);
98 // config.setMonitor(cdmMonitor);
99 ITaxonNodeService taxonService = CdmApplicationState.getService(ITaxonNodeService.class);
100 // taxonService.setSecundumForSubtree(config.getSubtreeUuid(), config.getNewSecundum(), config.isIncludeAcceptedTaxa(), config.isIncludeSynonyms(), config.isOverwriteExistingAccepted(), config.isOverwriteExistingSynonyms(), config.isIncludeSharedTaxa(), config.isEmptySecundumDetail(), null);
101 updateResult = taxonService.setSecundumForSubtree(config);
102
103 // Display.getDefault().asyncExec(new Runnable() {
104 // @Override
105 // public void run() {
106 // AbstractUtility.executeMoniteredOperation("Update: " + config.getClass().getSimpleName(),
107 // uuid,
108 // 1000,
109 // false,
110 // SetSecundumForSubtreeOperation.this,
111 // null);
112 // }
113 // });
114
115 } catch (CdmApplicationException e) {
116 // TODO Auto-generated catch block
117 e.printStackTrace();
118 }
119 //
120 return Status.OK_STATUS;
121
122 }
123 };
124 return job;
125 }
126
127
128 public void runMoniteredOperation() {
129 ITaxonNodeService nodeService;
130 try {
131 nodeService = CdmApplicationState.getService(ITaxonNodeService.class);
132
133 final UUID uuid = nodeService.monitSetSecundum(config);
134 Display.getDefault().asyncExec(new Runnable() {
135 @Override
136 public void run() {
137 AbstractUtility.executeMoniteredOperation("Set Secundum Reference for Subtree: ",
138 uuid,
139 1000,
140 false,
141 SetSecundumForSubtreeOperation.this,
142 null);
143 }
144 });
145 } catch (CdmApplicationException e) {
146 // TODO Auto-generated catch block
147 e.printStackTrace();
148 }
149
150 }
151
152
153
154 /**
155 * {@inheritDoc}
156 */
157 @Override
158 public void postOperation(IRemotingProgressMonitor monitor) {
159 // TODO Auto-generated method stub
160
161 }
162 }