org.swrlapi.ui.view.queries.SQWRLResultView Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of swrlapi Show documentation
Show all versions of swrlapi Show documentation
Java API for working with SWRL rules and SQWRL queries
package org.swrlapi.ui.view.queries;
import org.checkerframework.checker.nullness.qual.NonNull;
import org.checkerframework.checker.nullness.qual.Nullable;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.swrlapi.sqwrl.SQWRLQueryEngine;
import org.swrlapi.sqwrl.SQWRLResult;
import org.swrlapi.sqwrl.exceptions.SQWRLException;
import org.swrlapi.sqwrl.exceptions.SQWRLInvalidQueryNameException;
import org.swrlapi.sqwrl.values.SQWRLClassExpressionResultValue;
import org.swrlapi.sqwrl.values.SQWRLDataPropertyExpressionResultValue;
import org.swrlapi.sqwrl.values.SQWRLEntityResultValue;
import org.swrlapi.sqwrl.values.SQWRLLiteralResultValue;
import org.swrlapi.sqwrl.values.SQWRLObjectPropertyExpressionResultValue;
import org.swrlapi.sqwrl.values.SQWRLResultValue;
import org.swrlapi.ui.model.SQWRLQueryEngineModel;
import org.swrlapi.ui.view.SWRLAPIView;
import javax.swing.*;
import javax.swing.table.AbstractTableModel;
import java.awt.*;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.io.File;
import java.io.FileOutputStream;
import java.io.OutputStream;
import java.io.OutputStreamWriter;
/**
* A view holding the result for a single SQWRL query.
*
* @see org.swrlapi.sqwrl.SQWRLQueryEngine
* @see org.swrlapi.sqwrl.SQWRLResult
* @see org.swrlapi.ui.view.queries.SQWRLQueryControlView
*/
public class SQWRLResultView extends JPanel implements SWRLAPIView
{
private static final Logger log = LoggerFactory.getLogger(SQWRLResultView.class);
private static final long serialVersionUID = 1L;
@NonNull private final SQWRLQueryEngineModel queryEngineModel;
@NonNull private final SQWRLQueryControlView sqwrlQueryControlView;
@NonNull private final SQWRLQueryResultTableModel sqwrlQueryResultTableModel;
@NonNull private final String queryName;
@NonNull private SQWRLResult sqwrlResult;
@Nullable private static File currentDirectory = null;
public SQWRLResultView(@NonNull SQWRLQueryEngineModel queryEngineModel, @NonNull String queryName,
@NonNull SQWRLResult sqwrlResult, @NonNull SQWRLQueryControlView sqwrlQueryControlView)
{
this.queryEngineModel = queryEngineModel;
this.sqwrlQueryControlView = sqwrlQueryControlView;
this.sqwrlQueryResultTableModel = new SQWRLQueryResultTableModel();
this.queryName = queryName;
this.sqwrlResult = sqwrlResult;
}
@Override public void initialize()
{
this.sqwrlQueryControlView.initialize();
setLayout(new BorderLayout());
JTable sqwrlQueryResultTable = new JTable(this.sqwrlQueryResultTableModel);
JPanel buttonsPanel = new JPanel(new FlowLayout());
JButton saveSQWRLResultButton = createButton("Save as CSV...", "Save the result as a CSV file...",
new SaveSQWRLResultActionListener(this));
buttonsPanel.add(saveSQWRLResultButton);
JButton runSQWRLQueryButton = createButton("Rerun", "Rerun this SQWRL query", new RunSQWRLQueryActionListener());
buttonsPanel.add(runSQWRLQueryButton);
JButton closeSQWRLResultButton = createButton("Close", "Close the tab for this query",
new CloseSQWRLResultActionListener());
buttonsPanel.add(closeSQWRLResultButton);
JScrollPane scrollPane = new JScrollPane(sqwrlQueryResultTable);
JViewport viewPort = scrollPane.getViewport();
viewPort.setBackground(sqwrlQueryResultTable.getBackground());
add(BorderLayout.CENTER, scrollPane);
add(BorderLayout.SOUTH, buttonsPanel);
}
@Override public void validate()
{
this.sqwrlQueryResultTableModel.fireTableStructureChanged();
super.validate();
}
@Override public void update()
{
validate();
}
@NonNull private SQWRLQueryEngine getSQWRLQueryEngine()
{
return this.queryEngineModel.getSQWRLQueryEngine();
}
private class RunSQWRLQueryActionListener implements ActionListener
{
@Override public void actionPerformed(ActionEvent event)
{
try {
SQWRLResultView.this.sqwrlResult = SQWRLResultView.this.getSQWRLQueryEngine()
.runSQWRLQuery(SQWRLResultView.this.queryName);
if (SQWRLResultView.this.sqwrlResult == null || SQWRLResultView.this.sqwrlResult.getNumberOfRows() == 0) {
SQWRLResultView.this.sqwrlQueryControlView.appendToConsole(
"No result returned for SQWRL query '" + SQWRLResultView.this.queryName + "' - closing tab.\n");
SQWRLResultView.this.sqwrlQueryControlView.removeSQWRLResultView(SQWRLResultView.this.queryName);
} else
validate();
} catch (SQWRLInvalidQueryNameException e) {
SQWRLResultView.this.sqwrlQueryControlView
.appendToConsole("Invalid query name " + SQWRLResultView.this.queryName + ".\n");
} catch (SQWRLException e) {
SQWRLResultView.this.sqwrlQueryControlView.appendToConsole(
"Exception running SQWRL query '" + SQWRLResultView.this.queryName + "': " + (e != null ? e.getMessage() : "")
+ "\n");
}
/*
* if (sqwrlResult == null) { controlPanel.removeAllPanels();
* controlPanel.appendText("Closing all result tabs.\n"); }
*/
}
}
private class CloseSQWRLResultActionListener implements ActionListener
{
@Override public void actionPerformed(ActionEvent event)
{
SQWRLResultView.this.sqwrlQueryControlView.removeSQWRLResultView(SQWRLResultView.this.queryName);
SQWRLResultView.this.sqwrlQueryControlView
.appendToConsole("'" + SQWRLResultView.this.queryName + "' tab closed.\n");
}
}
private class SaveSQWRLResultActionListener implements ActionListener
{
@NonNull private final Component component;
@NonNull private final JFileChooser chooser;
public SaveSQWRLResultActionListener(Component component)
{
this.component = component;
this.chooser = new JFileChooser();
this.chooser.setCurrentDirectory(currentDirectory);
}
@Override public void actionPerformed(@NonNull ActionEvent event)
{
saveSQWRLResultAsCSV();
}
private void saveSQWRLResultAsCSV()
{
try {
int returnValue = this.chooser.showOpenDialog(SQWRLResultView.this.sqwrlQueryControlView);
if (returnValue == JFileChooser.APPROVE_OPTION) {
File selectedFile = this.chooser.getSelectedFile();
currentDirectory = this.chooser.getCurrentDirectory();
OutputStream fileOutputStream = new FileOutputStream(selectedFile);
OutputStreamWriter writer = new OutputStreamWriter(fileOutputStream, "UTF8");
SQWRLResultView.this.sqwrlResult = SQWRLResultView.this.getSQWRLQueryEngine()
.getSQWRLResult(SQWRLResultView.this.queryName);
if (SQWRLResultView.this.sqwrlResult != null) {
int numberOfColumns = SQWRLResultView.this.sqwrlResult.getNumberOfColumns();
for (int i = 0; i < numberOfColumns; i++) {
if (i != 0)
writer.write(", ");
writer.write(SQWRLResultView.this.sqwrlResult.getColumnName(i));
}
writer.write("\n");
while (SQWRLResultView.this.sqwrlResult.next()) {
for (int i = 0; i < numberOfColumns; i++) {
SQWRLResultValue value = SQWRLResultView.this.sqwrlResult.getValue(i);
if (i != 0)
writer.write(", ");
if (value instanceof SQWRLLiteralResultValue && ((SQWRLLiteralResultValue)value).isQuotableType())
writer.write("\"" + value + "\"");
else
writer.write("" + value);
}
writer.write("\n");
}
SQWRLResultView.this.sqwrlResult.reset();
writer.close();
SQWRLResultView.this.sqwrlQueryControlView.appendToConsole(
"Successfully saved results of query " + SQWRLResultView.this.queryName + " to CSV file " + selectedFile
.getPath() + ".\n");
}
}
} catch (Throwable e) {
JOptionPane
.showMessageDialog(this.component, "Error saving file: " + (e.getMessage() != null ? e.getMessage() : ""),
"Error saving file", JOptionPane.ERROR_MESSAGE);
}
}
}
@NonNull private JButton createButton(@NonNull String text, @NonNull String toolTipText,
@NonNull ActionListener listener)
{
JButton button = new JButton(text);
button.setToolTipText(toolTipText);
button.setPreferredSize(new Dimension(160, 30));
button.addActionListener(listener);
return button;
}
private class SQWRLQueryResultTableModel extends AbstractTableModel
{
private static final long serialVersionUID = 1L;
@Override public int getRowCount()
{
try {
return (SQWRLResultView.this.sqwrlResult == null) ? 0 : SQWRLResultView.this.sqwrlResult.getNumberOfRows();
} catch (SQWRLException e) {
return 0;
}
}
@Override public int getColumnCount()
{
try {
return (SQWRLResultView.this.sqwrlResult == null) ? 0 : SQWRLResultView.this.sqwrlResult.getNumberOfColumns();
} catch (SQWRLException e) {
return 0;
}
}
@NonNull @Override public String getColumnName(int columnIndex)
{
try {
return (SQWRLResultView.this.sqwrlResult == null) ?
"" :
SQWRLResultView.this.sqwrlResult.getColumnName(columnIndex);
} catch (SQWRLException e) {
return "";
}
}
@NonNull @Override public Object getValueAt(int row, int column)
{
try {
SQWRLResultValue sqwrlResultValue = (SQWRLResultView.this.sqwrlResult == null) ?
null :
SQWRLResultView.this.sqwrlResult.getValue(column, row);
if (sqwrlResultValue != null && sqwrlResultValue.isEntity()) {
SQWRLEntityResultValue sqwrlEntityResultValue = sqwrlResultValue.asEntityResult();
return sqwrlEntityResultValue.getShortName();
} else if (sqwrlResultValue != null && sqwrlResultValue.isClassExpression()) {
SQWRLClassExpressionResultValue sqwrlClassExpressionResultValue = sqwrlResultValue.asClassExpressionResult();
return sqwrlClassExpressionResultValue.getRendering();
} else if (sqwrlResultValue != null && sqwrlResultValue.isObjectPropertyExpression()) {
SQWRLObjectPropertyExpressionResultValue sqwrlObjectPropertyExpressionResultValue = sqwrlResultValue.asObjectPropertyExpressionResult();
return sqwrlObjectPropertyExpressionResultValue.getRendering();
} else if (sqwrlResultValue != null && sqwrlResultValue.isDataPropertyExpression()) {
SQWRLDataPropertyExpressionResultValue sqwrlDataPropertyExpressionResultValue = sqwrlResultValue.asDataPropertyExpressionResult();
return sqwrlDataPropertyExpressionResultValue.getRendering();
} else if (sqwrlResultValue != null && sqwrlResultValue.isLiteral()) {
SQWRLLiteralResultValue sqwrLiteralResultValue = sqwrlResultValue.asLiteralResult();
if (sqwrLiteralResultValue.isInteger() || sqwrLiteralResultValue.isDecimal() || sqwrLiteralResultValue.isString()
|| sqwrLiteralResultValue.isBoolean())
return sqwrLiteralResultValue.getValue();
else
return "\"" + sqwrLiteralResultValue.getValue() + "\"^^" + sqwrLiteralResultValue.getDatatypePrefixedName();
} else
return "";
} catch (SQWRLException e) {
return "";
}
}
}
}