/*
* Copyright (c) 2012 Patrick Meyer
*
* 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 <http://www.gnu.org/licenses/>.
*/
package com.itemanalysis.jmetrik.graph.density;
import com.itemanalysis.jmetrik.commandbuilder.Command;
import com.itemanalysis.jmetrik.dao.JmetrikDatabaseFactory;
import com.itemanalysis.jmetrik.sql.DataTableName;
import com.itemanalysis.jmetrik.swing.JmetrikTab;
import com.itemanalysis.jmetrik.workspace.*;
import javax.swing.*;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.beans.PropertyChangeListener;
import java.sql.Connection;
import java.util.ArrayList;
import java.util.TreeMap;
import java.util.concurrent.ThreadPoolExecutor;
public class DensityProcess extends AbstractJmetrikProcess {
private DensityCommand command = null;
private static final String PROCESS_NAME = "Density Process";
public DensityProcess(){
command = new DensityCommand();
}
public String getName(){
return PROCESS_NAME;
}
public boolean commandMatch(Command command){
return this.command.equals(command);
}
public void setCommand(Command command){
this.command = (DensityCommand)command;
}
public void addMenuItem(final JFrame parent, JMenu menu, final TreeMap<String, JDialog> dialogs, final Workspace workspace, final JList tableList){
JMenuItem mItem = new JMenuItem("Kernel Density...");
mItem.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
DataTableName tableName = (DataTableName)tableList.getSelectedValue();
if(!workspace.databaseOpened()){
JOptionPane.showMessageDialog(parent,
"You must open a database and select a table before creating a graph.",
"No Open Database", JOptionPane.ERROR_MESSAGE);
}else if(tableName==null){
JOptionPane.showMessageDialog(parent, "You must select a table before creating a graph.",
"No Table Selected", JOptionPane.ERROR_MESSAGE);
}else if(workspace.tableOpen()){
DensityDialog densityDialog = (DensityDialog)dialogs.get(PROCESS_NAME);
if(densityDialog==null ){
densityDialog = new DensityDialog(parent, workspace.getDatabaseName(), tableName, workspace.getVariables());
dialogs.put(PROCESS_NAME, densityDialog);
workspace.addVariableChangeListener(densityDialog.getVariableChangedListener());
}
densityDialog.setVisible(true);
if(densityDialog.canRun()){
workspace.runProcess(densityDialog.getCommand());
}
}
}
});
menu.add(mItem);
}
public void runProcess(Connection conn, JmetrikDatabaseFactory dbFactory, final JTabbedPane tabbedPane, ThreadPoolExecutor threadPool){
//create the chart panel, scroll pane and add to the tabbed pane
DensityPanel densityPanel = new DensityPanel(command);
final JScrollPane scrollPane = new JScrollPane(densityPanel);
tabbedPane.addTab(null, scrollPane);
int tabCount = tabbedPane.getTabCount();
//add tab close button listener
JmetrikTab jTab = new JmetrikTab("density"+ tabCount);
jTab.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
int closeTabNumber = tabbedPane.indexOfComponent(scrollPane);
tabbedPane.removeTabAt(closeTabNumber);
}
});
tabbedPane.setTabComponentAt(tabCount-1, jTab);
tabbedPane.setSelectedIndex(tabCount-1);
//instantiate and execute analysis
DensityAnalysis densityAnalysis = new DensityAnalysis(conn, dbFactory.getDatabaseAccessObject(), command, densityPanel);
for(PropertyChangeListener pcl : propertyChangeListeners){
densityAnalysis.addPropertyChangeListener(pcl);
}
for(VariableChangeListener vcl : variableChangeListeners){
densityAnalysis.addVariableChangeListener(vcl);
}
threadPool.execute(densityAnalysis);
}
}