зеркало из https://github.com/mozilla/pjs.git
Fixes for switching focus on Ender toolbars
This commit is contained in:
Родитель
c3feb17fd2
Коммит
e326156119
|
@ -121,6 +121,9 @@ extern int XP_EDT_DRAG_TABLE;
|
|||
|
||||
extern void fe_MailComposeDocumentLoaded(MWContext*);
|
||||
extern void fe_HackEditorNotifyToolbarUpdated(MWContext* context);
|
||||
#ifdef ENDER
|
||||
extern void XFE_EmbeddedEditorViewFocus(MWContext*);
|
||||
#endif /* ENDER */
|
||||
|
||||
static void
|
||||
fe_Bell(MWContext* context)
|
||||
|
@ -6161,9 +6164,9 @@ void xfe_GetShiftAndCtrl(XEvent* event, Boolean* shiftP, Boolean* ctrlP)
|
|||
* selected cell (if any), which means this code would have to live in
|
||||
* EditorView.cpp. But that means a lot of code change which I won't
|
||||
* be able to check in for quite some time due to the stability freeze.
|
||||
* So as a TEMPORARY measure, they're implemented as statics and we
|
||||
* So as a temporary measure, they're implemented as statics and we
|
||||
* count on the unliklihood of selection-extending in multiple windows
|
||||
* at once. (Safe for drag-select, unsafe for shift-ctrl-click.) Yuck.
|
||||
* at once. (Safe for drag-select, less so for shift-ctrl-click.) Yuck.
|
||||
*/
|
||||
static LO_Element* edElement = 0;
|
||||
static XP_Bool crossedCellBoundary = FALSE;
|
||||
|
@ -6369,7 +6372,16 @@ fe_EditorGrabFocus(MWContext* context, XEvent *event)
|
|||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
#ifdef ENDER
|
||||
/* See if we're in an HTML textarea -- if so, we need to fiddle
|
||||
* with toolbars to indicate which area has focus.
|
||||
*/
|
||||
if (EDITOR_CONTEXT_DATA(context)->embedded)
|
||||
XFE_EmbeddedEditorViewFocus(context);
|
||||
#endif /* ENDER */
|
||||
edElement = 0;
|
||||
}
|
||||
crossedCellBoundary = FALSE;
|
||||
}
|
||||
|
||||
|
|
|
@ -448,9 +448,13 @@ XFE_BrowserFrame::showEditorToolbar(XFE_View* view)
|
|||
{
|
||||
if (m_editorStyleToolbar)
|
||||
{
|
||||
m_editorStyleToolbar->show();
|
||||
if (view)
|
||||
m_editorStyleToolbar->setCommandDispatcher(view);
|
||||
m_editorStyleToolbar->update();
|
||||
// XXX Need to find a way to reset the toolbar to reflect
|
||||
// what's selected in the current view. This doesn't do it:
|
||||
//m_editorStyleToolbar->updateCommand(0);
|
||||
m_editorStyleToolbar->show();
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -101,6 +101,12 @@ XFE_Command::isSlow()
|
|||
return TRUE; // of course
|
||||
}
|
||||
|
||||
XP_Bool
|
||||
XFE_Command::isViewCommand()
|
||||
{
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
XP_Bool
|
||||
XFE_Command::isEnabled(XFE_View*, XFE_CommandInfo*)
|
||||
{
|
||||
|
@ -243,6 +249,12 @@ frame_to_view(XFE_Command* command, XFE_Frame* frame, XFE_CommandInfo*)
|
|||
return NULL;
|
||||
}
|
||||
|
||||
XP_Bool
|
||||
XFE_ViewCommand::isViewCommand()
|
||||
{
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
XP_Bool
|
||||
XFE_ViewCommand::isEnabled(XFE_Frame* frame, XFE_CommandInfo* info)
|
||||
{
|
||||
|
|
|
@ -22,7 +22,7 @@
|
|||
* EditorToolbar.cpp --- Toolbar for Editor and HTML Mail Compose.
|
||||
*
|
||||
* Created: David Williams <djw@netscape.com>, Feb-7-1997
|
||||
* RCSID: "$Id: EditorToolbar.cpp,v 3.2 1998-08-13 21:50:58 akkana%netscape.com Exp $"
|
||||
* RCSID: "$Id: EditorToolbar.cpp,v 3.3 1998-08-21 23:02:19 akkana%netscape.com Exp $"
|
||||
*
|
||||
*----------------------------------------------------------------------------
|
||||
*/
|
||||
|
@ -269,7 +269,15 @@ XFE_ActionMenuItem::getCommandDispatcher()
|
|||
void XFE_ActionMenuItem::doCommand(XFE_CommandInfo* info)
|
||||
{
|
||||
if (m_cmd_handler != NULL)
|
||||
{
|
||||
if (m_cmd_handler->isViewCommand())
|
||||
{
|
||||
XFE_Component* dispatcher = getCommandDispatcher();
|
||||
if (dispatcher && dispatcher->isClassOf("View"))
|
||||
((XFE_ViewCommand*)m_cmd_handler)->setView((XFE_View*)dispatcher);
|
||||
}
|
||||
m_cmd_handler->doCommand(getParentFrame(), info);
|
||||
}
|
||||
else
|
||||
{
|
||||
XFE_Component* dispatcher = getCommandDispatcher();
|
||||
|
|
|
@ -74,6 +74,23 @@ XFE_EmbeddedEditorView::~XFE_EmbeddedEditorView()
|
|||
parent_view->removeView(this);
|
||||
}
|
||||
|
||||
extern "C" XFE_Frame*
|
||||
fe_getFrameFromContext(MWContext* context)
|
||||
{
|
||||
XFE_Frame *frame = 0;
|
||||
while (context)
|
||||
{
|
||||
frame = ViewGlue_getFrame(context);
|
||||
if (frame)
|
||||
return frame;
|
||||
if (context->grid_parent)
|
||||
context = context->grid_parent;
|
||||
else
|
||||
return 0;
|
||||
}
|
||||
return 0; /* warning control -- shouldn't actually get here */
|
||||
}
|
||||
|
||||
extern "C" Widget
|
||||
XFE_CreateEmbeddedEditor(Widget parent, int32 cols, int32 rows,
|
||||
const char *default_url, MWContext *context)
|
||||
|
@ -81,7 +98,10 @@ XFE_CreateEmbeddedEditor(Widget parent, int32 cols, int32 rows,
|
|||
Widget w;
|
||||
MWContext *new_context;
|
||||
|
||||
XFE_Frame *frame = (XFE_Frame *)CONTEXT_DATA(context)->view;
|
||||
XFE_Frame *frame = fe_getFrameFromContext(context);
|
||||
XP_ASSERT(frame);
|
||||
if (!frame)
|
||||
return 0;
|
||||
XFE_View *view = frame->widgetToView(parent);
|
||||
|
||||
new_context = fe_CreateNewContext(MWContextEditor, CONTEXT_WIDGET(context),
|
||||
|
@ -131,9 +151,6 @@ XFE_CreateEmbeddedEditor(Widget parent, int32 cols, int32 rows,
|
|||
cols2pixels = overall.width;
|
||||
rows2pixels = ascent + descent;
|
||||
/* could also use CONTEXT_DATA(context)->line_height */
|
||||
#ifdef DEBUG_akkana
|
||||
printf("Read the font: %d x %d\n", rows2pixels, cols2pixels);
|
||||
#endif
|
||||
}
|
||||
else
|
||||
{
|
||||
|
@ -172,10 +189,31 @@ XFE_CreateEmbeddedEditor(Widget parent, int32 cols, int32 rows,
|
|||
return(w);
|
||||
}
|
||||
|
||||
extern "C" void
|
||||
XFE_EmbeddedEditorViewFocus(MWContext* context)
|
||||
{
|
||||
XFE_Frame *frame = fe_getFrameFromContext(context);
|
||||
XFE_EmbeddedEditorView* eev = 0;
|
||||
XP_ASSERT(frame);
|
||||
if (frame)
|
||||
eev = (XFE_EmbeddedEditorView*)frame->widgetToView(CONTEXT_DATA(context)->drawing_area);
|
||||
XP_ASSERT(eev);
|
||||
if (!eev)
|
||||
return;
|
||||
XFE_BrowserFrame* bf = (XFE_BrowserFrame*)frame;
|
||||
if (bf)
|
||||
{
|
||||
bf->showEditorToolbar(eev);
|
||||
}
|
||||
}
|
||||
|
||||
extern "C" MWContext *
|
||||
XFE_GetEmbeddedEditorContext(Widget w, MWContext *context)
|
||||
{
|
||||
XFE_Frame *frame = (XFE_Frame *)CONTEXT_DATA(context)->view;
|
||||
XFE_Frame *frame = fe_getFrameFromContext(context);
|
||||
XP_ASSERT(frame);
|
||||
if (!frame)
|
||||
return 0;
|
||||
XFE_View *view = frame->widgetToView(w);
|
||||
|
||||
return((view) ? view->getContext() : 0);
|
||||
|
@ -184,7 +222,10 @@ XFE_GetEmbeddedEditorContext(Widget w, MWContext *context)
|
|||
extern "C" void
|
||||
XFE_DestroyEmbeddedEditor(Widget w, MWContext *context)
|
||||
{
|
||||
XFE_Frame *frame = (XFE_Frame *)CONTEXT_DATA(context)->view;
|
||||
XFE_Frame *frame = fe_getFrameFromContext(context);
|
||||
XP_ASSERT(frame);
|
||||
if (!frame)
|
||||
return;
|
||||
XFE_View *view = frame->widgetToView(w);
|
||||
MWContext *vcontext;
|
||||
|
||||
|
|
Загрузка…
Ссылка в новой задаче