/* * Copyright (c) 2009 The Jackson Laboratory * * This software was developed by Gary Churchill's Lab at The Jackson * Laboratory (see http://research.jax.org/faculty/churchill). * * This 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 software 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 software. If not, see <http://www.gnu.org/licenses/>. */ package org.jax.qtl.fit.gui; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import javax.swing.AbstractAction; import javax.swing.SwingUtilities; import org.jax.qtl.QTL; import org.jax.qtl.cross.Cross; import org.jax.qtl.cross.QtlBasket; import org.jax.qtl.fit.FitQtlCommand; import org.jax.qtl.project.QtlProject; import org.jax.qtl.project.QtlProjectManager; import org.jax.qtl.project.gui.QtlProjectTree; import org.jax.r.jriutilities.RInterface; import org.jax.r.jriutilities.RInterfaceFactory; import org.jax.util.project.ProjectChangeListener; import org.jax.util.project.ProjectManager; /** * Perform a "fitqtl" * @author <A HREF="mailto:keith.sheppard@jax.org">Keith Sheppard</A> */ public class FitQtlAction extends AbstractAction { /** * every {@link java.io.Serializable} is supposed to have one of these */ private static final long serialVersionUID = 4886831184621793808L; private final QtlBasket qtlBasket; private final ActionListener fitApprovedListener = new ActionListener() { public void actionPerformed(ActionEvent e) { FitQtlDialog fitDialog = (FitQtlDialog)e.getSource(); RInterface rInterface = RInterfaceFactory.getRInterfaceInstance(); FitQtlCommand fitCommand = fitDialog.getFitQtlCommand(); rInterface.evaluateCommand(fitCommand); QtlProjectManager.getInstance().notifyActiveProjectModified(); } }; private final ProjectChangeListener projectChangeListener = new ProjectChangeListener() { public void projectChangeOccurred(ProjectManager projectManager) { FitQtlAction.this.projectChanged(); } }; /** * Constructor * @param qtlBasket * the qtl basket to use for fir */ public FitQtlAction(QtlBasket qtlBasket) { super("Fit QTL ..."); this.qtlBasket = qtlBasket; if(qtlBasket == null) { QtlProjectManager.getInstance().addProjectChangeListener( this.projectChangeListener); this.projectChanged(); } } /** * Respond to a project change */ private void projectChanged() { QtlProjectManager projectManager = QtlProjectManager.getInstance(); QtlProject activeProject = projectManager.getActiveProject(); final Cross[] crosses = activeProject.getDataModel().getCrosses(); SwingUtilities.invokeLater(new Runnable() { /** * {@inheritDoc} */ public void run() { FitQtlAction.this.setEnabled(crosses.length >= 1); } }); } /** * {@inheritDoc} */ public void actionPerformed(ActionEvent e) { QtlBasket qtlBasket = this.qtlBasket; if(qtlBasket == null) { QtlProjectTree projectTree = QTL.getInstance().getProjectTree(); qtlBasket = projectTree.getSelectedQtlBasket(); } final FitQtlDialog fitQtlDialog = new FitQtlDialog(QTL.getInstance().getApplicationFrame(), qtlBasket); fitQtlDialog.pack(); fitQtlDialog.addActionListener(this.fitApprovedListener); SwingUtilities.invokeLater(new Runnable() { public void run() { fitQtlDialog.setVisible(true); } }); } }