#include "wx/xrc/xh_treebk.h"
+#ifndef WX_PRECOMP
+ #include "wx/log.h"
+#endif
+
#include "wx/treebook.h"
#include "wx/imaglist.h"
-#include "wx/log.h"
+
+#include "wx/xml/xml.h"
IMPLEMENT_DYNAMIC_CLASS(wxTreebookXmlHandler, wxXmlResourceHandler)
GetStyle(wxT("style")),
GetName());
+ wxImageList *imagelist = GetImageList();
+ if ( imagelist )
+ tbk->AssignImageList(imagelist);
+
wxTreebook * old_par = m_tbk;
m_tbk = tbk;
CreateChildren(m_tbk, true/*only this handler*/);
+ wxXmlNode *node = GetParamNode("object");
+ int pageIndex = 0;
+ for (unsigned int i = 0; i < m_tbk->GetPageCount(); i++)
+ {
+ if ( m_tbk->GetPage(i) )
+ {
+ wxXmlNode *child = node->GetChildren();
+ while (child)
+ {
+ if (child->GetName() == "expanded" && child->GetNodeContent() == "1")
+ m_tbk->ExpandNode(pageIndex, true);
+
+ child = child->GetNext();
+ }
+ pageIndex++;
+ }
+ }
+
m_treeContext = old_treeContext;
m_isInside = old_ins;
m_tbk = old_par;
wnd = wxDynamicCast(item, wxWindow);
if (wnd == NULL && item != NULL)
- wxLogError(wxT("Error in resource: control within treebook's <page> tag is not a window."));
+ {
+ ReportError(n, "treebookpage child must be a window");
+ }
}
size_t depth = GetLong( wxT("depth") );
- if( depth <= m_treeContext.Count() )
+ if( depth <= m_treeContext.GetCount() )
{
// first prepare the icon
int imgIndex = wxNOT_FOUND;
}
imgIndex = imgList->Add(bmp);
}
+ else if ( HasParam(wxT("image")) )
+ {
+ if ( m_tbk->GetImageList() )
+ {
+ imgIndex = GetLong(wxT("image"));
+ }
+ else // image without image list?
+ {
+ ReportError(n, "image can only be used in conjunction "
+ "with imagelist");
+ }
+ }
// then add the page to the corresponding parent
- if( depth < m_treeContext.Count() )
- m_treeContext.RemoveAt(depth, m_treeContext.Count() - depth );
+ if( depth < m_treeContext.GetCount() )
+ m_treeContext.RemoveAt(depth, m_treeContext.GetCount() - depth );
if( depth == 0)
{
m_tbk->AddPage(wnd,
}
else
- wxLogError(wxT("Error in resource. wxTreebookPage has an invalid depth."));
+ {
+ ReportParamError("depth", "invalid depth");
+ }
+
return wnd;
}