package org.docear.plugin.pdfutilities.actions;
import java.awt.event.ActionEvent;
import java.io.IOException;
import java.net.URI;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Map;
import org.docear.plugin.core.features.AnnotationID;
import org.docear.plugin.core.util.Tools;
import org.docear.plugin.pdfutilities.features.AnnotationModel;
import org.docear.plugin.pdfutilities.features.AnnotationNodeModel;
import org.docear.plugin.pdfutilities.features.IAnnotation;
import org.docear.plugin.pdfutilities.features.IAnnotation.AnnotationType;
import org.docear.plugin.pdfutilities.map.AnnotationController;
import org.docear.plugin.pdfutilities.pdf.PdfAnnotationImporter;
import org.docear.plugin.pdfutilities.ui.conflict.ImportConflictDialog;
import org.docear.plugin.pdfutilities.util.MonitoringUtils;
import org.freeplane.core.ui.EnabledAction;
import org.freeplane.core.util.LogUtils;
import org.freeplane.features.map.NodeModel;
import org.freeplane.features.mode.Controller;
import de.intarsys.pdf.parser.COSLoadException;
@EnabledAction( checkOnPopup = true, checkOnNodeChange = true )
public class ImportNewAnnotationsAction extends ImportAnnotationsAction {
/**
*
*/
private static final long serialVersionUID = 1L;
@SuppressWarnings("serial")
public ImportNewAnnotationsAction(String key) {
super(key);
this.setEnableType(new ArrayList<AnnotationType>(){{ add(AnnotationType.PDF_FILE); }});
}
public void actionPerformed(ActionEvent event) {
NodeModel selected = Controller.getCurrentController().getSelection().getSelected();
if(selected == null){
return;
}
else{
URI uri = Tools.getAbsoluteUri(selected);
try {
PdfAnnotationImporter importer = new PdfAnnotationImporter();
Collection<AnnotationModel> annotations = importer.importAnnotations(uri);
Map<AnnotationID, Collection<AnnotationNodeModel>> oldAnnotations = MonitoringUtils.getOldAnnotationsFromCurrentMap();
annotations = AnnotationController.markNewAnnotations(annotations, oldAnnotations);
Map<AnnotationID, Collection<IAnnotation>> conflicts = AnnotationController.getConflictedAnnotations(annotations, oldAnnotations);
if(conflicts.size() > 0){
ImportConflictDialog dialog = new ImportConflictDialog(Controller.getCurrentController().getViewController().getJFrame(), conflicts);
dialog.showDialog();
}
//System.gc();
MonitoringUtils.insertNewChildNodesFrom(annotations, selected.isLeft(), selected, selected);
} catch (IOException e) {
LogUtils.severe("ImportAllAnnotationsAction IOException at URI("+uri+"): ", e); //$NON-NLS-1$ //$NON-NLS-2$
} catch (COSLoadException e) {
LogUtils.severe("ImportAllAnnotationsAction ImportException at URI("+uri+"): ", e); //$NON-NLS-1$ //$NON-NLS-2$
}
}
}
}