Improved handling for right mouse click menu on file in Navigator:
[phpeclipse.git] / net.sourceforge.phpeclipse / src / net / sourceforge / phpeclipse / actions / PHPEclipseShowAction.java
index 29a88f5..6a9430d 100644 (file)
@@ -1,14 +1,10 @@
-/**********************************************************************
-Copyright (c) 2000, 2002 IBM Corp. and others.
-All rights reserved. This program and the accompanying materials
-are made available under the terms of the Common Public License v1.0
-which accompanies this distribution, and is available at
-http://www.eclipse.org/legal/cpl-v10.html
-
-Contributors:
-    IBM Corporation - Initial implementation
-    Klaus Hartlage - www.eclipseproject.de
-**********************************************************************/
+/***********************************************************************************************************************************
+ * Copyright (c) 2000, 2002 IBM Corp. and others. All rights reserved. This program and the accompanying materials are made
+ * available under the terms of the Common Public License v1.0 which accompanies this distribution, and is available at
+ * http://www.eclipse.org/legal/cpl-v10.html
+ * 
+ * Contributors: IBM Corporation - Initial implementation Klaus Hartlage - www.eclipseproject.de
+ **********************************************************************************************************************************/
 package net.sourceforge.phpeclipse.actions;
 
 import java.io.IOException;
@@ -18,34 +14,33 @@ import java.text.MessageFormat;
 import java.util.Iterator;
 
 import net.sourceforge.phpeclipse.PHPeclipsePlugin;
-import net.sourceforge.phpeclipse.views.PHPConsole;
+import net.sourceforge.phpeclipse.ui.IPreferenceConstants;
+import net.sourceforge.phpeclipse.ui.editor.ShowExternalPreviewAction;
+import net.sourceforge.phpeclipse.ui.overlaypages.Util;
+import net.sourceforge.phpeclipse.webbrowser.IWebBrowser;
+import net.sourceforge.phpeclipse.webbrowser.internal.BrowserManager;
+import net.sourceforge.phpeclipse.webbrowser.internal.WebBrowserUtil;
+import net.sourceforge.phpeclipse.webbrowser.views.BrowserView;
 
 import org.eclipse.core.resources.IFile;
 import org.eclipse.core.resources.IResource;
-import org.eclipse.core.runtime.IPath;
-import org.eclipse.help.IHelp;
 import org.eclipse.jface.action.IAction;
 import org.eclipse.jface.dialogs.MessageDialog;
 import org.eclipse.jface.preference.IPreferenceStore;
 import org.eclipse.jface.viewers.ISelection;
 import org.eclipse.jface.viewers.ISelectionProvider;
 import org.eclipse.jface.viewers.StructuredSelection;
-import org.eclipse.swt.SWT;
 import org.eclipse.swt.widgets.Shell;
+import org.eclipse.ui.IActionDelegate;
 import org.eclipse.ui.IObjectActionDelegate;
 import org.eclipse.ui.IViewPart;
 import org.eclipse.ui.IWorkbenchPage;
 import org.eclipse.ui.IWorkbenchPart;
-import org.eclipse.ui.PartInitException;
-import org.eclipse.ui.help.WorkbenchHelp;
-import org.eclipse.update.internal.ui.UpdatePerspective;
-import org.eclipse.update.internal.ui.UpdateUIPlugin;
-import org.eclipse.update.internal.ui.views.IEmbeddedWebBrowser;
-//import org.eclipse.jdt.internal.ui.actions.OpenBrowserUtil;
-// import org.eclipse.help.ui.browser.LaunchURL;
+
 
 public class PHPEclipseShowAction implements IObjectActionDelegate {
   private IWorkbenchPart workbenchPart;
+
   /**
    * Constructor for Action1.
    */
@@ -63,77 +58,56 @@ public class PHPEclipseShowAction implements IObjectActionDelegate {
   public void run(IAction action) {
     ISelectionProvider selectionProvider = null;
     selectionProvider = workbenchPart.getSite().getSelectionProvider();
-
     StructuredSelection selection = null;
     selection = (StructuredSelection) selectionProvider.getSelection();
-    PHPConsole console = PHPConsole.getInstance();
-
+    //    PHPConsole console = PHPConsole.getInstance();
     IPreferenceStore store = PHPeclipsePlugin.getDefault().getPreferenceStore();
-
     Shell shell = null;
     Iterator iterator = null;
     iterator = selection.iterator();
     while (iterator.hasNext()) {
       //  obj => selected object in the view
       Object obj = iterator.next();
-
       // is it a resource
       if (obj instanceof IResource) {
         IResource resource = (IResource) obj;
-
         // check if it's a file resource
         switch (resource.getType()) {
+        case IResource.FILE:
+          // single file:
+          IFile previewFile = (IFile) resource;
+          String extension = previewFile.getFileExtension().toLowerCase();
+          boolean bringToTopPreview = Util.getPreviewBooleanValue(previewFile, IPreferenceConstants.PHP_BRING_TO_TOP_PREVIEW_DEFAULT);
+          boolean showHTMLFilesLocal = Util.getPreviewBooleanValue(previewFile, IPreferenceConstants.PHP_SHOW_HTML_FILES_LOCAL);
+          boolean showXMLFilesLocal = Util.getPreviewBooleanValue(previewFile, IPreferenceConstants.PHP_SHOW_XML_FILES_LOCAL);
+          boolean isHTMLFileName = "html".equals(extension) || "htm".equals(extension) || "xhtml".equals(extension);
+          boolean isXMLFileName = "xml".equals(extension) || "xsd".equals(extension) || "dtd".equals(extension);
 
-          case IResource.FILE :
-            // single file:
-            IFile file = (IFile) resource;
           String localhostURL;
-//            IPath path = file.getFullPath();
-//
-//            String localhostURL = file.getLocation().toString();
-//            String lowerCaseFileName = localhostURL.toLowerCase();
-//            //       fileName = "http://localhost"+fileName.replaceAll("c:", "");
-//            String documentRoot = store.getString(PHPeclipsePlugin.DOCUMENTROOT_PREF);
-//            documentRoot = documentRoot.replace('\\', '/');
-//            documentRoot = documentRoot.toLowerCase();
-//
-//            if (lowerCaseFileName.startsWith(documentRoot)) {
-//              localhostURL = localhostURL.substring(documentRoot.length());
+          if (showHTMLFilesLocal && isHTMLFileName) {
+            localhostURL = "file://"+previewFile.getLocation().toString();
+          } else if (showXMLFilesLocal && isXMLFileName) {
+            localhostURL = "file://"+previewFile.getLocation().toString();
+          } else if ((localhostURL = ShowExternalPreviewAction.getLocalhostURL(store, previewFile)) == null) {
+            MessageDialog.openInformation(shell, "Couldn't create localhost URL",
+            "Please configure your localhost and documentRoot");
+            return;
+          }
+        
+          try {
+//            if (store.getBoolean(PHPeclipsePlugin.USE_EXTERNAL_BROWSER_PREF)) {
+//              String[] arguments = { localhostURL };
+//              MessageFormat form = new MessageFormat(store.getString(PHPeclipsePlugin.EXTERNAL_BROWSER_PREF));
+//              Runtime runtime = Runtime.getRuntime();
+//              String command = form.format(arguments);
+//              //                console.write("External Browser command: " + command + "\n");
+//              runtime.exec(command);
 //            } else {
-//              MessageDialog.openInformation(shell, "Wrong DocumentRoot", "Adjust DocumentRoot: " + documentRoot);
-//              return;
+              open(new URL(localhostURL), shell, localhostURL);
 //            }
-//
-//            localhostURL = store.getString(PHPeclipsePlugin.LOCALHOST_PREF) + localhostURL.replaceAll(documentRoot, "");
-
-            if ((localhostURL=getLocalhostURL(store, (IFile) resource)) == null) {
-              MessageDialog.openInformation(shell, "Couldn't create localhost URL", "Please configure your localhost and documentRoot");
-              return;
-            }
-            try {
-              if (store.getBoolean(PHPeclipsePlugin.USE_EXTERNAL_BROWSER_PREF)) {
-                String[] arguments = { localhostURL };
-                MessageFormat form = new MessageFormat(store.getString(PHPeclipsePlugin.EXTERNAL_BROWSER_PREF));
-
-                Runtime runtime = Runtime.getRuntime();
-                String command = form.format(arguments);
-                console.write("External Browser command: " + command + "\n");
-                runtime.exec(command);
-                //                     runtime.exec(store.getString(PHPeclipsePlugin.EXTERNAL_BROWSER_PREF) + " " + fileName);
-                //                                                             runtime.exec("command.com /c start iexplore " + fileName);
-              } else {
-                //    MessageDialog.openInformation(shell, "localhostURL", "localhostURL: " + localhostURL);
-                //  this doesn't work under win98 ?
-                //     Program.launch(localhostURL);
-                console.write("Internal Browser URL: " + localhostURL + "\n");
-                open(new URL(localhostURL), shell, localhostURL);
-              }
-            } catch (MalformedURLException e) {
-              MessageDialog.openInformation(shell, "MalformedURLException: ", e.toString());
-            } catch (IOException e) {
-              MessageDialog.openInformation(shell, "IOException", "Cannot show: " + localhostURL);
-
-            }
+          } catch (MalformedURLException e) {
+            MessageDialog.openInformation(shell, "MalformedURLException: ", e.toString());
+          }
         }
       }
     }
@@ -145,50 +119,23 @@ public class PHPEclipseShowAction implements IObjectActionDelegate {
   public void selectionChanged(IAction action, ISelection selection) {
   }
 
-  public static String getLocalhostURL(IPreferenceStore store, IFile file) {
-    if (store == null) {
-      store = PHPeclipsePlugin.getDefault().getPreferenceStore();
-    }
-
-    IPath path = file.getFullPath();
-
-    String localhostURL = file.getLocation().toString();
-    String lowerCaseFileName = localhostURL.toLowerCase();
-    //       fileName = "http://localhost"+fileName.replaceAll("c:", "");
-    String documentRoot = store.getString(PHPeclipsePlugin.DOCUMENTROOT_PREF);
-    documentRoot = documentRoot.replace('\\', '/');
-    documentRoot = documentRoot.toLowerCase();
-
-    if (lowerCaseFileName.startsWith(documentRoot)) {
-      localhostURL = localhostURL.substring(documentRoot.length());
-    } else {
-      return null;
-    }
-
-    return store.getString(PHPeclipsePlugin.LOCALHOST_PREF) + localhostURL.replaceAll(documentRoot, "");
-
-  }
-
   public static void open(final URL url, final Shell shell, final String dialogTitle) {
-    if (SWT.getPlatform().equals("win32")) {
-      IWorkbenchPage page = PHPeclipsePlugin.getActivePage();
-      try {
-        IViewPart part = page.findView(UpdatePerspective.ID_BROWSER);
-        if (part == null) {
-          part = page.showView(UpdatePerspective.ID_BROWSER);
-        } else
-          page.bringToTop(part);
-        ((IEmbeddedWebBrowser) part).openTo(url.toExternalForm());
-      } catch (PartInitException e) {
-        UpdateUIPlugin.logException(e);
-      }
-    } else {
-      IHelp help = WorkbenchHelp.getHelpSupport();
-      if (help != null) {
-        WorkbenchHelp.getHelpSupport().displayHelpResource(url.toExternalForm());
-      } else {
-        //   showMessage(shell, dialogTitle, ActionMessages.getString("OpenBrowserUtil.help_not_available"), false); //$NON-NLS-1$
-      }
-    }
+//    if (WebBrowserUtil.canUseInternalWebBrowser()) {
+//      IWorkbenchPage page = PHPeclipsePlugin.getActivePage();
+//      try {
+//        IViewPart part = page.findView(BrowserView.ID_BROWSER);
+//        if (part == null) {
+//          part = page.showView(BrowserView.ID_BROWSER);
+//        } else {
+//          page.bringToTop(part);
+//        }
+//        ((BrowserView) part).setUrl(url.toExternalForm());
+//      } catch (Exception e) {
+//      }
+//    } else {
+      BrowserManager manager = BrowserManager.getInstance();
+      IWebBrowser browser = manager.getCurrentWebBrowser();
+      browser.openURL(url);
+//    }
   }
-}
+}
\ No newline at end of file