weka.gui.knowledgeflow.steps.SubstringLabelerStepEditorDialog Maven / Gradle / Ivy
/*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
*/
/*
* SubstringLabelerStepEditorDialog.java
* Copyright (C) 2015 University of Waikato, Hamilton, New Zealand
*
*/
package weka.gui.knowledgeflow.steps;
import weka.gui.EnvironmentField;
import weka.gui.JListHelper;
import weka.gui.beans.SubstringLabelerRules;
import weka.gui.knowledgeflow.StepEditorDialog;
import weka.knowledgeflow.steps.SubstringLabeler;
import javax.swing.BorderFactory;
import javax.swing.DefaultListModel;
import javax.swing.JButton;
import javax.swing.JCheckBox;
import javax.swing.JLabel;
import javax.swing.JList;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.SwingConstants;
import javax.swing.event.ListSelectionEvent;
import javax.swing.event.ListSelectionListener;
import java.awt.BorderLayout;
import java.awt.GridLayout;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.beans.PropertyChangeEvent;
import java.beans.PropertyChangeListener;
/**
* Step editor dialog for the SubstringLabeler step
*
* @author Mark Hall (mhall{[at]}pentaho{[dot]}com)
* @version $Revision: $
*/
public class SubstringLabelerStepEditorDialog extends StepEditorDialog {
private static final long serialVersionUID = 2386951012941540643L;
/** Field for specifying the name of the new attribute to create */
protected EnvironmentField m_matchAttNameField;
/** Field for specifying the attributes to match on */
protected EnvironmentField m_attListField;
/** Field for specifying the string/regex to match */
protected EnvironmentField m_matchField;
/** Field for specifying the label to assign if match is positive */
protected EnvironmentField m_labelField;
/** Checkbox to specify that the match is a regex */
protected JCheckBox m_regexCheck = new JCheckBox();
/** Checkbox for specifying that case should be ignored when matching */
protected JCheckBox m_ignoreCaseCheck = new JCheckBox();
/**
* Checkbox for making a binary label attribute into a nominal one (rather
* than numeric)
*/
protected JCheckBox m_nominalBinaryCheck = new JCheckBox();
/**
* Checkbox for specifying that non-matching instances should be consumed
* rather than having the match attribute value set to missing value
*/
protected JCheckBox m_consumeNonMatchingCheck = new JCheckBox();
/** Holds the list of match rules */
protected JList m_list =
new JList();
/** List model */
protected DefaultListModel m_listModel;
/** Button for adding a new match rule */
protected JButton m_newBut = new JButton("New");
/** Button for deleting a match rule */
protected JButton m_deleteBut = new JButton("Delete");
/** Button for moving a match rule up in the list */
protected JButton m_upBut = new JButton("Move up");
/** Button for moving a match rule down in the list */
protected JButton m_downBut = new JButton("Move down");
/**
* Initialize the dialog
*/
protected void initialize() {
String mlString = ((SubstringLabeler) getStepToEdit()).getMatchDetails();
m_listModel =
new DefaultListModel();
m_list.setModel(m_listModel);
if (mlString != null && mlString.length() > 0) {
String[] parts =
mlString.split(SubstringLabelerRules.MATCH_RULE_SEPARATOR);
if (parts.length > 0) {
m_upBut.setEnabled(true);
m_downBut.setEnabled(true);
for (String mPart : parts) {
SubstringLabelerRules.SubstringLabelerMatchRule m =
new SubstringLabelerRules.SubstringLabelerMatchRule(mPart);
m_listModel.addElement(m);
}
m_list.repaint();
}
}
}
/**
* Layout the editor dialog
*/
@Override
protected void layoutEditor() {
initialize();
JPanel mainHolder = new JPanel(new BorderLayout());
JPanel controlHolder = new JPanel();
controlHolder.setLayout(new BorderLayout());
JPanel fieldHolder = new JPanel();
JPanel attListP = new JPanel();
attListP.setLayout(new BorderLayout());
attListP.setBorder(BorderFactory.createTitledBorder("Apply to attributes"));
m_attListField = new EnvironmentField(m_env);
attListP.add(m_attListField, BorderLayout.CENTER);
attListP
.setToolTipText("Accepts a range of indexes (e.g. '1,2,6-10')
"
+ "or a comma-separated list of named attributes");
JPanel matchP = new JPanel();
matchP.setLayout(new BorderLayout());
matchP.setBorder(BorderFactory.createTitledBorder("Match"));
m_matchField = new EnvironmentField(m_env);
matchP.add(m_matchField, BorderLayout.CENTER);
JPanel labelP = new JPanel();
labelP.setLayout(new BorderLayout());
labelP.setBorder(BorderFactory.createTitledBorder("Label"));
m_labelField = new EnvironmentField(m_env);
labelP.add(m_labelField, BorderLayout.CENTER);
fieldHolder.add(attListP);
fieldHolder.add(matchP);
fieldHolder.add(labelP);
controlHolder.add(fieldHolder, BorderLayout.NORTH);
JPanel checkHolder = new JPanel();
checkHolder.setLayout(new GridLayout(0, 2));
JLabel attNameLab =
new JLabel("Name of label attribute", SwingConstants.RIGHT);
checkHolder.add(attNameLab);
m_matchAttNameField = new EnvironmentField(m_env);
m_matchAttNameField.setText(((SubstringLabeler) getStepToEdit())
.getMatchAttributeName());
checkHolder.add(m_matchAttNameField);
JLabel regexLab =
new JLabel("Match using a regular expression", SwingConstants.RIGHT);
regexLab
.setToolTipText("Use a regular expression rather than literal match");
checkHolder.add(regexLab);
checkHolder.add(m_regexCheck);
JLabel caseLab =
new JLabel("Ignore case when matching", SwingConstants.RIGHT);
checkHolder.add(caseLab);
checkHolder.add(m_ignoreCaseCheck);
JLabel nominalBinaryLab =
new JLabel("Make binary label attribute nominal", SwingConstants.RIGHT);
nominalBinaryLab
.setToolTipText("If the label attribute is binary (i.e. no
"
+ "explicit labels have been declared) then
this makes the resulting "
+ "attribute nominal
rather than numeric.");
checkHolder.add(nominalBinaryLab);
checkHolder.add(m_nominalBinaryCheck);
m_nominalBinaryCheck.setSelected(((SubstringLabeler) getStepToEdit())
.getNominalBinary());
JLabel consumeNonMatchLab =
new JLabel("Consume non-matching instances", SwingConstants.RIGHT);
consumeNonMatchLab
.setToolTipText("When explicit labels have been defined, consume "
+ "
(rather than output with missing value) instances");
checkHolder.add(consumeNonMatchLab);
checkHolder.add(m_consumeNonMatchingCheck);
m_consumeNonMatchingCheck.setSelected(((SubstringLabeler) getStepToEdit())
.getConsumeNonMatching());
controlHolder.add(checkHolder, BorderLayout.SOUTH);
mainHolder.add(controlHolder, BorderLayout.NORTH);
m_list.setVisibleRowCount(5);
m_deleteBut.setEnabled(false);
JPanel listPanel = new JPanel();
listPanel.setLayout(new BorderLayout());
JPanel butHolder = new JPanel();
butHolder.setLayout(new GridLayout(1, 0));
butHolder.add(m_newBut);
butHolder.add(m_deleteBut);
butHolder.add(m_upBut);
butHolder.add(m_downBut);
m_upBut.setEnabled(false);
m_downBut.setEnabled(false);
listPanel.add(butHolder, BorderLayout.NORTH);
JScrollPane js = new JScrollPane(m_list);
js.setBorder(BorderFactory
.createTitledBorder("Match-list list (rows applied in order)"));
listPanel.add(js, BorderLayout.CENTER);
mainHolder.add(listPanel, BorderLayout.CENTER);
add(mainHolder, BorderLayout.CENTER);
m_attListField.addPropertyChangeListener(new PropertyChangeListener() {
@Override
public void propertyChange(PropertyChangeEvent e) {
Object m = m_list.getSelectedValue();
if (m != null) {
((SubstringLabelerRules.SubstringLabelerMatchRule) m)
.setAttsToApplyTo(m_attListField.getText());
m_list.repaint();
}
}
});
m_matchField.addPropertyChangeListener(new PropertyChangeListener() {
@Override
public void propertyChange(PropertyChangeEvent e) {
Object m = m_list.getSelectedValue();
if (m != null) {
((SubstringLabelerRules.SubstringLabelerMatchRule) m)
.setMatch(m_matchField.getText());
m_list.repaint();
}
}
});
m_labelField.addPropertyChangeListener(new PropertyChangeListener() {
@Override
public void propertyChange(PropertyChangeEvent e) {
Object m = m_list.getSelectedValue();
if (m != null) {
((SubstringLabelerRules.SubstringLabelerMatchRule) m)
.setLabel(m_labelField.getText());
m_list.repaint();
}
}
});
m_list.addListSelectionListener(new ListSelectionListener() {
@Override
public void valueChanged(ListSelectionEvent e) {
if (!e.getValueIsAdjusting()) {
if (!m_deleteBut.isEnabled()) {
m_deleteBut.setEnabled(true);
}
checkUpDown();
Object entry = m_list.getSelectedValue();
if (entry != null) {
SubstringLabelerRules.SubstringLabelerMatchRule m =
(SubstringLabelerRules.SubstringLabelerMatchRule) entry;
m_attListField.setText(m.getAttsToApplyTo());
m_matchField.setText(m.getMatch());
m_labelField.setText(m.getLabel());
m_regexCheck.setSelected(m.getRegex());
m_ignoreCaseCheck.setSelected(m.getIgnoreCase());
}
}
}
});
m_newBut.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
SubstringLabelerRules.SubstringLabelerMatchRule m =
new SubstringLabelerRules.SubstringLabelerMatchRule();
String atts =
(m_attListField.getText() != null) ? m_attListField.getText() : "";
m.setAttsToApplyTo(atts);
String match =
(m_matchField.getText() != null) ? m_matchField.getText() : "";
m.setMatch(match);
String label =
(m_labelField.getText() != null) ? m_labelField.getText() : "";
m.setLabel(label);
m.setRegex(m_regexCheck.isSelected());
m.setIgnoreCase(m_ignoreCaseCheck.isSelected());
m_listModel.addElement(m);
if (m_listModel.size() > 1) {
m_upBut.setEnabled(true);
m_downBut.setEnabled(true);
}
m_list.setSelectedIndex(m_listModel.size() - 1);
checkUpDown();
}
});
m_deleteBut.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
int selected = m_list.getSelectedIndex();
if (selected >= 0) {
m_listModel.removeElementAt(selected);
checkUpDown();
if (m_listModel.size() <= 1) {
m_upBut.setEnabled(false);
m_downBut.setEnabled(false);
}
}
}
});
m_upBut.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
JListHelper.moveUp(m_list);
checkUpDown();
}
});
m_downBut.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
JListHelper.moveDown(m_list);
checkUpDown();
}
});
m_regexCheck.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
Object m = m_list.getSelectedValue();
if (m != null) {
((SubstringLabelerRules.SubstringLabelerMatchRule) m)
.setRegex(m_regexCheck.isSelected());
m_list.repaint();
}
}
});
m_ignoreCaseCheck.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
Object m = m_list.getSelectedValue();
if (m != null) {
((SubstringLabelerRules.SubstringLabelerMatchRule) m)
.setIgnoreCase(m_ignoreCaseCheck.isSelected());
m_list.repaint();
}
}
});
}
/**
* Set the enabled state of the up and down buttons based on the currently
* selected row in the table
*/
protected void checkUpDown() {
if (m_list.getSelectedValue() != null && m_listModel.size() > 1) {
m_upBut.setEnabled(m_list.getSelectedIndex() > 0);
m_downBut.setEnabled(m_list.getSelectedIndex() < m_listModel.size() - 1);
}
}
/**
* Called when the OK button is pressed
*/
@Override
protected void okPressed() {
StringBuilder buff = new StringBuilder();
for (int i = 0; i < m_listModel.size(); i++) {
SubstringLabelerRules.SubstringLabelerMatchRule mr =
(SubstringLabelerRules.SubstringLabelerMatchRule) m_listModel
.elementAt(i);
buff.append(mr.toStringInternal());
if (i < m_listModel.size() - 1) {
buff.append(SubstringLabelerRules.MATCH_RULE_SEPARATOR);
}
}
((SubstringLabeler) getStepToEdit()).setMatchDetails(buff.toString());
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy