package jav.gui.error.profiler;
import jav.concordance.control.ConcordanceEntry;
import jav.correctionBackend.Pattern;
import jav.correctionBackend.PatternOccurrence;
import jav.correctionBackend.Token;
import jav.gui.events.MessageCenter;
import jav.gui.events.concordance.ConcordanceEvent;
import jav.gui.events.concordance.ConcordanceType;
import jav.gui.filter.PatternFilter;
import jav.gui.main.MainController;
import java.awt.Color;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.MouseEvent;
import java.awt.event.MouseListener;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Iterator;
import java.util.LinkedHashMap;
import java.util.concurrent.CancellationException;
import java.util.concurrent.ExecutionException;
import javax.swing.SwingWorker;
import javax.swing.Timer;
/**
*Copyright (c) 2012, IMPACT working group at the Centrum für Informations- und Sprachverarbeitung, University of Munich.
*All rights reserved.
*Redistribution and use in source and binary forms, with or without
*modification, are permitted provided that the following conditions are met:
*Redistributions of source code must retain the above copyright
*notice, this list of conditions and the following disclaimer.
*Redistributions in binary form must reproduce the above copyright
*notice, this list of conditions and the following disclaimer in the
*documentation and/or other materials provided with the distribution.
*THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
*IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
*TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
*PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
*HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
*SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
*LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
*DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
*THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
*(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
*OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
* This file is part of the ocr-postcorrection tool developed
* by the IMPACT working group at the Centrum für Informations- und Sprachverarbeitung, University of Munich.
* For further information and contacts visit http://ocr.cis.uni-muenchen.de/
*
* @author thorsten (thorsten.vobl@googlemail.com)
*/
public class PatternDefaultMode implements PatternMode {
private PatternLabel lastSelectedPattern = null;
private int clickDelay = 200;
private Timer clickTimer;
private boolean docLoaded = false;
LinkedHashMap<Integer, ConcordanceEntry> tokens;
public PatternDefaultMode() {
// MessageCenter.getInstance().addTokenStatusEventListener(this);
}
@Override
public MouseListener getMouseListener() {
MouseListener ml = new MouseListener() {
@Override
public void mouseClicked(MouseEvent e) {
if (e.getSource() instanceof PatternLabel) {
final PatternLabel pl = (PatternLabel) e.getSource();
// single click = selection / deselection
if (e.getClickCount() == 1) {
clickTimer = new Timer(clickDelay, new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
if (lastSelectedPattern == null) {
pl.setSelected(true);
if (pl.getPattern().getOccurencesN() != pl.getPattern().getCorrected()) {
if (docLoaded) {
PatternTopComponent.findInstance().setKonkordanzButton(true);
}
}
lastSelectedPattern = pl;
} else {
if (lastSelectedPattern.equals(pl)) {
lastSelectedPattern.setSelected(false);
lastSelectedPattern = null;
PatternTopComponent.findInstance().setKonkordanzButton(false);
} else {
lastSelectedPattern.setSelected(false);
pl.setSelected(true);
lastSelectedPattern = pl;
if (pl.getPattern().getOccurencesN() != pl.getPattern().getCorrected()) {
if (docLoaded) {
PatternTopComponent.findInstance().setKonkordanzButton(true);
}
}
}
}
}
});
clickTimer.setRepeats(false);
clickTimer.start();
// double click = correction
} else if (e.getClickCount() == 2) {
clickTimer.stop();
if (pl.getPattern().getOccurencesN() != pl.getPattern().getCorrected()) {
if (!pl.isSelected()) {
pl.setSelected(true);
if (lastSelectedPattern != null) {
lastSelectedPattern.setSelected(false);
}
}
lastSelectedPattern = pl;
concordanceAction();
}
}
}
}
@Override
public void mousePressed(MouseEvent e) {
}
@Override
public void mouseReleased(MouseEvent e) {
}
@Override
public void mouseEntered(MouseEvent e) {
}
@Override
public void mouseExited(MouseEvent e) {
}
};
return ml;
}
@Override
public Color getSelectedColor() {
return Color.RED;
}
@Override
public Color getUnselectedColor() {
return Color.BLACK;
}
@Override
public void concordanceAction() {
MainController.changeCursorWaitStatus(true);
SwingWorker<ArrayList<Token>, Object> worker = new SwingWorker<ArrayList<Token>, Object>() {
@Override
protected ArrayList<Token> doInBackground() {
ArrayList<Token> result = null;
try {
tokens = new LinkedHashMap<>();
Iterator<PatternOccurrence> i = lastSelectedPattern.getPattern().getOccurences().iterator();
HashMap<String, PatternOccurrence> types = new HashMap<>();
while (i.hasNext()) {
PatternOccurrence po = i.next();
types.put(po.getWOCR_LC(), po);
}
PatternFilter pF = new PatternFilter(types, "");
result = pF.applyFilter(MainController.findInstance().getDocument().tokenIterator());
Iterator<Token> it = result.iterator();
while (it.hasNext()) {
Token tok = it.next();
ConcordanceEntry ke = new ConcordanceEntry(tok);
PatternOccurrence po = types.get(tok.getWOCR_lc());
// pattern suggestions are always lowercase, if wocr is uppercase then make first letter of suggestion uppercase
if (Character.isUpperCase(tok.getWOCR().charAt(0))) {
po.setWSuggestion(po.getWSuggestion().substring(0, 1).toUpperCase() + po.getWSuggestion().substring(1));
}
ke.setCandidateString(po.getWSuggestion());
tokens.put(tok.getID(), ke);
}
} catch (Exception e) {
}
return result;
}
@Override
protected void done() {
try {
ArrayList<Token> result = get();
if (result != null) {
MessageCenter.getInstance().fireConcordanceEvent(new ConcordanceEvent(this, ConcordanceType.DIVERSE, result, lastSelectedPattern.getPattern().getLeft() + " --> " + lastSelectedPattern.getPattern().getRight()));
} else {
}
MainController.changeCursorWaitStatus(false);
} catch (ExecutionException ex) {
} catch (InterruptedException ex) {
} catch (CancellationException ex) {
}
}
};
worker.execute();
}
@Override
public Pattern getSelectedPattern() {
if (lastSelectedPattern != null) {
return lastSelectedPattern.getPattern();
} else {
return null;
}
}
// @Override
// public void dispatchEvent(TokenStatusEvent e) {
// if (lastSelectedPattern != null && e.getType().equals(TokenStatusType.CORRECTED)) {
// final Integer tok = e.getTokenIndex();
// EventQueue.invokeLater(new Runnable() {
//
// @Override
// public void run() {
// if (tokens.containsKey(tok)) {
// lastSelectedPattern.getPattern().setCorrected(true);
// lastSelectedPattern.setToolTipText(java.util.ResourceBundle.getBundle("jav/gui/error/profiler/Bundle").getString("pat_frq") + lastSelectedPattern.getPattern().getOccurencesN() + java.util.ResourceBundle.getBundle("jav/gui/error/profiler/Bundle").getString("occurences") + lastSelectedPattern.getPattern().getOccurencesN() + "</br>" + java.util.ResourceBundle.getBundle("jav/gui/error/profiler/Bundle").getString("corrected") + lastSelectedPattern.getPattern().getCorrected() + "</br></html>");
// if (lastSelectedPattern.getPattern().getOccurencesN() == lastSelectedPattern.getPattern().getCorrected()) {
// PatternTopComponent.findInstance().setKonkordanzButton(false);
// }
// }
// }
// });
// }
// }
@Override
public void disconnect() {
// MessageCenter.getInstance().removeTokenStatusEventListener(this);
}
@Override
public void setDocLoaded(boolean b) {
this.docLoaded = b;
}
}