X-Git-Url: http://git.phpeclipse.com
diff --git a/net.sourceforge.phpeclipse.webbrowser/src/net/sourceforge/phpeclipse/webbrowser/views/BrowserView.java b/net.sourceforge.phpeclipse.webbrowser/src/net/sourceforge/phpeclipse/webbrowser/views/BrowserView.java
index dbb7ca7..c60b9e4 100644
--- a/net.sourceforge.phpeclipse.webbrowser/src/net/sourceforge/phpeclipse/webbrowser/views/BrowserView.java
+++ b/net.sourceforge.phpeclipse.webbrowser/src/net/sourceforge/phpeclipse/webbrowser/views/BrowserView.java
@@ -1,131 +1,194 @@
/*******************************************************************************
* Copyright (c) 2000, 2003 IBM Corporation and others.
- * All rights reserved. This program and the accompanying materials
+ * 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 API and implementation
*******************************************************************************/
package net.sourceforge.phpeclipse.webbrowser.views;
+import java.io.UnsupportedEncodingException;
+import java.net.URLDecoder;
+import java.nio.charset.Charset;
+
import net.sourceforge.phpeclipse.webbrowser.internal.WebBrowser;
import net.sourceforge.phpeclipse.webbrowser.internal.WebBrowserUtil;
+import org.eclipse.swt.browser.Browser;
+import org.eclipse.swt.browser.CloseWindowListener;
import org.eclipse.swt.browser.ProgressListener;
import org.eclipse.swt.browser.StatusTextListener;
import org.eclipse.swt.browser.TitleListener;
+import org.eclipse.swt.browser.WindowEvent;
import org.eclipse.swt.widgets.Composite;
+import org.eclipse.ui.part.IShowInTarget;
+import org.eclipse.ui.part.ShowInContext;
import org.eclipse.ui.part.ViewPart;
/**
- * BrowserView
is a simple demonstration of the SWT Browser widget. It consists of a workbench view and tab folder
- * where each tab in the folder allows the user to interact with a control.
+ * BrowserView
is a simple demonstration of the SWT Browser
+ * widget. It consists of a workbench view and tab folder where each tab in the
+ * folder allows the user to interact with a control.
*
* @see ViewPart
*/
-public class BrowserView extends ViewPart {
- public final static String ID_BROWSER = "net.sourceforge.phpeclipse.webbrowser.views";
-
- WebBrowser fInstance = null;
- String fUrl = null;
-
- /**
- * Create the example
- *
- * @see ViewPart#createPartControl
- */
- public void createPartControl(Composite frame) {
- try {
- if (WebBrowserUtil.isInternalBrowserOperational()) {
- fInstance = new WebBrowser(frame, true, true);
- }
- } catch (Exception e) {
- fInstance = null;
- }
- }
-
- /**
- * Called when we must grab focus.
- *
- * @see org.eclipse.ui.part.ViewPart#setFocus
- */
- public void setFocus() {
- if (fInstance != null) {
- fInstance.setFocus();
- }
- }
-
- /**
- * Called when the View is to be disposed
- */
- public void dispose() {
- if (fInstance != null) {
- fInstance.dispose();
- fInstance = null;
- }
- super.dispose();
- }
-
- public void setUrl(final String url) {
- if (fInstance != null) {
- fUrl = url;
- fInstance.setURL(url);
- // try {
- // ResourcesPlugin.getWorkspace().run(new IWorkspaceRunnable() {
- // public void run(IProgressMonitor monitor) throws CoreException {
- // instance.setURL(url);
- // }
- // }, null);
- // } catch (CoreException e) {
- // // TODO Auto-generated catch block
- // e.printStackTrace();
- // }
- }
- }
-
- public void refresh() {
- if (fInstance != null) {
- fInstance.refresh();
- // try {
- // ResourcesPlugin.getWorkspace().run(new IWorkspaceRunnable() {
- // public void run(IProgressMonitor monitor) throws CoreException {
- // instance.refresh();
- // }
- // }, null);
- // } catch (CoreException e) {
- // // TODO Auto-generated catch block
- // e.printStackTrace();
- // }
- }
- }
-
- public void refresh(String url) {
- if (fInstance != null) {
- if (fUrl==null || !fUrl.equals(url) ) {
- setUrl(url);
- } else {
- refresh();
- }
- }
- }
-
- public void addProgressListener(ProgressListener listener) {
- if (fInstance != null) {
- fInstance.addProgressListener(listener);
- }
- }
-
- public void addStatusTextListener(StatusTextListener listener) {
- if (fInstance != null) {
- fInstance.addStatusTextListener(listener);
- }
- }
-
- public void addTitleListener(TitleListener listener) {
- if (fInstance != null) {
- fInstance.addTitleListener(listener);
- }
- }
+public class BrowserView extends ViewPart implements IShowInTarget {
+ public final static String ID_BROWSER = "net.sourceforge.phpeclipse.webbrowser.views";
+
+ WebBrowser fInstance = null;
+
+ String fUrl = null;
+
+ /**
+ * Create the example
+ *
+ * @see ViewPart#createPartControl
+ */
+ public void createPartControl(Composite frame) {
+ try {
+ if (WebBrowserUtil.isInternalBrowserOperational()) {
+ fInstance = new WebBrowser(frame, true, true);
+ // #1365431 (toshihiro) start
+ fInstance.getBrowser().addCloseWindowListener(
+ new CloseWindowListener() {
+ public void close(WindowEvent event) {
+ getViewSite().getPage().hideView(
+ BrowserView.this);
+ }
+ });
+ // #1365431 (toshihiro) end
+ }
+ } catch (Exception e) {
+ fInstance = null;
+ }
+ }
+
+ /**
+ * Called when we must grab focus.
+ *
+ * @see org.eclipse.ui.part.ViewPart#setFocus
+ */
+ public void setFocus() {
+ if (fInstance != null) {
+ fInstance.setFocus();
+ }
+ }
+
+ /**
+ * Called when the View is to be disposed
+ */
+ public void dispose() {
+ if (fInstance != null) {
+ fInstance.dispose();
+ fInstance = null;
+ }
+ super.dispose();
+ }
+
+ public void setUrl(final String url) {
+ if (fInstance != null) {
+ if (fInstance.getURL() != null && fInstance.getURL().length() > 0) {
+ fUrl = fInstance.getURL();
+ fInstance.setURL(fUrl);
+ } else {
+ fUrl = url;
+ fInstance.setURL(url);
+ }
+ // try {
+ // ResourcesPlugin.getWorkspace().run(new IWorkspaceRunnable() {
+ // public void run(IProgressMonitor monitor) throws CoreException {
+ // instance.setURL(url);
+ // }
+ // }, null);
+ // } catch (CoreException e) {
+ // // TO DO Auto-generated catch block
+ // e.printStackTrace();
+ // }
+ }
+ }
+
+ public void refresh() {
+ if (fInstance != null) {
+ fInstance.refresh();
+ // try {
+ // ResourcesPlugin.getWorkspace().run(new IWorkspaceRunnable() {
+ // public void run(IProgressMonitor monitor) throws CoreException {
+ // instance.refresh();
+ // }
+ // }, null);
+ // } catch (CoreException e) {
+ // // TO DO Auto-generated catch block
+ // e.printStackTrace();
+ // }
+ }
+ }
+
+
+
+ public void refresh(String url) {
+ if (fInstance != null && url != null) {
+ if (fUrl == null) {
+ setUrl(url);
+ } else {
+ Browser browser = fInstance.getBrowser();
+ if (browser != null) {
+ String browserUrl = browser.getUrl();
+ try {
+ browserUrl = URLDecoder.decode(browserUrl, J5CharsetEmulator.defaultCharset().name());
+ } catch (UnsupportedEncodingException e) {
+ // e.printStackTrace();
+ }
+ if (!url.equals(browserUrl)) {
+ setUrl(url);
+ }
+ }
+ }
+ }
+ }
+
+ public void addProgressListener(ProgressListener listener) {
+ if (fInstance != null) {
+ fInstance.addProgressListener(listener);
+ }
+ }
+
+ public void addStatusTextListener(StatusTextListener listener) {
+ if (fInstance != null) {
+ fInstance.addStatusTextListener(listener);
+ }
+ }
+
+ public void addTitleListener(TitleListener listener) {
+ if (fInstance != null) {
+ fInstance.addTitleListener(listener);
+ }
+ }
+
+ public boolean show(ShowInContext context) {
+ if (context instanceof ShowInContextBrowser) {
+ ShowInContextBrowser contextBrowser = (ShowInContextBrowser) context;
+ String localhostURL = contextBrowser.getLocalhostUrl();
+ if (localhostURL != null) {
+ setUrl(localhostURL);
+ return true;
+ }
+ }
+ // *WARNING*
+ // This causes unexpected behaviour such as downloading (save file).
+ // It depends on mime-types setting and native browser, it isn't under control of eclipse.
+ // (IE shows script as plain text since .php is unknown type by default.
+ // Mozilla downloads script file since .php is defined in mimeTypes.rdf as such.)
+ //
+ //if (context.getInput() instanceof IFile) {
+ // IFile file = (IFile) context.getInput();
+ // String localhostURL;
+ // localhostURL = "file:///" + file.getLocation().toString();
+ // setUrl(localhostURL);
+ // return true;
+ //}
+ return false;
+ }
}
\ No newline at end of file