| /* |
| * Copyright (C) 2005, 2006, 2007, 2008, 2009, 2010, 2011 Apple Inc. All rights reserved. |
| * |
| * Redistribution and use in source and binary forms, with or without |
| * modification, are permitted provided that the following conditions |
| * are met: |
| * |
| * 1. Redistributions of source code must retain the above copyright |
| * notice, this list of conditions and the following disclaimer. |
| * 2. Redistributions in binary form must reproduce the above copyright |
| * notice, this list of conditions and the following disclaimer in the |
| * documentation and/or other materials provided with the distribution. |
| * 3. Neither the name of Apple Computer, Inc. ("Apple") nor the names of |
| * its contributors may be used to endorse or promote products derived |
| * from this software without specific prior written permission. |
| * |
| * THIS SOFTWARE IS PROVIDED BY APPLE AND ITS CONTRIBUTORS "AS IS" AND ANY |
| * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED |
| * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE |
| * DISCLAIMED. IN NO EVENT SHALL APPLE OR ITS CONTRIBUTORS BE LIABLE FOR ANY |
| * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES |
| * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; |
| * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND |
| * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
| * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF |
| * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| */ |
| |
| // This header contains the WebFrame SPI. |
| |
| #import <WebKit/WebFrame.h> |
| #import <JavaScriptCore/JSBase.h> |
| |
| #if !defined(ENABLE_NETSCAPE_PLUGIN_API) |
| #define ENABLE_NETSCAPE_PLUGIN_API 1 |
| #endif |
| |
| @class DOMDocumentFragment; |
| @class DOMNode; |
| @class DOMRange; |
| @class WebScriptObject; |
| @class WebScriptWorld; |
| |
| // Keys for accessing the values in the page cache dictionary. |
| extern NSString *WebPageCacheEntryDateKey; |
| extern NSString *WebPageCacheDataSourceKey; |
| extern NSString *WebPageCacheDocumentViewKey; |
| |
| extern NSString *WebFrameMainDocumentError; |
| extern NSString *WebFrameHasPlugins; |
| extern NSString *WebFrameHasUnloadListener; |
| extern NSString *WebFrameUsesDatabases; |
| extern NSString *WebFrameUsesGeolocation; |
| extern NSString *WebFrameUsesApplicationCache; |
| extern NSString *WebFrameCanSuspendActiveDOMObjects; |
| |
| typedef enum { |
| WebFrameLoadTypeStandard, |
| WebFrameLoadTypeBack, |
| WebFrameLoadTypeForward, |
| WebFrameLoadTypeIndexedBackForward, // a multi-item hop in the backforward list |
| WebFrameLoadTypeReload, |
| WebFrameLoadTypeReloadAllowingStaleData, |
| WebFrameLoadTypeSame, // user loads same URL again (but not reload button) |
| WebFrameLoadTypeInternal, // maps to WebCore::FrameLoadTypeRedirectWithLockedBackForwardList |
| WebFrameLoadTypeReplace, |
| WebFrameLoadTypeReloadFromOrigin, |
| WebFrameLoadTypeBackWMLDeckNotAccessible |
| } WebFrameLoadType; |
| |
| @interface WebFrame (WebPrivate) |
| |
| - (BOOL)_isDescendantOfFrame:(WebFrame *)frame; |
| - (void)_setShouldCreateRenderers:(BOOL)shouldCreateRenderers; |
| - (NSColor *)_bodyBackgroundColor; |
| - (BOOL)_isFrameSet; |
| - (BOOL)_firstLayoutDone; |
| - (WebFrameLoadType)_loadType; |
| |
| // These methods take and return NSRanges based on the root editable element as the positional base. |
| // This fits with AppKit's idea of an input context. These methods are slow compared to their DOMRange equivalents. |
| // You should use WebView's selectedDOMRange and setSelectedDOMRange whenever possible. |
| - (NSRange)_selectedNSRange; |
| - (void)_selectNSRange:(NSRange)range; |
| |
| - (BOOL)_isDisplayingStandaloneImage; |
| |
| - (unsigned)_pendingFrameUnloadEventCount; |
| |
| - (void)_setIsDisconnected:(bool)isDisconnected; |
| - (void)_setExcludeFromTextSearch:(bool)exclude; |
| |
| #if ENABLE_NETSCAPE_PLUGIN_API |
| - (void)_recursive_resumeNullEventsForAllNetscapePlugins; |
| - (void)_recursive_pauseNullEventsForAllNetscapePlugins; |
| #endif |
| |
| - (NSString *)_stringByEvaluatingJavaScriptFromString:(NSString *)string withGlobalObject:(JSObjectRef)globalObject inScriptWorld:(WebScriptWorld *)world; |
| - (JSGlobalContextRef)_globalContextForScriptWorld:(WebScriptWorld *)world; |
| |
| // Pause a given CSS animation or transition on the target node at a specific time. |
| // If the animation or transition is already paused, it will update its pause time. |
| // This method is only intended to be used for testing the CSS animation and transition system. |
| - (BOOL)_pauseAnimation:(NSString*)name onNode:(DOMNode *)node atTime:(NSTimeInterval)time; |
| - (BOOL)_pauseTransitionOfProperty:(NSString*)name onNode:(DOMNode*)node atTime:(NSTimeInterval)time; |
| |
| // Pause a given SVG animation on the target node at a specific time. |
| // This method is only intended to be used for testing the SVG animation system. |
| - (BOOL)_pauseSVGAnimation:(NSString*)elementId onSMILNode:(DOMNode *)node atTime:(NSTimeInterval)time; |
| |
| // Returns the total number of currently running animations (includes both CSS transitions and CSS animations). |
| - (unsigned)_numberOfActiveAnimations; |
| |
| // Suspend and resume animations (includes both CSS transitions and CSS animations). |
| - (void)_suspendAnimations; |
| - (void)_resumeAnimations; |
| |
| - (void)_replaceSelectionWithFragment:(DOMDocumentFragment *)fragment selectReplacement:(BOOL)selectReplacement smartReplace:(BOOL)smartReplace matchStyle:(BOOL)matchStyle; |
| - (void)_replaceSelectionWithText:(NSString *)text selectReplacement:(BOOL)selectReplacement smartReplace:(BOOL)smartReplace; |
| - (void)_replaceSelectionWithMarkupString:(NSString *)markupString baseURLString:(NSString *)baseURLString selectReplacement:(BOOL)selectReplacement smartReplace:(BOOL)smartReplace; |
| |
| - (void)_smartInsertForString:(NSString *)pasteString replacingRange:(DOMRange *)rangeToReplace beforeString:(NSString **)beforeString afterString:(NSString **)afterString; |
| |
| - (NSMutableDictionary *)_cacheabilityDictionary; |
| |
| - (BOOL)_allowsFollowingLink:(NSURL *)URL; |
| |
| // Sets whether the scrollbars, if any, should be shown inside the document's border |
| // (thus overlapping some content) or outside the webView's border (default behavior). |
| // Changing this flag changes the size of the contentView and maintains the size of the frameView. |
| - (void)setAllowsScrollersToOverlapContent:(BOOL)flag; |
| |
| // Sets if the scrollbar is always hidden, regardless of other scrollbar visibility settings. |
| // This does not affect the scrollability of the document. |
| - (void)setAlwaysHideHorizontalScroller:(BOOL)flag; |
| - (void)setAlwaysHideVerticalScroller:(BOOL)flag; |
| |
| // Sets the name presented to accessibility clients for the web area object. |
| - (void)setAccessibleName:(NSString *)name; |
| |
| - (NSString*)_layerTreeAsText; |
| |
| // Returns whether there is a spelling marker in the specified range of the focused node. |
| - (BOOL)hasSpellingMarker:(int)location length:(int)length; |
| |
| - (BOOL)hasGrammarMarker:(int)from length:(int)length; |
| |
| // The top of the accessibility tree. |
| - (id)accessibilityRoot; |
| |
| // Clears frame opener. This is executed between layout tests runs |
| - (void)_clearOpener; |
| |
| // Printing. |
| - (NSArray *)_computePageRectsWithPrintScaleFactor:(float)printWidthScaleFactor pageSize:(NSSize)pageSize; |
| |
| @end |