// headers
// ----------------------------------------------------------------------------
-#ifdef __GNUG__
+#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
#pragma implementation "notebookbase.h"
#endif
#include "wx/imaglist.h"
#include "wx/notebook.h"
+#ifdef __GNUWIN32_OLD__
+ #include "wx/msw/gnuwin32/extra.h"
+#endif
+
+#if defined(__WIN95__) && !(defined(__GNUWIN32_OLD__) && !defined(__CYGWIN10__))
+#include "wx/msw/private.h"
+#include <commctrl.h>
+#include "wx/msw/winundef.h"
+#endif
+
// ============================================================================
// implementation
// ============================================================================
// geometry
// ----------------------------------------------------------------------------
-wxSize wxNotebookBase::CalcSizeFromPage(const wxSize& sizePage)
+wxSize wxNotebookBase::CalcSizeFromPage(const wxSize& sizePage) const
{
- // this was just taken from wxNotebookSizer::CalcMin() and is, of
- // course, totally bogus - just like the original code was
+ // this is, of course, totally bogus -- but we must do something by
+ // default because not all ports implement this
wxSize sizeTotal = sizePage;
-
- // Mac has large notebook borders.
if ( HasFlag(wxNB_LEFT) || HasFlag(wxNB_RIGHT) )
{
sizeTotal.x += 90;
-#ifdef __WXMAC__
- sizeTotal.y += 20;
-#else
sizeTotal.y += 10;
-#endif
}
- else
+ else // tabs on top/bottom side
{
-#ifdef __WXMAC__
- sizeTotal.x += 32; // This is OK for Aqua.
-#else
sizeTotal.x += 10;
-#endif
sizeTotal.y += 40;
}
return sizeTotal;
}
+wxSize wxNotebookBase::DoGetBestSize() const
+{
+ wxSize bestSize;
+
+ // iterate over all pages, get the largest width and height
+ const size_t nCount = m_pages.Count();
+ for ( size_t nPage = 0; nPage < nCount; nPage++ )
+ {
+ wxNotebookPage *pPage = m_pages[nPage];
+ wxSize childBestSize(pPage->GetBestSize());
+
+ if ( childBestSize.x > bestSize.x )
+ bestSize.x = childBestSize.x;
+
+ if ( childBestSize.y > bestSize.y )
+ bestSize.y = childBestSize.y;
+ }
+
+ // convert display area to window area, adding the size neccessary for the
+ // tabs
+ return CalcSizeFromPage(bestSize);
+}
+
// ----------------------------------------------------------------------------
// pages management
// ----------------------------------------------------------------------------