2007-03-22 10:30:00 -07:00
|
|
|
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
|
|
/* ***** BEGIN LICENSE BLOCK *****
|
|
|
|
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
|
|
|
*
|
|
|
|
* 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 mozilla.org code.
|
|
|
|
*
|
|
|
|
* The Initial Developer of the Original Code is
|
|
|
|
* Netscape Communications Corporation.
|
|
|
|
* Portions created by the Initial Developer are Copyright (C) 2002
|
|
|
|
* the Initial Developer. All Rights Reserved.
|
|
|
|
*
|
|
|
|
* Contributor(s):
|
|
|
|
*
|
|
|
|
* Alternatively, the contents of this file may be used under the terms of
|
|
|
|
* either the GNU General Public License Version 2 or later (the "GPL"), or
|
|
|
|
* the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
|
|
|
* in which case the provisions of the GPL or the LGPL are applicable instead
|
|
|
|
* of those above. If you wish to allow use of your version of this file only
|
|
|
|
* under the terms of either the GPL or the LGPL, and not to allow others to
|
|
|
|
* use your version of this file under the terms of the MPL, indicate your
|
|
|
|
* decision by deleting the provisions above and replace them with the notice
|
|
|
|
* and other provisions required by the GPL or the LGPL. If you do not delete
|
|
|
|
* the provisions above, a recipient may use your version of this file under
|
|
|
|
* the terms of any one of the NPL, the GPL or the LGPL.
|
|
|
|
*
|
|
|
|
* ***** END LICENSE BLOCK ***** */
|
|
|
|
|
|
|
|
#ifndef mozView_h_
|
|
|
|
#define mozView_h_
|
|
|
|
|
2011-02-23 10:06:26 -08:00
|
|
|
#include "npapi.h"
|
|
|
|
|
2007-03-22 10:30:00 -07:00
|
|
|
#undef DARWIN
|
|
|
|
#import <Cocoa/Cocoa.h>
|
|
|
|
class nsIWidget;
|
|
|
|
|
2011-05-08 03:19:23 -07:00
|
|
|
namespace mozilla {
|
|
|
|
namespace widget{
|
|
|
|
class TextInputHandler;
|
|
|
|
} // namespace widget
|
|
|
|
} // namespace mozilla
|
|
|
|
|
2007-03-22 10:30:00 -07:00
|
|
|
// A protocol listing all the methods that an object which wants
|
|
|
|
// to live in gecko's widget hierarchy must implement. |nsChildView|
|
|
|
|
// makes assumptions that any NSView with which it comes in contact will
|
|
|
|
// implement this protocol.
|
|
|
|
@protocol mozView
|
|
|
|
|
2011-05-08 03:19:23 -07:00
|
|
|
// aHandler is Gecko's default text input handler: It implements the
|
|
|
|
// NSTextInput protocol to handle key events. Don't make aHandler a
|
|
|
|
// strong reference -- that causes a memory leak.
|
|
|
|
- (void)installTextInputHandler:(mozilla::widget::TextInputHandler*)aHandler;
|
|
|
|
- (void)uninstallTextInputHandler;
|
|
|
|
|
2007-03-22 10:30:00 -07:00
|
|
|
// access the nsIWidget associated with this view. DOES NOT ADDREF.
|
|
|
|
- (nsIWidget*)widget;
|
|
|
|
|
|
|
|
// return a context menu for this view
|
|
|
|
- (NSMenu*)contextMenu;
|
|
|
|
|
|
|
|
// Allows callers to do a delayed invalidate (e.g., if an invalidate
|
|
|
|
// happens during drawing)
|
|
|
|
- (void)setNeedsPendingDisplay;
|
|
|
|
- (void)setNeedsPendingDisplayInRect:(NSRect)invalidRect;
|
|
|
|
|
|
|
|
// called when our corresponding Gecko view goes away
|
|
|
|
- (void)widgetDestroyed;
|
|
|
|
|
2011-03-23 11:46:57 -07:00
|
|
|
- (BOOL)isDragInProgress;
|
|
|
|
|
2011-02-23 10:06:26 -08:00
|
|
|
// Gets the plugin event model for the view
|
|
|
|
- (NPEventModel)pluginEventModel;
|
|
|
|
|
|
|
|
// Checks whether the view is first responder or not
|
|
|
|
- (BOOL)isFirstResponder;
|
|
|
|
|
|
|
|
// Call when you dispatch an event which may cause to open context menu.
|
|
|
|
- (void)maybeInitContextMenuTracking;
|
|
|
|
|
2011-07-20 17:33:16 -07:00
|
|
|
// Checks whether the view is for plugin or not
|
|
|
|
- (BOOL)isPluginView;
|
|
|
|
|
2007-03-22 10:30:00 -07:00
|
|
|
@end
|
|
|
|
|
|
|
|
// An informal protocol implemented by the NSWindow of the host application.
|
|
|
|
//
|
|
|
|
// It's used to prevent re-entrant calls to -makeKeyAndOrderFront: when gecko
|
|
|
|
// focus/activate events propagate out to the embedder's
|
|
|
|
// nsIEmbeddingSiteWindow::SetFocus implementation.
|
|
|
|
@interface NSObject(mozWindow)
|
|
|
|
|
|
|
|
- (BOOL)suppressMakeKeyFront;
|
|
|
|
- (void)setSuppressMakeKeyFront:(BOOL)inSuppress;
|
|
|
|
|
|
|
|
@end
|
|
|
|
|
|
|
|
#endif // mozView_h_
|