]> git.saurik.com Git - wxWidgets.git/blame - src/generic/propdlg.cpp
adding OS level Window Menu by default
[wxWidgets.git] / src / generic / propdlg.cpp
CommitLineData
3c9287bb
JS
1/////////////////////////////////////////////////////////////////////////////
2// Name: propdlg.cpp
3// Purpose: wxPropertySheetDialog
4// Author: Julian Smart
5// Modified by:
6// Created: 2005-03-12
7// RCS-ID: $Id$
8// Copyright: (c) Julian Smart
9// Licence: wxWindows licence
10/////////////////////////////////////////////////////////////////////////////
11
12#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
13#pragma implementation "propdlg.h"
14#endif
15
16// For compilers that support precompilation, includes "wx.h".
17#include "wx/wxprec.h"
18
19#ifdef __BORLANDC__
20#pragma hdrstop
21#endif
22
23#include "wx/defs.h"
24
25#ifndef WX_PRECOMP
26 #include "wx/button.h"
27 #include "wx/sizer.h"
28 #include "wx/intl.h"
29 #include "wx/log.h"
30 #include "wx/msgdlg.h"
31#endif
32
3be8026d 33#include "wx/bookctrl.h"
3c9287bb
JS
34#include "wx/generic/propdlg.h"
35
36//-----------------------------------------------------------------------------
37// wxPropertySheetDialog
38//-----------------------------------------------------------------------------
39
40IMPLEMENT_DYNAMIC_CLASS(wxPropertySheetDialog, wxDialog)
41
c9ab63f4
JS
42BEGIN_EVENT_TABLE(wxPropertySheetDialog, wxDialog)
43 EVT_ACTIVATE(wxPropertySheetDialog::OnActivate)
44END_EVENT_TABLE()
45
3c9287bb
JS
46bool wxPropertySheetDialog::Create(wxWindow* parent, wxWindowID id, const wxString& title,
47 const wxPoint& pos, const wxSize& sz, long style,
48 const wxString& name)
49{
ac5f5c9e 50 if (!wxDialog::Create(parent, id, title, pos, sz, style|wxCLIP_CHILDREN, name))
3c9287bb
JS
51 return false;
52
53 wxBoxSizer *topSizer = new wxBoxSizer( wxVERTICAL );
54 SetSizer(topSizer);
55
56 // This gives more space around the edges
57 m_innerSizer = new wxBoxSizer( wxVERTICAL );
58
95ba86d7 59 int extraSpace = 2;
0906c58d 60#if defined(__SMARTPHONE__) || defined(__POCKETPC__)
3c9287bb
JS
61 extraSpace=0;
62#endif
63 topSizer->Add(m_innerSizer, 1, wxGROW|wxALL, extraSpace);
64
65 m_bookCtrl = CreateBookCtrl();
66 AddBookCtrl(m_innerSizer);
67
68 return true;
69}
70
71void wxPropertySheetDialog::Init()
72{
73 m_innerSizer = NULL;
74 m_bookCtrl = NULL;
75}
76
77// Layout the dialog, to be called after pages have been created
78void wxPropertySheetDialog::LayoutDialog()
79{
0906c58d 80#if !defined(__SMARTPHONE__) && !defined(__POCKETPC__)
3c9287bb 81 GetSizer()->Fit(this);
95ba86d7 82 GetSizer()->SetSizeHints(this);
3c9287bb
JS
83 Centre(wxBOTH);
84#endif
c9ab63f4
JS
85#if defined(__SMARTPHONE__)
86 if (m_bookCtrl)
87 m_bookCtrl->SetFocus();
88#endif
3c9287bb
JS
89}
90
91// Creates the buttons, if any
92void wxPropertySheetDialog::CreateButtons(int flags)
93{
53bc3491 94#if defined(__SMARTPHONE__)
0906c58d
JS
95 // TODO: create a right-click menu with all the other IDs available.
96 // Perhaps that could be embedded in CreateButtonSizer() directly.
53bc3491 97 SetRightMenu(wxID_CANCEL);
3be8026d 98 SetLeftMenu(wxID_OK);
9e7efd53 99 wxUnusedVar(flags);
0906c58d
JS
100#elif defined(__POCKETPC__)
101 // Do nothing
9e7efd53 102 wxUnusedVar(flags);
0906c58d 103#else
3c9287bb 104 wxSizer* sizer = CreateButtonSizer(flags);
95ba86d7
JS
105 m_innerSizer->Add( sizer, 0, wxGROW|wxALIGN_CENTER_VERTICAL|wxTOP|wxBOTTOM|wxLEFT|wxRIGHT, 2);
106 m_innerSizer->AddSpacer(2);
3c9287bb
JS
107#endif
108}
109
110// Creates the book control
111wxBookCtrlBase* wxPropertySheetDialog::CreateBookCtrl()
112{
ac5f5c9e 113 int style = wxCLIP_CHILDREN;
3be8026d 114#if defined(__POCKETPC__) && wxUSE_NOTEBOOK
3c9287bb 115 style |= wxNB_BOTTOM|wxNB_FLAT;
3be8026d
JS
116#else
117 style |= wxBC_DEFAULT;
3c9287bb 118#endif
3be8026d 119 return new wxBookCtrl(this, wxID_ANY, wxDefaultPosition, wxDefaultSize, style );
3c9287bb
JS
120}
121
122// Adds the book control to the inner sizer.
123void wxPropertySheetDialog::AddBookCtrl(wxSizer* sizer)
124{
3be8026d 125#if defined(__POCKETPC__) && wxUSE_NOTEBOOK
3c9287bb
JS
126 // The book control has to be sized larger than the dialog because of a border bug
127 // in WinCE
0906c58d
JS
128 int borderSize = -2;
129 sizer->Add( m_bookCtrl, 1, wxGROW|wxALIGN_CENTER_VERTICAL|wxLEFT|wxTOP|wxRIGHT, borderSize );
3c9287bb
JS
130#else
131 sizer->Add( m_bookCtrl, 1, wxGROW|wxALIGN_CENTER_VERTICAL|wxALL, 5 );
132#endif
133}
134
c9ab63f4
JS
135void wxPropertySheetDialog::OnActivate(wxActivateEvent& event)
136{
137#if defined(__SMARTPHONE__)
138 // Attempt to focus the choice control: not yet working, but might
139 // be a step in the right direction. OnActivate overrides the default
140 // handler in toplevel.cpp that sets the focus for the first child of
141 // of the dialog (the choicebook).
142 if (event.GetActive())
143 {
144 wxChoicebook* choiceBook = wxDynamicCast(GetBookCtrl(), wxChoicebook);
145 if (choiceBook)
146 choiceBook->SetFocus();
147 }
148 else
149#endif
150 event.Skip();
151}
152