aboutsummaryrefslogtreecommitdiff
path: root/Src/Wasabi/api/skin/widgets/xuiwndholder.h
diff options
context:
space:
mode:
Diffstat (limited to 'Src/Wasabi/api/skin/widgets/xuiwndholder.h')
-rw-r--r--Src/Wasabi/api/skin/widgets/xuiwndholder.h80
1 files changed, 80 insertions, 0 deletions
diff --git a/Src/Wasabi/api/skin/widgets/xuiwndholder.h b/Src/Wasabi/api/skin/widgets/xuiwndholder.h
new file mode 100644
index 00000000..13edc05a
--- /dev/null
+++ b/Src/Wasabi/api/skin/widgets/xuiwndholder.h
@@ -0,0 +1,80 @@
+#ifndef __XUIWNDHOLDER_H
+#define __XUIWNDHOLDER_H
+
+#include <api/wnd/wndclass/wndholder.h>
+#include <api/script/scriptguid.h>
+#include <api/script/objcontroller.h>
+
+#define XUIWNDHOLDER_PARENT WindowHolderWnd
+
+// -----------------------------------------------------------------------
+class XuiWindowHolder : public XUIWNDHOLDER_PARENT
+{
+
+ public:
+
+ XuiWindowHolder();
+ virtual ~XuiWindowHolder();
+
+ virtual int setXuiParam(int xuihandle, int xmlattributeid, const wchar_t *xmlattributename, const wchar_t *value);
+
+ void setRegionFromMap(ScriptObject *map, int byte, int inverse);
+ void setRegion(ScriptObject *region);
+ static GUID *parseGUID(const wchar_t *id);
+
+protected:
+ /*static */void CreateXMLParameters(int master_handle);
+ private:
+
+ enum {
+ XUIWNDHOLDER_ADDHOLD = 10,
+ XUIWNDHOLDER_SETNOSHOWCMDBAR = 20,
+ XUIWNDHOLDER_SETNOANIMRECTS = 30,
+ XUIWNDHOLDER_SETAUTOOPEN = 40,
+ XUIWNDHOLDER_SETAUTOCLOSE = 50,
+ XUIWNDHOLDER_SETAUTOFOCUS = 60,
+ XUIWNDHOLDER_SETAUTOAVAILABLE = 70,
+ };
+ static XMLParamPair params[];
+ int myxuihandle;
+};
+
+// -----------------------------------------------------------------------------------------------------
+class WindowHolderScriptController: public ScriptObjectControllerI {
+ public:
+
+ virtual const wchar_t *getClassName() { return L"WindowHolder"; }
+ virtual const wchar_t *getAncestorClassName() { return L"GuiObject"; }
+ virtual ScriptObjectController *getAncestorController() { return WASABI_API_MAKI->maki_getController(guiObjectGuid); }
+ virtual int getNumFunctions();
+ virtual const function_descriptor_struct *getExportedFunctions();
+ virtual GUID getClassGuid() { return windowHolderGuid; }
+ virtual ScriptObject *instantiate();
+ virtual void destroy(ScriptObject *o);
+ virtual void *encapsulate(ScriptObject *o);
+ virtual void deencapsulate(void *o);
+
+ public:
+ static scriptVar script_getGUID(SCRIPT_FUNCTION_PARAMS, ScriptObject *o);
+ static scriptVar script_setRegionFromMap(SCRIPT_FUNCTION_PARAMS, ScriptObject *o, scriptVar map, scriptVar byte, scriptVar inv);
+ static scriptVar script_setRegion(SCRIPT_FUNCTION_PARAMS, ScriptObject *o, scriptVar reg);
+ static scriptVar script_getContent(SCRIPT_FUNCTION_PARAMS, ScriptObject *o);
+ static scriptVar script_getComponentName(SCRIPT_FUNCTION_PARAMS, ScriptObject *o);
+
+ private:
+
+ static function_descriptor_struct exportedFunction[];
+};
+
+extern WindowHolderScriptController *windowHolderController;
+
+
+// -----------------------------------------------------------------------
+extern const wchar_t WindowHolderXuiObjectStr[];
+extern const wchar_t WindowHolderXuiObjectStrCompat[];
+extern char WindowHolderXuiSvcName[];
+extern char WindowHolderXuiSvcNameCompat[];
+class WindowHolderXuiSvc : public XuiObjectSvc<XuiWindowHolder, WindowHolderXuiObjectStr, WindowHolderXuiSvcName> {};
+class WindowHolderXuiSvc2 : public XuiObjectSvc<XuiWindowHolder, WindowHolderXuiObjectStrCompat, WindowHolderXuiSvcNameCompat> {};
+
+#endif