#include "precompiled.h" /* * wxJavaScript - mdi.cpp * * Copyright (c) 2002-2007 Franky Braem and the wxJavaScript project * * Project Info: http://www.wxjavascript.net or http://wxjs.sourceforge.net * * This library is free software; you can redistribute it and/or modify it * under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation; either version 2.1 of the License, or * (at your option) any later version. * * This library is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public * License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, * USA. * * $Id$ */ #ifndef WX_PRECOMP #include #endif #include "../../common/main.h" #include "../../ext/wxjs_ext.h" #include "../errors.h" #include "../misc/size.h" #include "window.h" #include "mdi.h" #include "frame.h" #include "toolbar.h" using namespace wxjs::gui; wxToolBar* MDIParentFrame::OnCreateToolBar(long style, wxWindowID id, const wxString& name) { ToolBar *tbar = new ToolBar(); tbar->Create(this, id, wxDefaultPosition, wxDefaultSize, style, name); return tbar; } /*** * gui * control/mdiparent * * An MDI (Multiple Document Interface) parent frame is a window which can * contain MDI child frames in its own 'desktop'. It is a convenient way to * avoid window clutter, and is used in many popular Windows applications, * such as Microsoft Word(TM). * */ WXJS_INIT_CLASS(MDIParentFrame, "wxMDIParentFrame", 3) bool MDIParentFrame::AddProperty(wxMDIParentFrame *p, JSContext* WXUNUSED(cx), JSObject* WXUNUSED(obj), const wxString &prop, jsval* WXUNUSED(vp)) { if ( WindowEventHandler::ConnectEvent(p, prop, true) ) return true; FrameEventHandler::ConnectEvent(p, prop, true); return true; } bool MDIParentFrame::DeleteProperty(wxMDIParentFrame *p, JSContext* WXUNUSED(cx), JSObject* WXUNUSED(obj), const wxString &prop) { if ( WindowEventHandler::ConnectEvent(p, prop, false) ) return true; FrameEventHandler::ConnectEvent(p, prop, false); return true; } /*** * * * * The parent window * The window ID * The title of the window * * * * * * Creates a new MDI parent frame. * * */ wxMDIParentFrame* MDIParentFrame::Construct(JSContext* cx, JSObject* obj, uintN argc, jsval *argv, bool WXUNUSED(constructing)) { MDIParentFrame *p = new MDIParentFrame(); SetPrivate(cx, obj, p); if ( argc > 0 ) { jsval rval; if ( ! create(cx, obj, argc, argv, &rval) ) return NULL; } return p; } /*** * * * The active MDI child, if there is one. * * */ WXJS_BEGIN_PROPERTY_MAP(MDIParentFrame) WXJS_READONLY_PROPERTY(P_ACTIVE_CHILD, "activeChild") WXJS_END_PROPERTY_MAP() bool MDIParentFrame::GetProperty(wxMDIParentFrame *p, JSContext *cx, JSObject *obj, int id, jsval *vp) { switch(id) { case P_ACTIVE_CHILD: { wxMDIChildFrame *child = p->GetActiveChild(); if ( child != NULL ) { JavaScriptClientData *data = dynamic_cast(child->GetClientObject()); if ( data ) { *vp = OBJECT_TO_JSVAL(data->GetObject()); } } } } return true; } WXJS_BEGIN_METHOD_MAP(MDIParentFrame) WXJS_METHOD("create", create, 3) WXJS_METHOD("activateNext", activateNext, 0) WXJS_METHOD("activatePrevious", activatePrevious, 0) WXJS_METHOD("arrangeIcons", arrangeIcons, 0) WXJS_METHOD("cascade", cascade, 0) WXJS_END_METHOD_MAP() /*** * * * The parent window * The window ID * The title of the window * * * * * * Sets a pixel to a particular color. * * */ JSBool MDIParentFrame::create(JSContext* cx, JSObject* obj, uintN argc, jsval* argv, jsval* rval) { wxMDIParentFrame *p = GetPrivate(cx, obj); *rval = JSVAL_FALSE; int style = wxDEFAULT_FRAME_STYLE | wxVSCROLL | wxHSCROLL; const wxPoint* pos = &wxDefaultPosition; const wxSize* size = &wxDefaultSize; if ( argc > 6 ) { argc = 6; } switch(argc) { case 6: if ( ! FromJS(cx, argv[5], style) ) { JS_ReportError(cx, WXJS_INVALID_ARG_TYPE, 6, "Integer"); return JS_FALSE; } case 5: size = Size::GetPrivate(cx, argv[4]); if ( size == NULL ) { JS_ReportError(cx, WXJS_INVALID_ARG_TYPE, 5, "wxSize"); return JS_FALSE; } case 4: pos = wxjs::ext::GetPoint(cx, argv[3]); if ( pos == NULL ) { JS_ReportError(cx, WXJS_INVALID_ARG_TYPE, 4, "wxPoint"); return JS_FALSE; } default: { wxString title; wxWindow *parent = NULL; int id = -1; FromJS(cx, argv[2], title); if ( ! FromJS(cx, argv[1], id) ) { JS_ReportError(cx, WXJS_INVALID_ARG_TYPE, 2, "wxPoint"); return JS_FALSE; } if ( ! JSVAL_IS_NULL(argv[0]) ) { parent = Window::GetPrivate(cx, argv[0]); if ( parent == NULL ) { JS_ReportError(cx, WXJS_INVALID_ARG_TYPE, 1, "wxWindow"); return JS_FALSE; } } if ( p->Create(parent, id, title, *pos, *size, style) ) { *rval = JSVAL_TRUE; p->SetClientObject(new JavaScriptClientData(cx, obj, true, false)); p->Connect(wxID_ANY, wxID_ANY, wxEVT_COMMAND_MENU_SELECTED, wxCommandEventHandler(FrameEventHandler::OnMenu)); } } } return JS_TRUE; } /*** * * * * Activates the MDI child following the currently active one. * * */ JSBool MDIParentFrame::activateNext(JSContext* cx, JSObject* obj, uintN WXUNUSED(argc), jsval* WXUNUSED(argv), jsval* WXUNUSED(rval)) { wxMDIParentFrame *p = GetPrivate(cx, obj); p->ActivateNext(); return JS_TRUE; } /*** * * * * Activates the MDI child preceding the currently active one. * * */ JSBool MDIParentFrame::activatePrevious(JSContext* cx, JSObject* obj, uintN WXUNUSED(argc), jsval* WXUNUSED(argv), jsval* WXUNUSED(rval)) { wxMDIParentFrame *p = GetPrivate(cx, obj); p->ActivatePrevious(); return JS_TRUE; } /*** * * * * Arranges any iconized (minimized) MDI child windows. * * */ JSBool MDIParentFrame::arrangeIcons(JSContext* cx, JSObject* obj, uintN WXUNUSED(argc), jsval* WXUNUSED(argv), jsval* WXUNUSED(rval)) { wxMDIParentFrame *p = GetPrivate(cx, obj); p->ArrangeIcons(); return JS_TRUE; } /*** * * * * Arranges the MDI child windows in a cascade. * * */ JSBool MDIParentFrame::cascade(JSContext* cx, JSObject* obj, uintN WXUNUSED(argc), jsval* WXUNUSED(argv), jsval* WXUNUSED(rval)) { wxMDIParentFrame *p = GetPrivate(cx, obj); p->Cascade(); return JS_TRUE; } /*** * * * * * * Tiles the MDI child windows either horizontally or vertically. * Currently only implemented for MSW, does nothing under the other platforms. * * */ JSBool MDIParentFrame::tile(JSContext* cx, JSObject* obj, uintN argc, jsval* argv, jsval* WXUNUSED(rval)) { wxMDIParentFrame *p = GetPrivate(cx, obj); int orient = wxHORIZONTAL; if ( argc > 0 ) { if ( ! FromJS(cx, argv[0], orient) ) { return JS_TRUE; } } p->Tile((wxOrientation) orient); return JS_TRUE; }