/
DeferredWidget.h
49 lines (42 loc) · 1.03 KB
/
DeferredWidget.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
#ifndef DEFERRED_WIDGET_H_
#define DEFERRED_WIDGET_H_
#include <Wt/WContainerWidget>
/*
* A utility container widget which defers creation of its single
* child widget until the container is loaded (which is done on-demand
* by a WMenu). The constructor takes the create function for the
* widget as a parameter.
*
* We use this to defer widget creation until needed, which also defers
* loading auxiliary javascript libraries.
*/
#if !defined(WT_TARGET_JAVA)
template <typename Function>
class DeferredWidget : public Wt::WContainerWidget
{
public:
DeferredWidget(Function f)
: f_(f) { }
private:
void load() {
addWidget(f_());
WContainerWidget::load();
}
Function f_;
};
template <typename Function>
DeferredWidget<Function> *deferCreate(Function f)
{
return new DeferredWidget<Function>(f);
}
#else
class DeferredWidget : public Wt::WContainerWidget {
public:
DeferredWidget(boost::bound f) {}
};
DeferredWidget *deferCreate(boost::bound b)
{
return new DeferredWidget(b);
}
#endif
#endif // DEFERRED_WIDGET_H_