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:
@@ -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);
|
||||||
|
@@ -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);
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user