Package org.gvt.action

Source Code of org.gvt.action.LoadBioPaxModelAction

package org.gvt.action;

import org.biopax.paxtools.model.Model;
import org.eclipse.jface.action.Action;
import org.eclipse.jface.dialogs.MessageDialog;
import org.eclipse.jface.resource.ImageDescriptor;
import org.eclipse.swt.SWT;
import org.eclipse.swt.widgets.FileDialog;
import org.eclipse.swt.widgets.MessageBox;
import org.gvt.ChisioMain;
import org.gvt.model.BioPAXGraph;
import org.gvt.util.BioPAXReader;

import java.io.File;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.List;

/**
* This class loads an XML file which is Graphml based and visualizes the graph.
* It is called from Menubar/File/Open item.
*
* @author Ozgun Babur
*
* Copyright: Bilkent Center for Bioinformatics, 2007 - present
*/
public class LoadBioPaxModelAction extends Action
{
  protected ChisioMain main;

  protected String filename;

  private String pathwayName;

  /**
   * BioPAX paxtools model object.
   */
  protected Model model;

  /**
   * The graph to load (if supplied)
   */
  protected BioPAXGraph graph;

  /**
   * What to do after load operation.
   */
  private boolean openPathways;

  private static String lastLocation = "samples/biopax-files/";

  /**
   * Constructor without filename. opens an FileChooser for filename
   *
   * @param chisio
   */
  public LoadBioPaxModelAction(ChisioMain chisio)
  {
    super("Load ...");
    setToolTipText(getText());
    setImageDescriptor(ImageDescriptor.createFromFile(ChisioMain.class, "icon/open.png"));

    this.openPathways = true;
    this.main = chisio;
  }

  public void setOpenPathways(boolean openPathways)
  {
    this.openPathways = openPathways;
  }

  public void setPathwayName(String pathwayName)
  {
    this.pathwayName = pathwayName;
  }

  public String getPathwayName()
  {
    return pathwayName;
  }

  /**
   * Constructor with filename. opens the xml with file with the given
   * filename.
   *
   * @param chisio
   * @param filename
   */
  public LoadBioPaxModelAction(ChisioMain chisio, String filename)
  {
    this(chisio);
    this.filename = filename;
  }

  public LoadBioPaxModelAction(ChisioMain chisio, Model model)
  {
    this(chisio);
    this.model = model;
  }

  public LoadBioPaxModelAction(ChisioMain chisio, BioPAXGraph graph)
  {
    this(chisio);
    this.graph = graph;
  }

  /**
   * Hands unsaved changes before the text is discarded.
   *
   * @param main main application
   * @return whether furthur action should be carried on.
   */
  public static boolean saveChangesBeforeDiscard(ChisioMain main)
  {
    if (main.isDirty())
    {
      MessageBox messageBox = new MessageBox(
        main.getShell(),
        SWT.ICON_WARNING | SWT.YES | SWT.NO | SWT.CANCEL);

      messageBox.setMessage("Would you like to save the changes?");
      messageBox.setText(ChisioMain.TOOL_NAME);
      int answer = messageBox.open();

      if (answer == SWT.YES)
      {
        SaveBioPAXFileAction save = new SaveBioPAXFileAction(main);
        save.run();

        return save.isSaved();
      }
      else if (answer == SWT.NO)
      {
        return true;
      }

      return false;
    }

    return true;
  }

  /**
   * opens a FileChooser for loading an xml file
   *
   * @return chosen filename
   */
  public String openFileChooser()
  {
    // choose an input file.
    FileDialog fileChooser = new FileDialog(main.getShell(), SWT.OPEN);
    fileChooser.setFilterExtensions(FILTER_EXTENSIONS);
    fileChooser.setFilterNames(FILTER_NAMES);

    fileChooser.setFilterPath(lastLocation);

    String f = fileChooser.open();

    String x = null;
    if (f != null)
    {
      if (f.contains("/"))
      {
        x = f.substring(0, f.lastIndexOf("/"));
      }
      else if (f.contains("\\"))
      {
        x = f.substring(0, f.lastIndexOf("\\"));
      }
    }

    if (x != null) lastLocation = x;

    return f;
  }

  public void run()
  {
    if (saveChangesBeforeDiscard(main))
    {
      if (filename == null && model == null && graph == null)
      {
        filename = openFileChooser();

        if (filename == null)
        {
          return;
        }
      }

      try
      {
        main.lockWithMessage("Loading BioPAX model ...");

        BioPAXGraph root = this.graph;

        if (root == null)
        {
          File xmlfile = filename == null ? null : new File(filename);
          BioPAXReader reader = model == null ?
            new BioPAXReader(): new BioPAXReader(model);
          root = (BioPAXGraph) reader.readXMLFile(xmlfile);
        }

        if (root != null)
        {
          if (!root.modelConstainsPathway() || pathwayName != null)
          {
            String name = pathwayName == null ? filename : pathwayName;

            if (name != null)
            {
              if (name.contains("\\"))
              {
                name = name.substring(name.lastIndexOf("\\") + 1);
              }
              else if (name.contains("/"))
              {
                name = name.substring(name.lastIndexOf("/") + 1);
              }

              if (name.contains("."))
              {
                name = name.substring(0, name.lastIndexOf("."));
              }
            }
            else
            {
              name = "Auto-created Pathway";
            }
            root.createGlobalPathway(name);
            pathwayName = name;
            main.getAllPathwayNames().add(pathwayName);
          }

          main.closeAllTabs(false);
          main.setRootGraph(root);
          main.setOwlFileName(filename);

          if (openPathways)
          {
            main.unlock();

            // If there is only one pathway, open it automatically

            int pathwaySize = main.getAllPathwayNames().size();
            List<String> autoOpen = null;

            if (pathwaySize == 1)
            {
              autoOpen = Arrays.asList(main.getAllPathwayNames().iterator().next());
            }

            new OpenPathwaysAction(main, autoOpen).run();
          }
        }
        else
        {
          MessageDialog.openError(main.getShell(), "Error", "Cannot load file.");
        }

        // reset filename for future loadings.
        // otherwise always opens the same file
        filename = null;
        model = null;
      }
      catch (Exception e)
      {
        e.printStackTrace();
        filename = null;
        model = null;
      }
      finally
      {
        main.unlock();
      }
    }
  }

  /**
   * Checks if the file has a valid extension for loading into chisio.
   * @param path the path of the file
   * @return true if file name is valid
   */
  public static boolean hasValidExtension(String path)
  {
    for (String extension : FILTER_EXTENSIONS)
    {
      if (path.substring(path.lastIndexOf(".")).equalsIgnoreCase(extension.substring(1)))
      {
        return true;
      }
    }
    return false;
  }

  public static final String[] FILTER_EXTENSIONS = new String[]{"*.owl"};
  public static final String[] FILTER_NAMES = new String[]{"BioPAX (*.owl)"};
}
TOP

Related Classes of org.gvt.action.LoadBioPaxModelAction

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.