2000-03-02 05:24:57 +03:00
|
|
|
/* -*- Mode: IDL; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*-
|
|
|
|
*
|
|
|
|
* The contents of this file are subject to the Mozilla 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/MPL/
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*
|
|
|
|
* The Original Code is the Mozilla browser.
|
|
|
|
*
|
|
|
|
* The Initial Developer of the Original Code is Netscape
|
|
|
|
* Communications, Inc. Portions created by Netscape are
|
|
|
|
* Copyright (C) 1999, Mozilla. All Rights Reserved.
|
|
|
|
*
|
|
|
|
* Contributor(s):
|
|
|
|
* Travis Bogard <travis@netscape.com>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "nsISupports.idl"
|
|
|
|
|
2000-12-15 02:26:35 +03:00
|
|
|
interface nsIDOMWindow;
|
2000-03-02 05:24:57 +03:00
|
|
|
interface nsIWebProgressListener;
|
|
|
|
|
|
|
|
/**
|
2000-12-15 02:26:35 +03:00
|
|
|
* The nsIWebProgress interface is used to look at the progress of document
|
|
|
|
* loading in a particular DOM Window.
|
2001-03-24 03:22:18 +03:00
|
|
|
*
|
|
|
|
* @status UNDER_REVIEW
|
2000-03-02 05:24:57 +03:00
|
|
|
*/
|
|
|
|
|
|
|
|
[scriptable, uuid(570F39D0-EFD0-11d3-B093-00A024FFC08C)]
|
|
|
|
interface nsIWebProgress : nsISupports
|
2000-12-15 02:26:35 +03:00
|
|
|
{
|
2002-05-17 00:57:37 +04:00
|
|
|
const unsigned long NOTIFY_STATE_REQUEST = 0x00000001;
|
|
|
|
const unsigned long NOTIFY_STATE_DOCUMENT = 0x00000002;
|
|
|
|
const unsigned long NOTIFY_STATE_NETWORK = 0x00000004;
|
|
|
|
const unsigned long NOTIFY_STATE_WINDOW = 0x00000008;
|
|
|
|
const unsigned long NOTIFY_STATE_ALL = 0x0000000f;
|
|
|
|
|
|
|
|
const unsigned long NOTIFY_PROGRESS = 0x00000010;
|
|
|
|
const unsigned long NOTIFY_STATUS = 0x00000020;
|
|
|
|
const unsigned long NOTIFY_SECURITY = 0x00000040;
|
|
|
|
const unsigned long NOTIFY_LOCATION = 0x00000080;
|
|
|
|
|
|
|
|
const unsigned long NOTIFY_ALL = 0x000000ff;
|
|
|
|
|
2000-12-15 02:26:35 +03:00
|
|
|
/**
|
|
|
|
* Registers a listener to be notified of Progress Events
|
|
|
|
*
|
|
|
|
* @param listener - The listener interface to be called when a progress
|
|
|
|
* event occurs.
|
|
|
|
*
|
2002-05-17 00:57:37 +04:00
|
|
|
* @param aNotifyMask - The types of notifications to receive.
|
|
|
|
*
|
2000-12-15 02:26:35 +03:00
|
|
|
* @return NS_OK - Listener was registered successfully.
|
|
|
|
* NS_INVALID_ARG - The listener passed in was either nsnull,
|
|
|
|
* or was already registered with this progress
|
|
|
|
* interface.
|
|
|
|
*/
|
2002-05-17 00:57:37 +04:00
|
|
|
void addProgressListener(in nsIWebProgressListener listener,
|
|
|
|
in unsigned long aNotifyMask);
|
2000-03-02 05:24:57 +03:00
|
|
|
|
2000-12-15 02:26:35 +03:00
|
|
|
/**
|
|
|
|
* Removes a previously registered listener of Progress Events
|
|
|
|
*
|
|
|
|
* @param listener - The listener interface previously registered with
|
|
|
|
* AddListener().
|
|
|
|
*
|
|
|
|
* @return NS_OK - Listener was successfully unregistered.
|
|
|
|
* NS_ERROR_INVALID_ARG - The listener was not previously
|
|
|
|
* registered listener.
|
|
|
|
*/
|
|
|
|
void removeProgressListener(in nsIWebProgressListener listener);
|
2000-03-02 05:24:57 +03:00
|
|
|
|
2000-12-15 02:26:35 +03:00
|
|
|
/**
|
|
|
|
* The DOM Window associated with the WebProgress instance.
|
|
|
|
*/
|
|
|
|
readonly attribute nsIDOMWindow DOMWindow;
|
2002-07-02 06:17:15 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The IsLoadingDocument associated with the WebProgress instance
|
|
|
|
*/
|
|
|
|
readonly attribute PRBool isLoadingDocument;
|
2000-03-02 05:24:57 +03:00
|
|
|
};
|