1998-07-19 01:43:02 +04:00
|
|
|
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*-
|
|
|
|
*
|
1999-11-06 06:43:54 +03:00
|
|
|
* The contents of this file are subject to the Netscape Public
|
|
|
|
* License Version 1.1 (the "License"); you may not use this file
|
|
|
|
* except in compliance with the License. You may obtain a copy of
|
|
|
|
* the License at http://www.mozilla.org/NPL/
|
1998-07-19 01:43:02 +04:00
|
|
|
*
|
1999-11-06 06:43:54 +03:00
|
|
|
* Software distributed under the License is distributed on an "AS
|
|
|
|
* IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
|
|
|
|
* implied. See the License for the specific language governing
|
|
|
|
* rights and limitations under the License.
|
1998-07-19 01:43:02 +04:00
|
|
|
*
|
|
|
|
* The Original Code is Mozilla Communicator client code.
|
|
|
|
*
|
|
|
|
* The Initial Developer of the Original Code is Netscape Communications
|
1999-11-06 06:43:54 +03:00
|
|
|
* Corporation. Portions created by Netscape are
|
|
|
|
* Copyright (C) 1998 Netscape Communications Corporation. All
|
|
|
|
* Rights Reserved.
|
|
|
|
*
|
|
|
|
* Contributor(s):
|
1998-07-19 01:43:02 +04:00
|
|
|
*/
|
|
|
|
#ifndef nsIWebShell_h___
|
|
|
|
#define nsIWebShell_h___
|
|
|
|
|
|
|
|
#include "nsIWidget.h"
|
1999-11-19 10:35:27 +03:00
|
|
|
#include "nsIParser.h"
|
1998-07-19 01:43:02 +04:00
|
|
|
#include "nsIScrollableView.h"
|
|
|
|
#include "nsIContentViewerContainer.h"
|
1999-06-28 14:35:57 +04:00
|
|
|
#include "nsIChannel.h"
|
1998-11-10 02:30:16 +03:00
|
|
|
#include "nsIScrollableView.h"
|
1998-07-19 01:43:02 +04:00
|
|
|
|
1999-05-15 02:40:03 +04:00
|
|
|
class nsIDOMElement;
|
2000-09-01 05:54:35 +04:00
|
|
|
class nsIDOMWindowInternal;
|
1998-07-19 05:17:39 +04:00
|
|
|
class nsIFactory;
|
1999-08-04 00:51:41 +04:00
|
|
|
//class nsIPostData;
|
1998-07-19 01:43:02 +04:00
|
|
|
class nsIStreamObserver;
|
1998-07-23 08:23:00 +04:00
|
|
|
class nsIDocumentLoader;
|
1999-04-07 01:00:26 +04:00
|
|
|
class nsIDocumentLoaderObserver;
|
1998-07-19 01:43:02 +04:00
|
|
|
class nsIWebShell;
|
|
|
|
class nsIWebShellContainer;
|
1999-04-20 05:50:03 +04:00
|
|
|
class nsIContent;
|
1999-11-18 10:06:07 +03:00
|
|
|
class nsIURIContentListener;
|
1999-11-12 01:32:13 +03:00
|
|
|
class nsIDOMDocument;
|
1999-11-23 12:57:47 +03:00
|
|
|
class nsIChromeEventHandler;
|
1998-07-19 01:43:02 +04:00
|
|
|
|
|
|
|
// Interface ID for nsIWebShell
|
|
|
|
#define NS_IWEB_SHELL_IID \
|
|
|
|
{ 0xa6cf9058, 0x15b3, 0x11d2,{0x93, 0x2e, 0x00, 0x80, 0x5f, 0x8a, 0xdd, 0x32}}
|
|
|
|
|
|
|
|
// Interface ID for nsIWebShellContainer
|
|
|
|
#define NS_IWEB_SHELL_CONTAINER_IID \
|
|
|
|
{ 0xa6cf905a, 0x15b3, 0x11d2,{0x93, 0x2e, 0x00, 0x80, 0x5f, 0x8a, 0xdd, 0x32}}
|
|
|
|
|
|
|
|
// Class ID for an implementation of nsIWebShell
|
|
|
|
#define NS_WEB_SHELL_CID \
|
|
|
|
{ 0xa6cf9059, 0x15b3, 0x11d2,{0x93, 0x2e, 0x00, 0x80, 0x5f, 0x8a, 0xdd, 0x32}}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
|
1998-08-15 03:08:54 +04:00
|
|
|
typedef enum {
|
|
|
|
nsLoadURL,
|
|
|
|
nsLoadHistory,
|
|
|
|
nsLoadLink,
|
|
|
|
nsLoadRefresh
|
|
|
|
} nsLoadType;
|
|
|
|
|
1998-07-19 01:43:02 +04:00
|
|
|
// Container for web shell's
|
|
|
|
class nsIWebShellContainer : public nsISupports {
|
|
|
|
public:
|
1999-03-12 01:34:13 +03:00
|
|
|
static const nsIID& GetIID() { static nsIID iid = NS_IWEB_SHELL_CONTAINER_IID; return iid; }
|
|
|
|
|
1998-07-19 01:43:02 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The web shell is a container for implementations of nsIContentViewer.
|
|
|
|
* It is a content-viewer-container and also knows how to delegate certain
|
|
|
|
* behavior to an nsIWebShellContainer.
|
|
|
|
*
|
|
|
|
* Web shells can be arranged in a tree.
|
|
|
|
*
|
1998-07-19 05:17:39 +04:00
|
|
|
* Web shells are also nsIWebShellContainer's because they can contain
|
|
|
|
* other web shells.
|
1998-07-19 01:43:02 +04:00
|
|
|
*/
|
|
|
|
class nsIWebShell : public nsIContentViewerContainer {
|
|
|
|
public:
|
1999-03-12 01:34:13 +03:00
|
|
|
static const nsIID& GetIID() { static nsIID iid = NS_IWEB_SHELL_IID; return iid; }
|
|
|
|
|
1998-11-03 11:04:34 +03:00
|
|
|
/**
|
|
|
|
* Set the nsIWebShellContainer for the WebShell.
|
|
|
|
*/
|
1998-07-19 01:43:02 +04:00
|
|
|
NS_IMETHOD SetContainer(nsIWebShellContainer* aContainer) = 0;
|
1998-11-03 11:04:34 +03:00
|
|
|
|
1999-03-13 06:31:55 +03:00
|
|
|
/**
|
1999-04-07 01:00:26 +04:00
|
|
|
* Return the current nsIWebShellContainer.
|
1999-03-13 06:31:55 +03:00
|
|
|
*/
|
1999-04-07 01:00:26 +04:00
|
|
|
NS_IMETHOD GetContainer(nsIWebShellContainer*& aResult) = 0;
|
1999-03-13 06:31:55 +03:00
|
|
|
|
1999-11-16 23:06:12 +03:00
|
|
|
/**
|
|
|
|
* Returns the top level window (this would be the containing window
|
2000-03-14 06:58:45 +03:00
|
|
|
* the same object that implements nsIWebShellContainer, nsIWebShellWindow).
|
1999-11-16 23:06:12 +03:00
|
|
|
*/
|
|
|
|
NS_IMETHOD GetTopLevelWindow(nsIWebShellContainer** aTopLevelWindow) = 0;
|
|
|
|
|
1998-11-03 11:04:34 +03:00
|
|
|
/**
|
|
|
|
* Return the root WebShell instance. Since WebShells can be nested
|
|
|
|
* (when frames are present for example) this instance represents the
|
|
|
|
* outermost WebShell.
|
|
|
|
*/
|
1998-07-19 05:17:39 +04:00
|
|
|
NS_IMETHOD GetRootWebShell(nsIWebShell*& aResult) = 0;
|
1998-11-03 11:04:34 +03:00
|
|
|
|
1999-10-26 02:20:10 +04:00
|
|
|
/**
|
|
|
|
* Get the referrer of the link using this WebShell.
|
|
|
|
*/
|
|
|
|
NS_IMETHOD GetReferrer(nsIURI **aReferrer) = 0;
|
|
|
|
|
1998-11-03 11:04:34 +03:00
|
|
|
//
|
1998-08-15 03:08:54 +04:00
|
|
|
// Document load api's
|
1998-11-03 11:04:34 +03:00
|
|
|
//
|
|
|
|
/**
|
|
|
|
* Return the nsIDocumentLoader associated with the WebShell.
|
|
|
|
*/
|
1998-08-15 03:08:54 +04:00
|
|
|
NS_IMETHOD GetDocumentLoader(nsIDocumentLoader*& aResult) = 0;
|
1998-11-03 11:04:34 +03:00
|
|
|
|
|
|
|
//
|
1998-07-19 01:43:02 +04:00
|
|
|
// History api's
|
1998-11-03 11:04:34 +03:00
|
|
|
//
|
|
|
|
/**
|
|
|
|
* Load the previous document in the history list.
|
|
|
|
*/
|
1998-07-22 15:22:59 +04:00
|
|
|
NS_IMETHOD GoTo(PRInt32 aHistoryIndex) = 0;
|
1999-01-29 02:13:48 +03:00
|
|
|
NS_IMETHOD GetHistoryLength(PRInt32& aResult) = 0;
|
1998-07-19 01:43:02 +04:00
|
|
|
NS_IMETHOD GetHistoryIndex(PRInt32& aResult) = 0;
|
1999-02-14 09:35:01 +03:00
|
|
|
NS_IMETHOD GetURL(PRInt32 aHistoryIndex, const PRUnichar **aURLResult) = 0;
|
1998-07-19 01:43:02 +04:00
|
|
|
|
|
|
|
// SetToolBar
|
|
|
|
// SetMenuBar
|
|
|
|
// SetStatusBar
|
1998-08-19 02:01:50 +04:00
|
|
|
|
1998-10-24 00:47:57 +04:00
|
|
|
/**
|
|
|
|
* Finds text in content
|
|
|
|
*/
|
|
|
|
NS_IMETHOD FindNext(const PRUnichar * aSearchStr, PRBool aMatchCase, PRBool aSearchDown, PRBool &aIsFound) = 0;
|
1999-06-15 02:10:41 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the URL of the current WebShell.
|
|
|
|
*/
|
|
|
|
NS_IMETHOD SetURL(const PRUnichar* aURL) = 0;
|
|
|
|
|
2000-02-16 01:55:36 +03:00
|
|
|
/**
|
|
|
|
* Notify children to fire unload events before root data gone
|
|
|
|
*/
|
|
|
|
NS_IMETHOD FireUnloadEvent(void) = 0;
|
1998-07-19 01:43:02 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif /* nsIWebShell_h___ */
|