handle the buttons with ids specified in SetAffirmative/CancelId() as Ok/Cancel

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@40700 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Vadim Zeitlin
2006-08-20 10:30:26 +00:00
parent 64fb0e2088
commit 551f281b79
2 changed files with 95 additions and 14 deletions

View File

@@ -52,12 +52,16 @@ public:
void SetReturnCode(int returnCode) { m_returnCode = returnCode; } void SetReturnCode(int returnCode) { m_returnCode = returnCode; }
int GetReturnCode() const { return m_returnCode; } int GetReturnCode() const { return m_returnCode; }
// The identifier for the affirmative button // Set the identifier for the affirmative button: this button will close
void SetAffirmativeId(int affirmativeId) { m_affirmativeId = affirmativeId; } // the dialog after validating data and calling TransferDataFromWindow()
void SetAffirmativeId(int affirmativeId);
int GetAffirmativeId() const { return m_affirmativeId; } int GetAffirmativeId() const { return m_affirmativeId; }
// Identifier for Esc key translation // Set identifier for Esc key translation: the button with this id will
void SetEscapeId(int escapeId) { m_escapeId = escapeId; } // close the dialog without doing anything else; special value wxID_NONE
// means to not handle Esc at all while wxID_ANY means to map Esc to
// wxID_CANCEL if present and GetAffirmativeId() otherwise
void SetEscapeId(int escapeId);
int GetEscapeId() const { return m_escapeId; } int GetEscapeId() const { return m_escapeId; }
#if wxUSE_STATTEXT // && wxUSE_TEXTCTRL #if wxUSE_STATTEXT // && wxUSE_TEXTCTRL
@@ -92,6 +96,10 @@ protected:
// the dialog return code // the dialog return code
void EndDialog(int rc); void EndDialog(int rc);
// call Validate() and TransferDataFromWindow() and close dialog with
// wxID_OK return code
void AcceptAndClose();
// The return code from modal dialog // The return code from modal dialog
int m_returnCode; int m_returnCode;
@@ -113,9 +121,9 @@ private:
void OnCloseWindow(wxCloseEvent& event); void OnCloseWindow(wxCloseEvent& event);
// handle the standard buttons // handle the standard buttons
void OnOK(wxCommandEvent& event); void OnAffirmativeButton(wxCommandEvent& event);
void OnApply(wxCommandEvent& event); void OnApply(wxCommandEvent& event);
void OnCancel(wxCommandEvent& event); void OnCancelButton(wxCommandEvent& event);
// update the background colour // update the background colour
void OnSysColourChanged(wxSysColourChangedEvent& event); void OnSysColourChanged(wxSysColourChangedEvent& event);

View File

@@ -99,9 +99,9 @@ private:
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
BEGIN_EVENT_TABLE(wxDialogBase, wxTopLevelWindow) BEGIN_EVENT_TABLE(wxDialogBase, wxTopLevelWindow)
EVT_BUTTON(wxID_OK, wxDialogBase::OnOK) EVT_BUTTON(wxID_OK, wxDialogBase::OnAffirmativeButton)
EVT_BUTTON(wxID_APPLY, wxDialogBase::OnApply) EVT_BUTTON(wxID_APPLY, wxDialogBase::OnApply)
EVT_BUTTON(wxID_CANCEL, wxDialogBase::OnCancel) EVT_BUTTON(wxID_CANCEL, wxDialogBase::OnCancelButton)
EVT_CLOSE(wxDialogBase::OnCloseWindow) EVT_CLOSE(wxDialogBase::OnCloseWindow)
@@ -426,6 +426,82 @@ wxStdDialogButtonSizer *wxDialogBase::CreateStdDialogButtonSizer( long flags )
#endif // wxUSE_BUTTON #endif // wxUSE_BUTTON
// ----------------------------------------------------------------------------
// escape/affirmatives button handling
// ----------------------------------------------------------------------------
void wxDialogBase::AcceptAndClose()
{
if ( Validate() && TransferDataFromWindow() )
{
EndDialog(wxID_OK);
}
}
void wxDialogBase::SetAffirmativeId(int affirmativeId)
{
if ( affirmativeId == m_affirmativeId )
return;
// disconnect the handler for the old affirmative button
if ( m_affirmativeId != wxID_NONE && m_affirmativeId != wxID_OK )
{
if ( !Disconnect
(
m_affirmativeId,
wxEVT_COMMAND_BUTTON_CLICKED,
wxCommandEventHandler(wxDialogBase::OnAffirmativeButton)
) )
{
wxFAIL_MSG( _T("failed to disconnect old ok handler") );
}
}
//else: wxID_OK is always handled
// connect the handler to the new button
if ( affirmativeId != wxID_NONE )
{
Connect(m_affirmativeId,
wxEVT_COMMAND_BUTTON_CLICKED,
wxCommandEventHandler(wxDialogBase::OnAffirmativeButton));
}
//else: no affirmative button
m_affirmativeId = affirmativeId;
}
void wxDialogBase::SetEscapeId(int escapeId)
{
if ( escapeId == m_escapeId )
return;
if ( m_escapeId != wxID_ANY &&
m_escapeId != wxID_CANCEL &&
m_escapeId != wxID_ANY )
{
if ( !Disconnect
(
m_escapeId,
wxEVT_COMMAND_BUTTON_CLICKED,
wxCommandEventHandler(wxDialogBase::OnCancelButton)
) )
{
wxFAIL_MSG( _T("failed to disconnect old cancel handler") );
}
}
//else: wxID_CANCEL is always handled
// connect the handler to the new button
if ( escapeId != wxID_NONE )
{
Connect(m_escapeId,
wxEVT_COMMAND_BUTTON_CLICKED,
wxCommandEventHandler(wxDialogBase::OnCancelButton));
}
m_escapeId = escapeId;
}
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
// event handling stuff // event handling stuff
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
@@ -488,12 +564,9 @@ void wxDialogBase::OnCharHook(wxKeyEvent& event)
event.Skip(); event.Skip();
} }
void wxDialogBase::OnOK(wxCommandEvent& WXUNUSED(event)) void wxDialogBase::OnAffirmativeButton(wxCommandEvent& WXUNUSED(event))
{ {
if ( Validate() && TransferDataFromWindow() ) AcceptAndClose();
{
EndDialog(wxID_OK);
}
} }
void wxDialogBase::OnApply(wxCommandEvent& WXUNUSED(event)) void wxDialogBase::OnApply(wxCommandEvent& WXUNUSED(event))
@@ -504,7 +577,7 @@ void wxDialogBase::OnApply(wxCommandEvent& WXUNUSED(event))
// TODO probably need to disable the Apply button until things change again // TODO probably need to disable the Apply button until things change again
} }
void wxDialogBase::OnCancel(wxCommandEvent& WXUNUSED(event)) void wxDialogBase::OnCancelButton(wxCommandEvent& WXUNUSED(event))
{ {
EndDialog(wxID_CANCEL); EndDialog(wxID_CANCEL);
} }