2018-09-13 20:04:55 +00:00
|
|
|
/* -*- Mode: IDL; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
2017-08-19 07:55:00 +00:00
|
|
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this file,
|
|
|
|
* You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
|
|
*/
|
|
|
|
|
|
|
|
interface LoadContext;
|
2019-04-09 20:59:37 +00:00
|
|
|
interface RemoteTab;
|
2017-08-19 07:55:00 +00:00
|
|
|
interface URI;
|
|
|
|
interface nsIDocShell;
|
|
|
|
interface nsIPrintSettings;
|
2017-08-19 21:16:16 +00:00
|
|
|
interface nsIWebBrowserPersistDocumentReceiver;
|
2017-08-19 07:55:00 +00:00
|
|
|
interface nsIWebProgressListener;
|
|
|
|
|
2019-09-27 15:26:14 +00:00
|
|
|
[ChromeOnly,
|
|
|
|
Exposed=Window]
|
2017-08-19 07:55:00 +00:00
|
|
|
interface FrameLoader {
|
|
|
|
/**
|
|
|
|
* Get the docshell from the frame loader.
|
|
|
|
*/
|
|
|
|
[GetterThrows]
|
|
|
|
readonly attribute nsIDocShell? docShell;
|
|
|
|
|
|
|
|
/**
|
2019-04-09 20:59:37 +00:00
|
|
|
* Get this frame loader's RemoteTab, if it has a remote frame. Otherwise,
|
2017-08-19 07:55:00 +00:00
|
|
|
* returns null.
|
|
|
|
*/
|
2019-04-09 20:59:37 +00:00
|
|
|
readonly attribute RemoteTab? remoteTab;
|
2017-08-19 07:55:00 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get an nsILoadContext for the top-level docshell. For remote
|
|
|
|
* frames, a shim is returned that contains private browsing and app
|
|
|
|
* information.
|
|
|
|
*/
|
|
|
|
readonly attribute LoadContext loadContext;
|
|
|
|
|
2018-10-20 00:02:37 +00:00
|
|
|
/**
|
|
|
|
* Get the root BrowsingContext within the frame.
|
|
|
|
* This may be null immediately after creating a remote frame.
|
|
|
|
*/
|
|
|
|
readonly attribute BrowsingContext? browsingContext;
|
|
|
|
|
2017-08-19 07:55:00 +00:00
|
|
|
/**
|
|
|
|
* Find out whether the loader's frame is at too great a depth in
|
|
|
|
* the frame tree. This can be used to decide what operations may
|
|
|
|
* or may not be allowed on the loader's docshell.
|
|
|
|
*/
|
|
|
|
[Pure]
|
|
|
|
readonly attribute boolean depthTooGreat;
|
|
|
|
|
2019-12-18 18:27:47 +00:00
|
|
|
/**
|
|
|
|
* Find out whether the loader's frame is a remote frame.
|
|
|
|
*/
|
|
|
|
readonly attribute boolean isRemoteFrame;
|
|
|
|
|
2017-08-19 07:55:00 +00:00
|
|
|
/**
|
|
|
|
* Activate remote frame.
|
|
|
|
* Throws an exception with non-remote frames.
|
|
|
|
*/
|
|
|
|
[Throws]
|
|
|
|
void activateRemoteFrame();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Deactivate remote frame.
|
|
|
|
* Throws an exception with non-remote frames.
|
|
|
|
*/
|
|
|
|
[Throws]
|
|
|
|
void deactivateRemoteFrame();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Activate event forwarding from client (remote frame) to parent.
|
|
|
|
*/
|
|
|
|
[Throws]
|
|
|
|
void activateFrameEvent(DOMString aType, boolean capture);
|
|
|
|
|
|
|
|
// Note, when frameloaders are swapped, also messageManagers are swapped.
|
2017-06-20 09:09:50 +00:00
|
|
|
readonly attribute MessageSender? messageManager;
|
2017-08-19 07:55:00 +00:00
|
|
|
|
2017-09-20 18:03:58 +00:00
|
|
|
/**
|
|
|
|
* Force a remote browser to recompute its dimension and screen position.
|
|
|
|
*/
|
|
|
|
[Throws]
|
|
|
|
void requestUpdatePosition();
|
|
|
|
|
2019-05-04 10:42:52 +00:00
|
|
|
/**
|
|
|
|
* Force a TabStateFlush from native sessionStoreListeners.
|
2021-03-26 08:59:33 +00:00
|
|
|
* Returns a promise that resolves when all session store data has been
|
|
|
|
* flushed.
|
2019-05-04 10:42:52 +00:00
|
|
|
*/
|
2021-03-26 08:59:33 +00:00
|
|
|
[Throws]
|
|
|
|
Promise<void> requestTabStateFlush();
|
2019-05-04 10:42:52 +00:00
|
|
|
|
2019-07-11 09:46:14 +00:00
|
|
|
/**
|
|
|
|
* Force Epoch update in native sessionStoreListeners.
|
|
|
|
*/
|
|
|
|
void requestEpochUpdate(unsigned long aEpoch);
|
|
|
|
|
2020-03-19 14:31:52 +00:00
|
|
|
/**
|
|
|
|
* Request a session history update in native sessionStoreListeners.
|
|
|
|
*/
|
2021-06-10 14:30:59 +00:00
|
|
|
void requestSHistoryUpdate();
|
2020-03-19 14:31:52 +00:00
|
|
|
|
2020-09-01 11:00:36 +00:00
|
|
|
/**
|
|
|
|
* Creates a print preview document in this frame, or updates the existing
|
|
|
|
* print preview document with new print settings.
|
|
|
|
*
|
|
|
|
* @param aPrintSettings The print settings to use to layout the print
|
|
|
|
* preview document.
|
2021-04-17 18:41:11 +00:00
|
|
|
* @param aSourceBrowsingContext Optionally, the browsing context that
|
|
|
|
* contains the document from which the print preview is to be generated,
|
|
|
|
* which must be in the same process as the browsing context of the frame
|
|
|
|
* loader itself.
|
|
|
|
*
|
|
|
|
* This should only be passed on the first call. It should not be passed
|
|
|
|
* for any subsequent calls that are made to update the existing print
|
|
|
|
* preview document with a new print settings object.
|
2020-09-01 11:00:36 +00:00
|
|
|
* @return A Promise that resolves with a PrintPreviewSuccessInfo on success.
|
|
|
|
*/
|
|
|
|
[ChromeOnly, Throws]
|
|
|
|
Promise<unsigned long> printPreview(nsIPrintSettings aPrintSettings,
|
2021-04-17 18:41:11 +00:00
|
|
|
BrowsingContext? aSourceBrowsingContext);
|
2020-09-01 11:00:36 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Inform the print preview document that we're done with it.
|
|
|
|
*/
|
|
|
|
[ChromeOnly]
|
|
|
|
void exitPrintPreview();
|
|
|
|
|
2017-08-19 07:55:00 +00:00
|
|
|
/**
|
|
|
|
* The element which owns this frame loader.
|
|
|
|
*
|
|
|
|
* For example, if this is a frame loader for an <iframe>, this attribute
|
|
|
|
* returns the iframe element.
|
|
|
|
*/
|
|
|
|
[Pure]
|
|
|
|
readonly attribute Element? ownerElement;
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2019-04-09 20:59:37 +00:00
|
|
|
* Cached childID of the ContentParent owning the RemoteTab in this frame
|
|
|
|
* loader. This can be used to obtain the childID after the RemoteTab died.
|
2017-08-19 07:55:00 +00:00
|
|
|
*/
|
|
|
|
[Pure]
|
|
|
|
readonly attribute unsigned long long childID;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Find out whether the owner content really is a mozbrowser. <xul:browser>
|
|
|
|
* is not considered to be a mozbrowser frame.
|
|
|
|
*/
|
|
|
|
[Pure]
|
|
|
|
readonly attribute boolean ownerIsMozBrowserFrame;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The last known width of the frame. Reading this property will not trigger
|
|
|
|
* a reflow, and therefore may not reflect the current state of things. It
|
|
|
|
* should only be used in asynchronous APIs where values are not guaranteed
|
|
|
|
* to be up-to-date when received.
|
|
|
|
*/
|
|
|
|
[Pure]
|
|
|
|
readonly attribute unsigned long lazyWidth;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The last known height of the frame. Reading this property will not trigger
|
|
|
|
* a reflow, and therefore may not reflect the current state of things. It
|
|
|
|
* should only be used in asynchronous APIs where values are not guaranteed
|
|
|
|
* to be up-to-date when received.
|
|
|
|
*/
|
|
|
|
[Pure]
|
|
|
|
readonly attribute unsigned long lazyHeight;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Is `true` if the frameloader is dead (destroy has been called on it)
|
|
|
|
*/
|
|
|
|
[Pure]
|
|
|
|
readonly attribute boolean isDead;
|
|
|
|
};
|
2017-08-19 21:16:16 +00:00
|
|
|
|
2018-04-09 20:30:33 +00:00
|
|
|
/**
|
|
|
|
* Interface for objects which represent a document that can be
|
|
|
|
* serialized with nsIWebBrowserPersist. This interface is
|
|
|
|
* asynchronous because the actual document can be in another process
|
|
|
|
* (e.g., if this object is a FrameLoader for an out-of-process
|
|
|
|
* frame).
|
|
|
|
*
|
|
|
|
* @see nsIWebBrowserPersistDocumentReceiver
|
|
|
|
* @see nsIWebBrowserPersistDocument
|
|
|
|
* @see nsIWebBrowserPersist
|
|
|
|
*
|
2020-05-13 14:44:03 +00:00
|
|
|
* @param aContext
|
|
|
|
* The browsing context of the subframe we'd like to persist.
|
|
|
|
* If set to nullptr, WebBrowserPersistable will attempt to persist
|
|
|
|
* the top-level document. If the browsing context is for a subframe
|
|
|
|
* that is not held beneath the WebBrowserPersistable, aRecv's onError
|
|
|
|
* method will be called with NS_ERROR_NO_CONTENT.
|
2018-04-09 20:30:33 +00:00
|
|
|
* @param aRecv
|
|
|
|
* The nsIWebBrowserPersistDocumentReceiver is a callback that
|
|
|
|
* will be fired once the document is ready for persisting.
|
|
|
|
*/
|
2019-09-24 15:22:26 +00:00
|
|
|
interface mixin WebBrowserPersistable
|
2017-08-19 21:16:16 +00:00
|
|
|
{
|
|
|
|
[Throws]
|
2020-05-13 14:44:03 +00:00
|
|
|
void startPersistence(BrowsingContext? aContext,
|
2017-08-19 21:16:16 +00:00
|
|
|
nsIWebBrowserPersistDocumentReceiver aRecv);
|
|
|
|
};
|
|
|
|
|
2021-09-21 16:38:53 +00:00
|
|
|
enum PrintPreviewOrientation {
|
|
|
|
"landscape",
|
|
|
|
"portrait",
|
|
|
|
"unspecified"
|
|
|
|
};
|
|
|
|
|
2020-09-01 11:00:36 +00:00
|
|
|
/**
|
|
|
|
* Interface for the object that's used to resolve the Promise returned from
|
|
|
|
* FrameLoader.printPreview() if that method successfully creates the print
|
|
|
|
* preview document/successfully updates it with new settings.
|
|
|
|
*/
|
|
|
|
[GenerateConversionToJS]
|
|
|
|
dictionary PrintPreviewSuccessInfo {
|
|
|
|
/**
|
|
|
|
* The total number of sheets of paper required to print, taking into account
|
|
|
|
* the provided nsIPrintSettings. This takes into account page range
|
|
|
|
* selection, the pages-per-sheet, whether duplex printing is enabled, etc.
|
|
|
|
*/
|
|
|
|
unsigned long sheetCount = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The total number of virtual pages, not taking into account page range
|
|
|
|
* selection, the pages-per-sheet, whether duplex printing is enabled, etc.
|
|
|
|
*/
|
|
|
|
unsigned long totalPageCount = 0;
|
2020-09-02 08:15:35 +00:00
|
|
|
|
2020-12-02 21:48:03 +00:00
|
|
|
/**
|
|
|
|
* Whether the preview is empty because of page range selection.
|
|
|
|
*/
|
|
|
|
boolean isEmpty = false;
|
|
|
|
|
2020-09-02 08:15:35 +00:00
|
|
|
/**
|
2020-12-10 10:52:41 +00:00
|
|
|
* Whether the document or any subdocument has a selection that can be
|
|
|
|
* printed.
|
2020-09-02 08:15:35 +00:00
|
|
|
*/
|
|
|
|
boolean hasSelection = false;
|
2020-12-10 10:52:41 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Whether the previewed document has a selection itself.
|
|
|
|
*/
|
|
|
|
boolean hasSelfSelection = false;
|
2021-09-21 16:38:53 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Specified orientation of the document, or "unspecified".
|
|
|
|
*/
|
|
|
|
PrintPreviewOrientation orientation = "unspecified";
|
2020-09-01 11:00:36 +00:00
|
|
|
};
|
|
|
|
|
2019-09-24 15:22:26 +00:00
|
|
|
FrameLoader includes WebBrowserPersistable;
|