X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/9a83f860948059b0273b5cc6d9e43fadad3ebfca..c7ea5a0c7edbdb777640e2613bfaac5f649b3340:/src/generic/datectlg.cpp diff --git a/src/generic/datectlg.cpp b/src/generic/datectlg.cpp index 0d67a6c6ec..6ea3d01c4a 100644 --- a/src/generic/datectlg.cpp +++ b/src/generic/datectlg.cpp @@ -4,7 +4,6 @@ // Author: Andreas Pflug // Modified by: // Created: 2005-01-19 -// RCS-ID: $Id$ // Copyright: (c) 2005 Andreas Pflug // Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// @@ -28,15 +27,18 @@ #ifndef WX_PRECOMP #include "wx/dialog.h" #include "wx/dcmemory.h" + #include "wx/intl.h" #include "wx/panel.h" #include "wx/textctrl.h" #include "wx/valtext.h" #endif +#include "wx/calctrl.h" +#include "wx/combo.h" + #include "wx/datectrl.h" #include "wx/generic/datectrl.h" - // ---------------------------------------------------------------------------- // constants // ---------------------------------------------------------------------------- @@ -127,7 +129,7 @@ public: if ( !s.empty() ) { - pDt->ParseFormat(s.c_str(), m_format); + pDt->ParseFormat(s, m_format); if ( !pDt->IsValid() ) return false; } @@ -202,66 +204,19 @@ private: return m_combo->GetParent()->HasFlag(flag); } - // it expands "%x" format and changes %y to %Y if wxDP_SHOWCENTURY flag - // is given. If the locale format can't be easily analyzed (e.g. when - // the month is given as a name, not number), "%x" is returned + // Return the format to be used for the dates shown by the control. This + // functions honours wxDP_SHOWCENTURY flag. wxString GetLocaleDateFormat() const { - wxString x_format(wxT("%x")); - wxString fmt; - int year_cnt = 0, month_cnt = 0, day_cnt = 0; - - wxDateTime dt; - dt.ParseFormat(wxT("2003-10-17"), wxT("%Y-%m-%d")); - wxString str(dt.Format(x_format)); - - const wxChar *p = str.c_str(); - while ( *p ) - { - if (wxIsdigit(*p)) - { - int n=wxAtoi(p); - if (n == dt.GetDay()) - { - fmt.Append(wxT("%d")); - day_cnt++; - p += 2; - } - else if (n == (int)dt.GetMonth()+1) - { - fmt.Append(wxT("%m")); - month_cnt++; - p += 2; - } - else if (n == dt.GetYear()) - { - fmt.Append(wxT("%Y")); - year_cnt++; - p += 4; - } - else if (n == (dt.GetYear() % 100)) - { - if ( HasDPFlag(wxDP_SHOWCENTURY) ) - fmt.Append(wxT("%Y")); - else - fmt.Append(wxT("%y")); - year_cnt++; - p += 2; - } - else - // this shouldn't happen - return x_format; - } - else { - fmt.Append(*p); - p++; - } - } - - if (year_cnt == 1 && month_cnt == 1 && day_cnt == 1) - return fmt; - - return x_format; +#if wxUSE_INTL + wxString fmt = wxLocale::GetInfo(wxLOCALE_SHORT_DATE_FMT); + if ( HasDPFlag(wxDP_SHOWCENTURY) ) + fmt.Replace("%y", "%Y"); + + return fmt; +#else // !wxUSE_INTL + return wxT("x"); +#endif // wxUSE_INTL/!wxUSE_INTL } bool SetFormat(const wxString& fmt) @@ -423,7 +378,27 @@ bool wxDatePickerCtrlGeneric::Destroy() wxSize wxDatePickerCtrlGeneric::DoGetBestSize() const { - return m_combo->GetBestSize(); + // A better solution would be to use a custom text control that would have + // the best size determined by the current date format and let m_combo take + // care of the best size computation, but this isn't easily possible with + // wxComboCtrl currently, so we compute our own best size here instead even + // if this means adding some extra margins to account for text control + // borders, space between it and the button and so on. + wxSize size = m_combo->GetButtonSize(); + + wxTextCtrl* const text = m_combo->GetTextCtrl(); + size.x += text->GetTextExtent(text->GetValue()).x; + size.x += 2*text->GetCharWidth(); // This is the margin mentioned above. + + return size; +} + +wxWindowList wxDatePickerCtrlGeneric::GetCompositeWindowParts() const +{ + wxWindowList parts; + parts.push_back(m_combo); + parts.push_back(m_popup); + return parts; } // ----------------------------------------------------------------------------