minor
[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 }
63
64 /**
65 * {@inheritDoc}
66 */
67 @Override
68 protected UpdateResult doUpdateExecute(IProgressMonitor monitor, IAdaptable info) throws Exception {
69 // runMoniteredOperation();
70
71 Job job = createJob(monitor);
72 // configure the job
73 job.setProperty(IProgressConstants.KEEP_PROPERTY, true);
74 job.setUser(true);
75 // schedule job
76 job.schedule();
77
78 return updateResult;
79
80
81 }
82
83
84 private Job createJob(IProgressMonitor monitor){
85 Assert.isNotNull(config, "Configuration may not be null");
86
87 final Display display = Display.getDefault();
88
89 Job job = new Job(Messages.SetSecundumForSubtreeOperation_SET_SEC_TASK) {
90
91
92 @Override
93 protected IStatus run(IProgressMonitor monitor) {
94
95 try {
96 // eu.etaxonomy.cdm.common.monitor.IProgressMonitor cdmMonitor = CdmProgressMonitorAdapter.CreateMonitor(monitor);
97 // config.setMonitor(cdmMonitor);
98 ITaxonNodeService taxonService = CdmApplicationState.getService(ITaxonNodeService.class);
99 // taxonService.setSecundumForSubtree(config.getSubtreeUuid(), config.getNewSecundum(), config.isIncludeAcceptedTaxa(), config.isIncludeSynonyms(), config.isOverwriteExistingAccepted(), config.isOverwriteExistingSynonyms(), config.isIncludeSharedTaxa(), config.isEmptySecundumDetail(), null);
100 updateResult = taxonService.setSecundumForSubtree(config);
101
102 // Display.getDefault().asyncExec(new Runnable() {
103 // @Override
104 // public void run() {
105 // AbstractUtility.executeMoniteredOperation("Update: " + config.getClass().getSimpleName(),
106 // uuid,
107 // 1000,
108 // false,
109 // SetSecundumForSubtreeOperation.this,
110 // null);
111 // }
112 // });
113
114 } catch (CdmApplicationException e) {
115 // TODO Auto-generated catch block
116 e.printStackTrace();
117 }
118 //
119 return Status.OK_STATUS;
120
121 }
122 };
123 return job;
124 }
125
126
127 public void runMoniteredOperation() {
128 ITaxonNodeService nodeService;
129 try {
130 nodeService = CdmApplicationState.getService(ITaxonNodeService.class);
131
132 final UUID uuid = nodeService.monitSetSecundum(config);
133 Display.getDefault().asyncExec(new Runnable() {
134 @Override
135 public void run() {
136 AbstractUtility.executeMoniteredOperation("Set Secundum Reference for Subtree: ",
137 uuid,
138 1000,
139 false,
140 SetSecundumForSubtreeOperation.this,
141 null);
142 }
143 });
144 } catch (CdmApplicationException e) {
145 // TODO Auto-generated catch block
146 e.printStackTrace();
147 }
148
149 }
150
151
152
153 /**
154 * {@inheritDoc}
155 */
156 @Override
157 public void postOperation(IRemotingProgressMonitor monitor) {
158 // TODO Auto-generated method stub
159
160 }
161 }