/*******************************************************************************
* Copyright (c) 2016 Weasis Team and others.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* Nicolas Roduit - initial API and implementation
*******************************************************************************/
package org.weasis.acquire.explorer.gui.control;
import java.awt.Dimension;
import java.beans.PropertyChangeEvent;
import java.io.File;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.ExecutorService;
import javax.swing.JButton;
import javax.swing.JOptionPane;
import javax.swing.JPanel;
import javax.swing.SwingWorker;
import javax.swing.SwingWorker.StateValue;
import org.dcm4che3.net.Status;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.weasis.acquire.explorer.Messages;
import org.weasis.acquire.explorer.PublishDicomTask;
import org.weasis.acquire.explorer.gui.dialog.AcquirePublishDialog;
import org.weasis.core.api.gui.task.CircularProgressBar;
import org.weasis.core.api.gui.util.JMVUtils;
import org.weasis.core.api.gui.util.WinUtil;
import org.weasis.core.api.util.FontTools;
import org.weasis.core.api.util.ThreadUtil;
import org.weasis.dicom.param.DicomNode;
import org.weasis.dicom.param.DicomState;
@SuppressWarnings("serial")
public class AcquirePublishPanel extends JPanel {
private static final Logger LOGGER = LoggerFactory.getLogger(AcquirePublishPanel.class);
private final JButton publishBtn = new JButton(Messages.getString("AcquirePublishPanel.publish")); //$NON-NLS-1$
private final CircularProgressBar progressBar = new CircularProgressBar(0, 100);
public static final ExecutorService PUBLISH_DICOM = ThreadUtil.buildNewSingleThreadExecutor("Publish Dicom"); //$NON-NLS-1$
public AcquirePublishPanel() {
// setBorder(new TitledBorder(null, "Publish", TitledBorder.LEADING, TitledBorder.TOP, null, null));
publishBtn.addActionListener(e -> {
final AcquirePublishDialog dialog = new AcquirePublishDialog(AcquirePublishPanel.this);
JMVUtils.showCenterScreen(dialog, WinUtil.getParentWindow(AcquirePublishPanel.this));
});
publishBtn.setPreferredSize(new Dimension(150, 40));
publishBtn.setFont(FontTools.getFont12Bold());
add(publishBtn);
add(progressBar);
progressBar.setVisible(false);
}
public void publishDirDicom(File exportDirDicom, DicomNode destinationNode) {
SwingWorker<DicomState, File> publishDicomTask = new PublishDicomTask(exportDirDicom, destinationNode);
publishDicomTask.addPropertyChangeListener(this::publishChanged);
PUBLISH_DICOM.execute(publishDicomTask);
}
private void publishChanged(PropertyChangeEvent evt) {
if ("progress" == evt.getPropertyName()) { //$NON-NLS-1$
int progress = (Integer) evt.getNewValue();
progressBar.setValue(progress);
} else if ("state" == evt.getPropertyName()) { //$NON-NLS-1$
if (StateValue.STARTED == evt.getNewValue()) {
publishBtn.setEnabled(false);
progressBar.setVisible(true);
progressBar.setValue(0);
} else if (StateValue.DONE == evt.getNewValue()) {
try {
SwingWorker<DicomState, File> publishDicomTask = (SwingWorker<DicomState, File>) evt.getSource();
final DicomState dicomState = publishDicomTask.get();
if (dicomState.getStatus() != Status.Success && dicomState.getStatus() != Status.Cancel) {
LOGGER.error("Dicom send error: {}", dicomState.getMessage()); //$NON-NLS-1$
JOptionPane.showMessageDialog(WinUtil.getParentWindow(AcquirePublishPanel.this),
dicomState.getMessage(), null, // $NON-NLS-1$
JOptionPane.ERROR_MESSAGE);
}
} catch (InterruptedException e) {
LOGGER.warn("Retrieving task Interruption"); //$NON-NLS-1$
} catch (ExecutionException e) {
LOGGER.error("Retrieving task", e); //$NON-NLS-1$
}
publishBtn.setEnabled(true);
progressBar.setVisible(false);
}
}
}
}