From 25e64cc13f2ce988cb1802c0b0671557e588d076 Mon Sep 17 00:00:00 2001 From: xj qian <qianxj15@sina.com> Date: 星期四, 27 六月 2024 22:38:58 +0800 Subject: [PATCH] test --- jrj/project/business/HR/ManpowerFileWindow.cpp | 109 +++--- jrj/project/business/HR/AdministrativeDepartmentFolder.cpp | 151 +++++---- jrj/project/business/HR/BlankExcelTemplate.cpp | 81 ++-- jrj/project/business/HR/AdministrativeDepartment.cpp | 279 +++++++++--------- jrj/project/business/HR/ManpowerFile.cpp | 228 +++++++------- 5 files changed, 442 insertions(+), 406 deletions(-) diff --git a/jrj/project/business/HR/AdministrativeDepartment.cpp b/jrj/project/business/HR/AdministrativeDepartment.cpp index d2f3c64..07fe927 100644 --- a/jrj/project/business/HR/AdministrativeDepartment.cpp +++ b/jrj/project/business/HR/AdministrativeDepartment.cpp @@ -8,100 +8,108 @@ #include "viewobject/view.base.hpp" using xml = KXMLDOMDocument; - class ViewAdministrativeDepartmentList : public listwin + class __declspec(dllexport) ViewAdministrativeDepartmentList : public listwin { + public: xdwgrid dw_list; xtreeview tv_folder;//hxsoft.com -> Developer -> wface -> vcontrol - string rows; - string urlTree; - string myDataUrl; + xstring rows; + xstring urlTree; + xstring myDataUrl; int changeddlb; xnode m_agentNode; //Agent Condition - + public: + ViewAdministrativeDepartmentList(void* implPtr, HWND hWnd) :listwin(implPtr, hWnd) {} + public: + static ViewAdministrativeDepartmentList* CreateInstance(void* implPtr, void* hWnd) + { + ViewAdministrativeDepartmentList* pWin = new ViewAdministrativeDepartmentList(implPtr, (HWND)hWnd); + return pWin; + } int SetAgent() { - string xfNodeAgentArea = "agentarea"; + xstring xfNodeAgentArea = L"agentarea"; xnode anode = GetAgentNode(xfNodeAgentArea); if (m_agentNode) { - SetAgentNodeContent(anode, m_agentNode); + SetAgentNode(anode, m_agentNode); } else { - msxml::IXMLDOMElement xframeElement = GetElement(); - msxml::IXMLDOMElement agent = xframeElement.selectSingleNode("agent/" + xfNodeAgentArea + "[1]/*"); + KXMLDOMElement xframeElement = GetElement(); + KXMLDOMElement agent = xframeElement.selectSingleNode(L"agent/" + xfNodeAgentArea + L"[1]/*"); if (agent) { - string s = agent.xml; - m_agentNode = SetAgentNodeContent(anode, s); + xstring s = agent.xml(); + m_agentNode = SetAgentNode(anode, s); } } return 1; } //展开放进树里面 - int ExpandCatChildFolder(int hItem, msxml::IXMLDOMElement ele, int image) + int ExpandCatChildFolder(HTREEITEM hItem, KXMLDOMElement ele, int image) { /*在具体应用时可以用DOMDocument的Load方法来装载XML文档 用IXMLDOMNode 的selectNodes(查询的结果有多个,得到存放搜索结果的链表) 或selectSingleNode(查询的结果有一个,在有多个的情况下返回找到的第一个节点)方法进行查询, 用createNode和appendChild方法来创建节点和追加节点, 用IXMLDOMElement的setAttribute和getAttribute方法来设置和获得节点的属性。*/ - msxml::IXMLDOMNodeList nlist = ele.SelectNodes("item"); - int len = nlist.length; + KXMLDOMNodeList nlist = ele.selectNodes(L"item"); + int len = nlist.length(); if (len > 0) tv_folder.SetItemChild(hItem, 1); for (int i = 0; i < len; i++) { - msxml::IXMLDOMElement e = nlist.item(i); - string name = e.getAttribute("name"); - int h = tv_folder.InsertChildItem(hItem, name, trust(e as int), image);//trust(e as int)将e放入树结构里面的data属性中 + KXMLDOMElement& e = *new KXMLDOMElement(nlist.item(i)); + xstring name = e.getAttribute(L"name"); + HTREEITEM h = tv_folder.InsertChildItem(hItem, name, (LPARAM)&e, image);//trust(e as int)将e放入树结构里面的data属性中 ExpandCatChildFolder(h, e, 35); } return 1; } //展开文件夹明细 - int ExpandFolderItem(int hItem, string parentid) + int ExpandFolderItem(HTREEITEM hItem, xstring parentid) { - xml x = ViewObject::RetrieveData(urlTree, "status", "有效", "parentid", parentid);//获取后台数据 + xml x = ViewObject::RetrieveData(urlTree, L"status", L"有效", L"parentid", parentid);//获取后台数据 if (!x) { return 0; } - msxml::IXMLDOMNodeList nlist = x.GetXmlDoc().SelectNodes("data/Item"); - int len = nlist.length; + KXMLDOMNodeList nlist = x.selectNodes(L"data/Item"); + int len = nlist.length(); for (int i = 0; i < len; i++) { - msxml::IXMLDOMElement e = nlist.item(i); - string name = e.selectSingleNode("name").text; - int h = tv_folder.InsertChildItem(hItem, name, trust(e as int), 35); + KXMLDOMElement& e = *new KXMLDOMElement(nlist.item(i)); + xstring name = e.selectSingleNode(L"name").text(); + HTREEITEM h = tv_folder.InsertChildItem(hItem, name, (LPARAM)&e, 35); ExpandCatChildFolder(h, e, 35); } return 1; } //查找当前树项的顶级目录 - int LookupTopFolder(int hItem) + HTREEITEM LookupTopFolder(HTREEITEM hItem) { - int hRoot = tv_folder.GetRootItem(); + HTREEITEM hRoot = tv_folder.GetRootItem(); while (tv_folder.GetParentItem(hItem)) hItem = tv_folder.GetParentItem(hItem); return hItem; } //树展开 - int OnTreeExpanding(ref TNotifyEvent evt, int p) + int OnTreeExpanding(TEvent* evt, int p) { - ref NMTREEVIEW nmtv = evt.pnmh; - int hItem = nmtv.itemNew.hItem; - int hTopItem = LookupTopFolder(hItem); - string name = tv_folder.GetItemLabel(hTopItem); - int child = tv_folder.GetChildItem(hItem); + NMTREEVIEW& nmtv = *(NMTREEVIEW*)evt->notify.pnmh; + HTREEITEM hItem = nmtv.itemNew.hItem; + HTREEITEM hTopItem = LookupTopFolder(hItem); + xstring name = tv_folder.GetItemLabel(hTopItem); + HTREEITEM child = tv_folder.GetChildItem(hItem); - msxml::IXMLDOMElement e = tv_folder.GetItemData(hItem); - string parentid = ""; - if (name != "部门结构") - parentid = e.selectSingleNode("adid").text; + KXMLDOMElement e = tv_folder.GetItemData(hItem); + xstring parentid = L""; + if (name != L"部门结构") + parentid = e.selectSingleNode(L"adid").text(); trace(parentid); if (!child) { ExpandFolderItem(hItem, parentid); @@ -112,26 +120,26 @@ //查询节点的列表数据 int OnPreRetrieve() { - int hItem = tv_folder.GetSelectedItem(); + HTREEITEM hItem = tv_folder.GetSelectedItem(); if (hItem <= 0) return 1; //int hCursor = xutil::SetCursorWait(); - msxml::IXMLDOMElement e = cast(tv_folder.GetItemData(hItem) as msxml::IXMLDOMElement); - string name = e.getAttribute("name"); + KXMLDOMElement& e = *(KXMLDOMElement*)tv_folder.GetItemData(hItem); + xstring name = e.getAttribute(L"name"); xml x = 0; - string parentid = ""; - if (name != "部门结构") - parentid = e.selectSingleNode("adid").text; + xstring parentid = L""; + if (name != L"部门结构") + parentid = e.selectSingleNode(L"adid").text(); trace(parentid); - x = ViewObject::RetrieveData(myDataUrl, "parentid", parentid); + x = ViewObject::RetrieveData(myDataUrl, L"parentid", parentid); if (x) { - //trace(x.GetXml()); + //trace(x.xml()); dw_list.Retrieve(x); dw_list.Redraw(); } else { - dw_list.ResetEx(); + dw_list.Reset(); dw_list.Redraw(); } dw_list.SetReadOnly(true); @@ -139,20 +147,20 @@ return 1; } - int OnTreeSelChanged(ref TNotifyEvent evt, int p) + int OnTreeSelChanged(TEvent* evt, int p) { if (changeddlb) return 1; - int hItem = tv_folder.GetSelectedItem(); + HTREEITEM hItem = tv_folder.GetSelectedItem(); if (hItem <= 0) return 1; - int child = tv_folder.GetChildItem(hItem); + HTREEITEM child = tv_folder.GetChildItem(hItem); if (!child) { - int hCursor = xutil::SetCursorWait(); - msxml::IXMLDOMElement e = cast(tv_folder.GetItemData(hItem) as msxml::IXMLDOMElement); - if (!e.getAttribute("name")) { - string adid = e.selectSingleNode("adid").text; - string parentid = adid; + HCURSOR hCursor = xutil::SetCursorWait(); + KXMLDOMElement& e = *(KXMLDOMElement*)tv_folder.GetItemData(hItem); + if (!e.getAttribute(L"name")) { + xstring adid = e.selectSingleNode(L"adid").text(); + xstring parentid = adid; ExpandFolderItem(hItem, parentid); } } @@ -160,7 +168,7 @@ } //焦点激活处理函数 - int OnSetFocus(ref TEvent evt, int param) + int OnSetFocus(TEvent* evt, LPARAM p) { //重置工具条 SetAgent(); @@ -169,18 +177,18 @@ int OnAdd() { - int hItem = tv_folder.GetSelectedItem(); + HTREEITEM hItem = tv_folder.GetSelectedItem(); if (hItem <= 0) return 1; - int hCursor = xutil::SetCursorWait(); - msxml::IXMLDOMElement e = cast(tv_folder.GetItemData(hItem) as msxml::IXMLDOMElement); - string parentid = "";//父级id - if (!e.getAttribute("name")) - parentid = e.selectSingleNode("adid").text; - xaserverarg arg = new xaserverarg; - arg.setNativePointer(arg.CreateInstance()); - arg.AddArg("parentid", parentid); - OpenWindow("dev:xpage[AdministrativeDepartmentFolder.vx]", cast(arg as int)); + HCURSOR hCursor = xutil::SetCursorWait(); + KXMLDOMElement& e = *(KXMLDOMElement*)tv_folder.GetItemData(hItem); + xstring parentid = L"";//父级id + if (!e.getAttribute(L"name")) + parentid = e.selectSingleNode(L"adid").text(); + xaserverarg arg; + + arg.AddArg(L"parentid", parentid); + OpenWindow(L"dev:xpage[AdministrativeDepartmentFolder.vx]",arg); return 1; } @@ -192,32 +200,32 @@ if(hItem <=0) return 1; int hCursor = xutil::SetCursorWait(); - msxml::IXMLDOMElement e = cast(tv_folder.GetItemData(hItem) as msxml::IXMLDOMElement); + KXMLDOMElement e = cast(tv_folder.GetItemData(hItem) as KXMLDOMElement); - if(e.getAttribute("name")) + if(e.getAttribute(L"name")) return 1;*/ int row = dw_list.GetRow(); if (row < 1) return 1; - string parentid = "", adid = ""; - /*msxml::IXMLDOMElement ele = dw_list.GetRowElement(row); - adid = ele.selectSingleNode("adid").text;*/ - adid = dw_list.GetItemString(row, "adid"); - parentid = dw_list.GetItemString(row, "parentid"); + xstring parentid = L"", adid = L""; + /*KXMLDOMElement ele = dw_list.GetRowElement(row); + adid = ele.selectSingleNode(L"adid").text();*/ + adid = dw_list.GetItemString(row, L"adid"); + parentid = dw_list.GetItemString(row, L"parentid"); - xaserverarg arg = new xaserverarg; - arg.setNativePointer(arg.CreateInstance()); - /*string parentid = "", adid = "";//父级id + xaserverarg arg; + + /*xstring parentid = L"", adid = L"";//父级id - if(!e.getAttribute("name")){ + if(!e.getAttribute(L"name")){ - parentid = e.selectSingleNode("adid").text; - adid = e.selectSingleNode("adid").text; + parentid = e.selectSingleNode(L"adid").text(); + adid = e.selectSingleNode(L"adid").text(); }*/ - arg.AddArg("parentid", parentid); - arg.AddArg("adid", adid); - OpenWindow("dev:xpage[AdministrativeDepartmentFolder.vx]", cast(arg as int)); + arg.AddArg(L"parentid", parentid); + arg.AddArg(L"adid", adid); + OpenWindow(L"dev:xpage[AdministrativeDepartmentFolder.vx]",arg); return 1; } @@ -227,32 +235,32 @@ if(hItem <=0) return 1; int hCursor = xutil::SetCursorWait(); - msxml::IXMLDOMElement e = cast(tv_folder.GetItemData(hItem) as msxml::IXMLDOMElement); - string name = e.getAttribute("name"); - string adid = ""; - if(name != "部门结构") - adid = e.selectSingleNode("adid").text;*/ + KXMLDOMElement e = cast(tv_folder.GetItemData(hItem) as KXMLDOMElement); + xstring name = e.getAttribute(L"name"); + xstring adid = L""; + if(name != L"部门结构") + adid = e.selectSingleNode(L"adid").text();*/ int row = dw_list.GetRow(); if (row < 1) return 1; - string adid = ""; - /*msxml::IXMLDOMElement ele = dw_list.GetRowElement(row); - adid = ele.selectSingleNode("adid").text;*/ - adid = dw_list.GetItemString(row, "adid"); + xstring adid = L""; + /*KXMLDOMElement ele = dw_list.GetRowElement(row); + adid = ele.selectSingleNode(L"adid").text();*/ + adid = dw_list.GetItemString(row, L"adid"); xml x = new xml; - x.setNativePointer(xml::CreateInstance()); - xaserverarg arg = new xaserverarg; - arg.setNativePointer(arg.CreateInstance()); - arg.AddArg("adid", adid); - if (getUrl("/sale/data/AdministrativeDepartment/ad_delete", arg.GetString(), x) != 1) + + xaserverarg arg; + + arg.AddArg(L"adid", adid); + if (getUrl(L"/sale/data/AdministrativeDepartment/ad_delete", arg.GetString(), x) != 1) { - string error = x.GetXmlDoc().text; - alert("err:" + error); + xstring error = x.text(); + alert(L"err:" + error); return 1; } - alert(x.GetXmlDoc().text); + alert(x.text()); dw_list.DeleteRow(row); return 1; } @@ -264,38 +272,38 @@ } //命令发布函数 - int OnCmdDispatch(string comdid) + int OnCmdDispatch(xstring comdid) { - if (comdid == "xmUpdate") + if (comdid == L"xmUpdate") return OnUpdate(); - else if (comdid == "xmAdd") + else if (comdid == L"xmAdd") return OnAdd(); - else if (comdid == "xmDelete") + else if (comdid == L"xmDelete") return OnDelete(); - else if (comdid == "xmRefresh") + else if (comdid == L"xmRefresh") return OnRefresh(); return 0; } //命令处理事件 - int OnXCommand(ref TXCommandEvent evt, int param) + int OnXCommand(TEvent* evt, LPARAM p) { - return OnCmdDispatch(evt.pStrID); + return OnCmdDispatch(evt->xcommand.pStrID); } int OnAttachEvent() { - AttachEvent("tv_folder", "TVN_SELCHANGED", OnTreeSelChanged); //树选择 - AttachEvent("tv_folder", "TVN_ITEMEXPANDING", OnTreeExpanding); //树展开 + AttachEvent(L"tv_folder", L"TVN_SELCHANGED", (FEvent)&ViewAdministrativeDepartmentList::OnTreeSelChanged); //树选择 + AttachEvent(L"tv_folder", L"TVN_ITEMEXPANDING", (FEvent)&ViewAdministrativeDepartmentList::OnTreeExpanding); //树展开 - //AttachEvent("dw_list","DWV_ROWFOCUSCHANGED",OnRowChanged); - //AttachEvent("cbx_1","CBN_SELCHANGE",OnSelectDdlb); - //AttachEvent("cbx_datashow","CBN_SELCHANGE",OnSelectDataShowDdlb); + //AttachEvent(L"dw_list",L"DWV_ROWFOCUSCHANGED",OnRowChanged); + //AttachEvent(L"cbx_1",L"CBN_SELCHANGE",OnSelectDdlb); + //AttachEvent(L"cbx_datashow",L"CBN_SELCHANGE",OnSelectDataShowDdlb); //绑定工具条点击事件 - AttachEvent("WM_XCOMMAND", OnXCommand); + AttachEvent(L"WM_XCOMMAND", (FEvent)&ViewAdministrativeDepartmentList::OnXCommand); //获取焦点事件,用于重置工具条 - AttachEvent("WM_SETFOCUS", OnSetFocus); + AttachEvent(L"WM_SETFOCUS", (FEvent)&ViewAdministrativeDepartmentList::OnSetFocus); } /* @@ -303,13 +311,13 @@ int OnRetrieve() { xml x = new xml; - x.setNativePointer(xml::CreateInstance()); - xaserverarg arg = new xaserverarg; - arg.setNativePointer(arg.CreateInstance()); - //arg.AddArg("xxx","xxx"); + + xaserverarg arg; + + //arg.AddArg(L"xxx",L"xxx"); if (getUrl(myDataUrl,arg.GetString(),x)!=1) { - trace(x.GetXmlDoc().text); + trace(x.text()); return -1; }else { @@ -321,20 +329,20 @@ */ //展开子文件 - int ExpandChildFolder(int hItem, msxml::IXMLDOMElement pElement) + int ExpandChildFolder(HTREEITEM hItem, KXMLDOMElement pElement) { - msxml::IXMLDOMNodeList nlist = pElement.SelectNodes("Item"); - int len = nlist.length; + KXMLDOMNodeList nlist = pElement.selectNodes(L"Item"); + int len = nlist.length(); for (int i = 0; i < len; i++) { - msxml::IXMLDOMElement e = nlist.item(i); - string name = e.getAttribute("name"); - string sImage = e.getAttribute("image"); - string child = e.getAttribute("child"); + KXMLDOMElement& e = *new KXMLDOMElement(nlist.item(i)); + xstring name = e.getAttribute(L"name"); + xstring sImage = e.getAttribute(L"image"); + xstring child = e.getAttribute(L"child"); int image = 18; if (sImage) image = sImage.toInt(); - int h = tv_folder.InsertChildItem(tv_folder.GetId(), hItem, name, trust(e as int), image); - if (child != "no") + HTREEITEM h = tv_folder.InsertChildItem(hItem, name, (LPARAM) & e, image); + if (child != L"no") tv_folder.SetItemChild(h, 1); ExpandChildFolder(h, e); } @@ -344,8 +352,8 @@ //初始化文件夹 int InitialFolder() { - msxml::IXMLDOMElement xframeElement = GetElement(); - msxml::IXMLDOMElement e = xframeElement.selectSingleNode("//xtree[@name='tv_folder']/initial"); + KXMLDOMElement xframeElement = GetElement(); + KXMLDOMElement e = xframeElement.selectSingleNode(L"//xtree[@name='tv_folder']/initial"); if (e) ExpandChildFolder(0, e); return 1; @@ -353,14 +361,14 @@ int onload() { - dw_list = GetControl("dw_list"); - dw_list.openUrl("/sale/view/AdministrativeDepartment/template/adlist"); - dw_list.SetColumnState("adid", false); - dw_list.SetColumnState("parentid", false); + dw_list = GetControl(L"dw_list"); + dw_list.openUrl(L"/sale/view/AdministrativeDepartment/template/adlist"); + dw_list.SetColumnState(L"adid", false); + dw_list.SetColumnState(L"parentid", false); - myDataUrl = "/sale/data/AdministrativeDepartment/ad_list"; - urlTree = "/sale/data/AdministrativeDepartment/ad_sidelist"; - tv_folder = GetControl("tv_folder"); + myDataUrl = L"/sale/data/AdministrativeDepartment/ad_list"; + urlTree = L"/sale/data/AdministrativeDepartment/ad_sidelist"; + tv_folder = GetControl(L"tv_folder"); tv_folder.SetLineAtRoot(true); InitialFolder(); OnAttachEvent(); @@ -374,5 +382,4 @@ return 1; } - }; -] \ No newline at end of file + }; \ No newline at end of file diff --git a/jrj/project/business/HR/AdministrativeDepartmentFolder.cpp b/jrj/project/business/HR/AdministrativeDepartmentFolder.cpp index c8d4839..31ca6fa 100644 --- a/jrj/project/business/HR/AdministrativeDepartmentFolder.cpp +++ b/jrj/project/business/HR/AdministrativeDepartmentFolder.cpp @@ -8,40 +8,48 @@ #include "viewobject/view.base.hpp" using xml = KXMLDOMDocument; - class AdministrativeDepartmentFolderView : public xframe + class __declspec(dllexport) AdministrativeDepartmentFolderView : public xframe { + public: //xdwgrid dw_list; xdwtable dw_base;//新增弹窗时使用 - string adid; - string name; - string parentid; - string getsingle_url; + xstring adid; + xstring name; + xstring parentid; + xstring getsingle_url; xnode m_agentNode; //Agent Condition - + public: + AdministrativeDepartmentFolderView(void* implPtr, HWND hWnd) :xframe(implPtr, hWnd) {} + public: + static AdministrativeDepartmentFolderView* CreateInstance(void* implPtr, void* hWnd) + { + AdministrativeDepartmentFolderView* pWin = new AdministrativeDepartmentFolderView(implPtr, (HWND)hWnd); + return pWin; + } /*int SetAgent() { - string xfNodeAgentArea = "agentarea"; + xstring xfNodeAgentArea = L"agentarea"; xnode anode = GetAgentNode(xfNodeAgentArea); if(m_agentNode) { - SetAgentNodeContent (anode,m_agentNode); + SetAgentNode (anode,m_agentNode); } else { - msxml::IXMLDOMElement xframeElement = GetElement(); - msxml::IXMLDOMElement agent = xframeElement.selectSingleNode("agent/"+xfNodeAgentArea+"[1]/*"); + KXMLDOMElement xframeElement = GetElement(); + KXMLDOMElement agent = xframeElement.selectSingleNode(L"agent/"+xfNodeAgentArea+L"[1]/*"); if(agent) { - string s = agent.xml; - m_agentNode = SetAgentNodeContent (anode,s); + xstring s = agent.xml; + m_agentNode = SetAgentNode (anode,s); } } return 1; }*/ //焦点激活处理函数 - int OnSetFocus(ref TEvent evt, int param) + int OnSetFocus(TEvent* evt, LPARAM p) { //重置工具条 //SetAgent(); @@ -51,89 +59,89 @@ int OnSave() { xml x = new xml; - x.setNativePointer(xml::CreateInstance()); + dw_base.AcceptText(); - dw_base.DwUpdateAllTo(x.GetXmlDoc()); - xaserverarg arg = new xaserverarg; + dw_base.DwUpdateAllTo(x); + xaserverarg arg; arg.setNativePointer(xaserverarg::CreateInstance()); - arg.AddArg("content", x.GetXml()); - //trace(x.GetXml()); - if (getUrl("/sale/data/AdministrativeDepartment/ad_update", arg.GetString(), x) != 1) + arg.AddArg(L"content", x.xml()); + //trace(x.xml()); + if (getUrl(L"/sale/data/AdministrativeDepartment/ad_update", arg.GetString(), x) != 1) { - string error = x.GetXmlDoc().text; - alert("err:" + error); + xstring error = x.text(); + alert(L"err:" + error); return 1; } - //trace("返回信息"+x.GetXml()); - string str = x.GetXmlDoc().documentElement.getAttribute("text"); - if (str == "true") + //trace(L"返回信息"+x.xml()); + xstring str = x.documentElement().getAttribute(L"text"); + if (str == L"true") { dw_base.ResetUpdateStatus(); CloseWindow(); - alert("保存成功!"); + alert(L"保存成功!"); } else { - alert("保存失败!"); + alert(L"保存失败!"); } return 1; } //命令发布函数 - int OnCmdDispatch(string comdid) + int OnCmdDispatch(xstring comdid) { - if (comdid == "xmSave") + if (comdid == L"xmSave") return OnSave(); - else if (comdid == "xmClose") + else if (comdid == L"xmClose") CloseWindow(); return 0; } //命令处理事件 - int OnXCommand(ref TXCommandEvent evt, int param) + int OnXCommand(TEvent* evt, LPARAM p) { - return OnCmdDispatch(evt.pStrID); + return OnCmdDispatch(evt->xcommand.pStrID); } int OnAttachEvent() { //绑定工具条点击事件 - AttachEvent("WM_XCOMMAND", OnXCommand); + AttachEvent(L"WM_XCOMMAND", (FEvent)&AdministrativeDepartmentFolderView::OnXCommand); //获取焦点事件,用于重置工具条 - AttachEvent("WM_SETFOCUS", OnSetFocus); + AttachEvent(L"WM_SETFOCUS", (FEvent)&AdministrativeDepartmentFolderView::OnSetFocus); } int OnParentRetrieve() { xml x = new xml; - x.setNativePointer(xml::CreateInstance()); - xaserverarg arg = new xaserverarg; - arg.setNativePointer(arg.CreateInstance()); - arg.AddArg("adid", parentid); + + xaserverarg arg; + + arg.AddArg(L"adid", parentid); if (getUrl(getsingle_url, arg.GetString(), x) != 1) { - trace(x.GetXmlDoc().text); + trace(x.text()); return -1; } else { - string parent_name = ""; - string parent_adid = ""; - string parent_level = ""; - msxml::IXMLDOMNodeList nlist = x.GetXmlDoc().SelectNodes("data/Item"); - int len = nlist.length; + xstring parent_name = L""; + xstring parent_adid = L""; + xstring parent_level = L""; + KXMLDOMNodeList nlist = x.selectNodes(L"data/Item"); + int len = nlist.length(); for (int i = 0; i < len; i++) { - msxml::IXMLDOMElement e = nlist.item(i); - parent_name = e.selectSingleNode("name").text; - parent_adid = e.getAttribute("guid"); - parent_level = e.selectSingleNode("level").text; + KXMLDOMElement e = nlist.item(i); + parent_name = e.selectSingleNode(L"name").text(); + parent_adid = e.getAttribute(L"guid"); + parent_level = e.selectSingleNode(L"level").text(); } - xdwtable dw_obj = dw_base.FindDwTable("Item"); - dw_obj.SetItemString(1, "parent_name", parent_name); - if (adid == "") { - dw_obj.SetItemString(1, "parentid", parent_adid); - dw_obj.SetItemString(1, "level", (parent_level.toInt() + 1).toString()); + xdwtable dw_obj = dw_base.FindDwTable(L"Item"); + dw_obj.SetItemString(1, L"parent_name", parent_name); + if (adid == L"") { + dw_obj.SetItemString(1, L"parentid", parent_adid); + dw_obj.SetItemString(1, L"level", xstring((parent_level.toInt() + 1))); } //dw_base.Retrieve(x); @@ -145,13 +153,13 @@ int OnRetrieve() { xml x = new xml; - x.setNativePointer(xml::CreateInstance()); - xaserverarg arg = new xaserverarg; - arg.setNativePointer(arg.CreateInstance()); - arg.AddArg("adid", adid); + + xaserverarg arg; + + arg.AddArg(L"adid", adid); if (getUrl(getsingle_url, arg.GetString(), x) != 1) { - trace(x.GetXmlDoc().text); + trace(x.text()); return -1; } else @@ -165,21 +173,21 @@ int onload() { - dw_base = GetControl("dw_base"); - dw_base.openUrl("/sale/view/AdministrativeDepartment/template/adwin"); - getsingle_url = "/sale/data/AdministrativeDepartment/ad_getsingle"; - xaserverarg arg = new xaserverarg; - arg.setNativePointer(arg.CreateInstance()); - arg = GetParam(); - adid = ""; - parentid = ""; - if (GetParam()) { - parentid = arg.GetArgString("parentid"); - adid = arg.GetArgString("adid"); + dw_base = GetControl(L"dw_base"); + dw_base.openUrl(L"/sale/view/AdministrativeDepartment/template/adwin"); + getsingle_url = L"/sale/data/AdministrativeDepartment/ad_getsingle"; + xaserverarg arg; + + + adid = L""; + parentid = L""; + if (GetWinParam()) { + parentid = arg.GetArgString(L"parentid"); + adid = arg.GetArgString(L"adid"); } - if (adid != "") + if (adid != L"") OnRetrieve(); - if (parentid != "") + if (parentid != L"") OnParentRetrieve(); OnAttachEvent(); dw_base.SetColHeaderHeight(0); @@ -195,5 +203,4 @@ return 1; } - }; -] \ No newline at end of file + }; \ No newline at end of file diff --git a/jrj/project/business/HR/BlankExcelTemplate.cpp b/jrj/project/business/HR/BlankExcelTemplate.cpp index 4747fdb..289e4ce 100644 --- a/jrj/project/business/HR/BlankExcelTemplate.cpp +++ b/jrj/project/business/HR/BlankExcelTemplate.cpp @@ -8,36 +8,44 @@ #include "viewobject/view.base.hpp" using xml = KXMLDOMDocument; - class BlankExcelTemplateView : public xframe + class __declspec(dllexport) BlankExcelTemplateView : public xframe { + public: xdwgrid dw_list; //xdwtable dw_base;//新增弹窗时使用 xnode m_agentNode; //Agent Condition - + public: + BlankExcelTemplateView(void* implPtr, HWND hWnd) :xframe(implPtr, hWnd) {} + public: + static BlankExcelTemplateView* CreateInstance(void* implPtr, void* hWnd) + { + BlankExcelTemplateView* pWin = new BlankExcelTemplateView(implPtr, (HWND)hWnd); + return pWin; + } int SetAgent() { - string xfNodeAgentArea = "agentarea"; + xstring xfNodeAgentArea = L"agentarea"; xnode anode = GetAgentNode(xfNodeAgentArea); if (m_agentNode) { - SetAgentNodeContent(anode, m_agentNode); + SetAgentNode(anode, m_agentNode); } else { - msxml::IXMLDOMElement xframeElement = GetElement(); - msxml::IXMLDOMElement agent = xframeElement.selectSingleNode("agent/" + xfNodeAgentArea + "[1]/*"); + KXMLDOMElement xframeElement = GetElement(); + KXMLDOMElement agent = xframeElement.selectSingleNode(L"agent/" + xfNodeAgentArea + L"[1]/*"); if (agent) { - string s = agent.xml; - m_agentNode = SetAgentNodeContent(anode, s); + xstring s = agent.xml(); + m_agentNode = SetAgentNode(anode, s); } } return 1; } //焦点激活处理函数 - int OnSetFocus(ref TEvent evt, int param) + int OnSetFocus(TEvent* evt, LPARAM p) { //重置工具条 SetAgent(); @@ -47,65 +55,65 @@ int OnSave() { xml x = new xml; - x.setNativePointer(xml::CreateInstance()); + dw_list.AcceptText(); - dw_list.DwUpdateAllToEx(x.GetXmlDoc()); - xaserverarg arg = new xaserverarg; + dw_list.DwUpdateAllToEx(x); + xaserverarg arg; arg.setNativePointer(xaserverarg::CreateInstance()); - arg.AddArg("content", x.GetXml().replace(" 00:00:00", "").replace("0000-00-00", "")); - //trace(x.GetXml().replace(" 00:00:00", "").replace("0000-00-00", ""));//运行界面打印 - if (getUrl("/sale/data/ManpowerFile/multiUpdate", arg.GetString(), x) != 1) { - string error = x.GetXmlDoc().text; - alert("err:" + error); + arg.AddArg(L"content", x.xml().replace(L" 00:00:00", L"").replace(L"0000-00-00", L"")); + //trace(x.xml().replace(L" 00:00:00", L"").replace(L"0000-00-00", L""));//运行界面打印 + if (getUrl(L"/sale/data/ManpowerFile/multiUpdate", arg.GetString(), x) != 1) { + xstring error = x.text(); + alert(L"err:" + error); return 1; } - string str = x.GetXmlDoc().documentElement.getAttribute("text"); - if (str == "true") + xstring str = x.documentElement().getAttribute(L"text"); + if (str == L"true") { dw_list.ResetUpdateStatus();//更改更新状态,防止多保存 - alert("保存成功!"); + alert(L"保存成功!"); } else { - alert("保存失败!"); + alert(L"保存失败!"); } return 1; } //命令发布函数 - int OnCmdDispatch(string comdid) + int OnCmdDispatch(xstring comdid) { - if (comdid == "xmSave") + if (comdid == L"xmSave") return OnSave(); return 0; } //命令处理事件 - int OnXCommand(ref TXCommandEvent evt, int param) + int OnXCommand(TEvent* evt, LPARAM p) { - return OnCmdDispatch(evt.pStrID); + return OnCmdDispatch(evt->xcommand.pStrID); } int OnAttachEvent() { //绑定工具条点击事件 - AttachEvent("WM_XCOMMAND", OnXCommand); + AttachEvent(L"WM_XCOMMAND", (FEvent)&BlankExcelTemplateView::OnXCommand); //获取焦点事件,用于重置工具条 - AttachEvent("WM_SETFOCUS", OnSetFocus); + AttachEvent(L"WM_SETFOCUS", (FEvent)&BlankExcelTemplateView::OnSetFocus); } /*//加载数据 int OnRetrieve() { xml x = new xml; - x.setNativePointer(xml::CreateInstance()); - xaserverarg arg = new xaserverarg; - arg.setNativePointer(arg.CreateInstance()); - arg.AddArg("xxx","xxx"); - if (getUrl("",arg.GetString(),x)!=1) + + xaserverarg arg; + + arg.AddArg(L"xxx",L"xxx"); + if (getUrl(L"",arg.GetString(),x)!=1) { - trace(x.GetXmlDoc().text); + trace(x.text()); return -1; }else { @@ -118,8 +126,8 @@ int onload() { - dw_list = GetControl("dw_list"); - dw_list.openUrl("/sale/view/ManpowerFile/template/list"); + dw_list = GetControl(L"dw_list"); + dw_list.openUrl(L"/sale/view/ManpowerFile/template/list"); OnAttachEvent(); @@ -132,5 +140,4 @@ return 1; } - }; -] \ No newline at end of file + }; \ No newline at end of file diff --git a/jrj/project/business/HR/ManpowerFile.cpp b/jrj/project/business/HR/ManpowerFile.cpp index e834cf5..ea4c79e 100644 --- a/jrj/project/business/HR/ManpowerFile.cpp +++ b/jrj/project/business/HR/ManpowerFile.cpp @@ -8,68 +8,77 @@ #include "viewobject/view.base.hpp" using xml = KXMLDOMDocument; - class ViewManpowerFileList : public xframe + class __declspec(dllexport) ViewManpowerFileList : public xframe { + public: xdwgrid dw_list;//hxsoft.com -> Developer -> wface -> vcontrol int hSignWin; xdwtable dw_arg; xnode m_agentNode; //Agent Condition - string urlTree; + xstring urlTree; xtreeview tv_folder; - //展开子文件 - int ExpandChildFolder(int hItem, msxml::IXMLDOMElement pElement) + public: + ViewManpowerFileList(void* implPtr, HWND hWnd) :xframe(implPtr, hWnd) {} + public: + static ViewManpowerFileList* CreateInstance(void* implPtr, void* hWnd) { - msxml::IXMLDOMNodeList nlist = pElement.SelectNodes("Item"); - int len = nlist.length; + ViewManpowerFileList* pWin = new ViewManpowerFileList(implPtr, (HWND)hWnd); + return pWin; + } + //展开子文件 + int ExpandChildFolder(HTREEITEM hItem,KXMLDOMElement pElement) + { + KXMLDOMNodeList nlist = pElement.selectNodes(L"Item"); + int len = nlist.length(); for (int i = 0; i < len; i++) { - msxml::IXMLDOMElement e = nlist.item(i); - string name = e.getAttribute("name"); - string sImage = e.getAttribute("image"); - string child = e.getAttribute("child"); + KXMLDOMElement& e = *new KXMLDOMElement(nlist.item(i)); + xstring name = e.getAttribute(L"name"); + xstring sImage = e.getAttribute(L"image"); + xstring child = e.getAttribute(L"child"); int image = 15; if (sImage) image = sImage.toInt(); - int h = tv_folder.InsertChildItem(tv_folder.GetId(), hItem, name, trust(e as int), image); - if (child != "no") tv_folder.SetItemChild(h, 1); + HTREEITEM h = tv_folder.InsertChildItem( hItem, name, (LPARAM)&e, image); + if (child != L"no") tv_folder.SetItemChild(h, 1); ExpandChildFolder(h, e); } return 1; } int InitialFolder() { - msxml::IXMLDOMElement xframeElement = GetElement(); - msxml::IXMLDOMElement e = xframeElement.selectSingleNode("//xtree[@name='tv_folder']/initial"); + KXMLDOMElement xframeElement = GetElement(); + KXMLDOMElement e = xframeElement.selectSingleNode(L"//xtree[@name='tv_folder']/initial"); if (e) ExpandChildFolder(0, e); return 1; } - int ExpandCatChildFolder(int hItem, msxml::IXMLDOMElement ele, int image) + int ExpandCatChildFolder(HTREEITEM hItem, KXMLDOMElement ele, int image) { - msxml::IXMLDOMNodeList nlist = ele.SelectNodes("item"); - int len = nlist.length; + KXMLDOMNodeList nlist = ele.selectNodes(L"item"); + int len = nlist.length(); if (len > 0) tv_folder.SetItemChild(hItem, 1); for (int i = 0; i < len; i++) { - msxml::IXMLDOMElement e = nlist.item(i); - string name = e.getAttribute("name"); - int h = tv_folder.InsertChildItem(hItem, name, trust(e as int), image); + KXMLDOMElement& e = *new KXMLDOMElement(nlist.item(i)); + xstring name = e.getAttribute(L"name"); + HTREEITEM h = tv_folder.InsertChildItem(hItem, name, (LPARAM)&e, image); ExpandCatChildFolder(h, e, 35); } return 1; } - int ExpandFolderItem(int hItem) + int ExpandFolderItem(HTREEITEM hItem) { xml x = ViewObject::RetrieveData(urlTree); if (!x) return 0; - msxml::IXMLDOMNodeList nlist = x.GetXmlDoc().SelectNodes("/data/item"); - int len = nlist.length; + KXMLDOMNodeList nlist = x.selectNodes(L"/data/item"); + int len = nlist.length(); for (int i = 0; i < len; i++) { - msxml::IXMLDOMElement e = nlist.item(i); - string name = e.getAttribute("name"); - int h = tv_folder.InsertChildItem(hItem, name, trust(e as int), 35); + KXMLDOMElement& e = *new KXMLDOMElement(nlist.item(i)); + xstring name = e.getAttribute(L"name"); + HTREEITEM h = tv_folder.InsertChildItem(hItem, name, (LPARAM)&e, 35); ExpandCatChildFolder(h, e, 35); } return 1; @@ -77,27 +86,27 @@ int SetAgent() { - string xfNodeAgentArea = "agentarea"; + xstring xfNodeAgentArea = L"agentarea"; xnode anode = GetAgentNode(xfNodeAgentArea); if (m_agentNode) { - SetAgentNodeContent(anode, m_agentNode); + SetAgentNode(anode, m_agentNode); } else { - msxml::IXMLDOMElement xframeElement = GetElement(); - msxml::IXMLDOMElement agent = xframeElement.selectSingleNode("agent/" + xfNodeAgentArea + "[1]/*"); + KXMLDOMElement xframeElement = GetElement(); + KXMLDOMElement agent = xframeElement.selectSingleNode(L"agent/" + xfNodeAgentArea + L"[1]/*"); if (agent) { - string s = agent.xml; - m_agentNode = SetAgentNodeContent(anode, s); + xstring s = agent.xml(); + m_agentNode = SetAgentNode(anode, s); } } return 1; } //焦点激活处理函数 - int OnSetFocus(ref TEvent evt, int param) + int OnSetFocus(TEvent* evt, LPARAM p) { //重置工具条 SetAgent(); @@ -106,7 +115,7 @@ int OnOpenAddWindow() { - OpenWindow("dev:xpage[ManpowerFileWindow.vx]"); + OpenWindow(L"dev:xpage[ManpowerFileWindow.vx]"); return 1; } @@ -115,15 +124,15 @@ int row = dw_list.GetRow(); if (row < 1) return 1; - msxml::IXMLDOMElement ele = dw_list.GetRowElement(row); - string mfid = ele.selectSingleNode("mfid").text;//获取节点的值 - OpenWindow("dev:xpage[ManpowerFileWindow.vx]", cast(mfid as int)); + KXMLDOMElement ele = dw_list.GetRowElement(row); + xstring mfid = ele.selectSingleNode(L"mfid").text();//获取节点的值 + OpenWindow(L"dev:xpage[ManpowerFileWindow.vx]",mfid); return 1; } int OnExchangeFileWindow() { - xwin xw = OpenWindow("dev:xpage[BlankExcelTemplate.vx]", 0); + xwin xw = OpenWindow(L"dev:xpage[BlankExcelTemplate.vx]", 0); hSignWin = xw.GetHWND(); return 1; } @@ -132,26 +141,26 @@ { int MB_OKCANCEL = 1; int IDOK = 1; - int ret = win32::MessageBox(GetHWND(), "确认删除?", "提示", MB_OKCANCEL); + int ret = MessageBoxW(GetHWND(), L"确认删除?", L"提示", MB_OKCANCEL); if (ret == IDOK) { int row = dw_list.GetRow(); if (row < 1) return 1; - msxml::IXMLDOMElement ele = dw_list.GetRowElement(row); - string mfid = ele.selectSingleNode("mfid").text;//查看 + KXMLDOMElement ele = dw_list.GetRowElement(row); + xstring mfid = ele.selectSingleNode(L"mfid").text();//查看 xml x = new xml; - x.setNativePointer(xml::CreateInstance()); - xaserverarg arg = new xaserverarg;//放置参数 - arg.setNativePointer(arg.CreateInstance()); - arg.AddArg("mfid", mfid); - if (getUrl("/sale/data/ManpowerFile/delete", arg.GetString(), x) != 1) + + xaserverarg arg;//放置参数 + + arg.AddArg(L"mfid", mfid); + if (getUrl(L"/sale/data/ManpowerFile/delete", arg.GetString(), x) != 1) { - string error = x.GetXmlDoc().text; - alert("err:" + error); + xstring error = x.text(); + alert(L"err:" + error); return 1; } - alert(x.GetXmlDoc().text); + alert(x.text()); OnRefresh(); } return 1; @@ -165,50 +174,50 @@ //分析 int OnAnalysis() { - int hCursor = xutil::SetCursorWait(); - string str = dw_list.DataAnalysis(""); - xaserverarg arg = new xaserverarg; - arg.setNativePointer(arg.CreateInstance()); - arg.AddArg("html", str); + HCURSOR hCursor = xutil::SetCursorWait(); + xstring str = dw_list.DataAnalysis(L""); + xaserverarg arg; + + arg.AddArg(L"html", str); int obj = cast(dw_list as int); - arg.AddArg("obj", obj.toString()); - OpenWindow("dev:xpage[data.vanalysis.vx]", cast(arg as int)); + arg.AddArg(L"obj", obj.toString()); + OpenWindow(L"dev:xpage[data.vanalysis.vx]", cast(arg as int)); xutil::RestoreCursor(hCursor); return 1; } - string GetQueryArg() + xstring GetQueryArg() { dw_arg.AcceptText(); xml x = new xml; - x.setNativePointer(xml::CreateInstance()); - dw_arg.DwUpdateAllTo(x.GetXmlDoc()); + + dw_arg.DwUpdateAllTo(x); - return x.GetXml(); + return x.xml(); } int OnRetrieveEx1() { - int hItem = tv_folder.GetSelectedItem(); + HTREEITEM hItem = tv_folder.GetSelectedItem(); if (hItem <= 0) return 1; - int hCursor = xutil::SetCursorWait(); - msxml::IXMLDOMElement e1 = cast(tv_folder.GetItemData(hItem) as msxml::IXMLDOMElement); - string no = e1.getAttribute("no"); + HCURSOR hCursor = xutil::SetCursorWait(); + KXMLDOMElement& e1 = *(KXMLDOMElement*)tv_folder.GetItemData(hItem); + xstring no = e1.getAttribute(L"no"); xml x = new xml; - x.setNativePointer(xml::CreateInstance()); - xaserverarg arg = new xaserverarg; - arg.setNativePointer(arg.CreateInstance()); - //arg.AddArg("QueryTxt",GetControl("sle_search").GetText()); - arg.AddArg("QueryArg", GetQueryArg()); - arg.AddArg("MStatus", no); + + xaserverarg arg; + + //arg.AddArg(L"QueryTxt",GetControl(L"sle_search").GetText()); + arg.AddArg(L"QueryArg", GetQueryArg()); + arg.AddArg(L"MStatus", no); - arg.AddArg("QueryName", GetControl("QueryName").GetText()); + arg.AddArg(L"QueryName", GetControl(L"QueryName").GetText()); //trace(arg.GetString()); - if (getUrl("/sale/data/ManpowerFile/list", arg.GetString(), x) != 1) + if (getUrl(L"/sale/data/ManpowerFile/list", arg.GetString(), x) != 1) { - trace(x.GetXmlDoc().text); + trace(x.text()); return -1; } else @@ -223,36 +232,36 @@ } //命令发布函数 - int OnCmdDispatch(string comdid) + int OnCmdDispatch(xstring comdid) { - if (comdid == "xmAddHumanDocument") + if (comdid == L"xmAddHumanDocument") return OnOpenAddWindow(); - else if (comdid == "xmUpdateHumanDocument") + else if (comdid == L"xmUpdateHumanDocument") return OnOpenUpdateWindow(); - else if (comdid == "xmRefresh" || comdid == "xmSearch") + else if (comdid == L"xmRefresh" || comdid == L"xmSearch") return OnRetrieveEx1(); - else if (comdid == "xmExchangeFile") + else if (comdid == L"xmExchangeFile") return OnExchangeFileWindow(); - else if (comdid == "xmDelete") + else if (comdid == L"xmDelete") return OnDelete(); - else if (comdid == "xmAnalysis") + else if (comdid == L"xmAnalysis") return OnAnalysis(); return 0; } //命令处理事件 - int OnXCommand(ref TXCommandEvent evt, int param) + int OnXCommand(TEvent* evt, LPARAM p) { - return OnCmdDispatch(evt.pStrID); + return OnCmdDispatch(evt->xcommand.pStrID); } - int OnDoubleClicked(ref TNotifyEvent evt, int p) + int OnDoubleClicked(TEvent* evt, LPARAM p) { - return OnCmdDispatch("xmUpdateHumanDocument"); + return OnCmdDispatch(L"xmUpdateHumanDocument"); } - int OnTreeSelChanged(ref TNotifyEvent evt, int p) + int OnTreeSelChanged(TEvent* evt, LPARAM p) { return OnRetrieveEx1(); } @@ -260,11 +269,11 @@ int OnAttachEvent() { //绑定工具条点击事件 - AttachEvent("WM_XCOMMAND", OnXCommand); + AttachEvent(L"WM_XCOMMAND", (FEvent)&ViewManpowerFileList::OnXCommand); //获取焦点事件,用于重置工具条 - AttachEvent("WM_SETFOCUS", OnSetFocus); - AttachEvent("dw_list", "DWV_DOUBLECLICKED", OnDoubleClicked);//行双击 - AttachEvent("tv_folder", "TVN_SELCHANGED", OnTreeSelChanged); //树选择 + AttachEvent(L"WM_SETFOCUS", (FEvent)&ViewManpowerFileList::OnSetFocus); + AttachEvent(L"dw_list", L"DWV_DOUBLECLICKED", (FEvent)&ViewManpowerFileList::OnDoubleClicked);//行双击 + AttachEvent(L"tv_folder", L"TVN_SELCHANGED", (FEvent)&ViewManpowerFileList::OnTreeSelChanged); //树选择 } //数据传输函数 @@ -272,17 +281,17 @@ { //int hCursor = xutil::SetCursorWait();//鼠标位置 xml x = new xml; - x.setNativePointer(xml::CreateInstance()); - xaserverarg arg = new xaserverarg;//放置参数 - arg.setNativePointer(arg.CreateInstance()); - //arg.AddArg("QueryTxt",GetControl("sle_search").GetText());//添加所需要传到后台的参数 - arg.AddArg("QueryArg", GetQueryArg()); - arg.AddArg("MStatus", ""); - arg.AddArg("QueryName", GetControl("QueryName").GetText()); - //trace("查看arg="+arg.GetString());//运行界面打印 - if (getUrl("/sale/data/ManpowerFile/list", arg.GetString(), x) != 1)///sale/data/ManpowerFile/doclist后台接口 + + xaserverarg arg;//放置参数 + + //arg.AddArg(L"QueryTxt",GetControl(L"sle_search").GetText());//添加所需要传到后台的参数 + arg.AddArg(L"QueryArg", GetQueryArg()); + arg.AddArg(L"MStatus", L""); + arg.AddArg(L"QueryName", GetControl(L"QueryName").GetText()); + //trace(L"查看arg=L"+arg.GetString());//运行界面打印 + if (getUrl(L"/sale/data/ManpowerFile/list", arg.GetString(), x) != 1)///sale/data/ManpowerFile/doclist后台接口 { - trace(x.GetXmlDoc().text); + trace(x.text()); return -1; } else @@ -295,10 +304,10 @@ int onload() { - //【1】控制页面中name="dw_list"的内容 - dw_list = GetControl("dw_list"); + //【1】控制页面中name=L"dw_list"的内容 + dw_list = GetControl(L"dw_list"); //【2】加载sale根目录下view下的ManpowerFile.vface文件中的template/list url 前端页面 - dw_list.openUrl("/sale/view/ManpowerFile/template/list"); + dw_list.openUrl(L"/sale/view/ManpowerFile/template/list"); //【3】绑定事件 OnAttachEvent(); //【4】加载后台数据 @@ -306,17 +315,17 @@ //【6】设为只读 dw_list.SetReadOnly(true); - dw_arg = GetControl("dw_arg"); - dw_arg.openUrl("/sale/view/ManpowerFile/template/QueryArg"); + dw_arg = GetControl(L"dw_arg"); + dw_arg.openUrl(L"/sale/view/ManpowerFile/template/QueryArg"); dw_arg.SetColHeaderHeight(0); dw_arg.SetRowSelectorWidth(0); dw_arg.SetHScrollState(false); dw_arg.SetVScrollState(false); - dw_arg.SetItemString(1, "DateType", "不设定"); + dw_arg.SetItemString(1, L"DateType", L"不设定"); OnRetrieve(); - urlTree = "/sale/data/ManpowerFile/folder"; - tv_folder = GetControl("tv_folder"); + urlTree = L"/sale/data/ManpowerFile/folder"; + tv_folder = GetControl(L"tv_folder"); tv_folder.SetLineAtRoot(true); InitialFolder(); @@ -326,11 +335,10 @@ int onloaded() { SetAgent(); - int hItem = tv_folder.GetRootItem(); + HTREEITEM hItem = tv_folder.GetRootItem(); ExpandFolderItem(hItem); tv_folder.ExpandItem(hItem); tv_folder.ItemFocus(hItem); return 1; } - }; -] \ No newline at end of file + }; \ No newline at end of file diff --git a/jrj/project/business/HR/ManpowerFileWindow.cpp b/jrj/project/business/HR/ManpowerFileWindow.cpp index de306d3..df48086 100644 --- a/jrj/project/business/HR/ManpowerFileWindow.cpp +++ b/jrj/project/business/HR/ManpowerFileWindow.cpp @@ -8,16 +8,24 @@ #include "viewobject/view.base.hpp" using xml = KXMLDOMDocument; - class ViewManpowerFileWiondow : public xframe + class __declspec(dllexport) ViewManpowerFileWiondow : public xframe { + public: //xdwgrid dw_list;//新建列表时使用 xdwtable dw_base;//新增弹窗时使用 - string mfid; + xstring mfid; xnode m_agentNode; //Agent Condition - + public: + ViewManpowerFileWiondow(void* implPtr, HWND hWnd) :xframe(implPtr, hWnd) {} + public: + static ViewManpowerFileWiondow* CreateInstance(void* implPtr, void* hWnd) + { + ViewManpowerFileWiondow* pWin = new ViewManpowerFileWiondow(implPtr, (HWND)hWnd); + return pWin; + } /*int SetAgent() { - string xfNodeAgentArea = "agentarea"; + xstring xfNodeAgentArea = L"agentarea"; xnode anode = GetAgentNode(xfNodeAgentArea); if(m_agentNode) { @@ -26,10 +34,10 @@ else { msxml::IXMLDOMElement xframeElement = GetElement(); - msxml::IXMLDOMElement agent = xframeElement.selectSingleNode("agent/"+xfNodeAgentArea+"[1]/*"); + msxml::IXMLDOMElement agent = xframeElement.selectSingleNode(L"agent/"+xfNodeAgentArea+L"[1]/*"); if(agent) { - string s = agent.xml; + xstring s = agent.xml; m_agentNode = SetAgentNodeContent (anode,s); } } @@ -37,7 +45,7 @@ }*/ //焦点激活处理函数 - int OnSetFocus(ref TEvent evt, int param) + int OnSetFocus(TEvent* evt, LPARAM p) { //重置工具条 SetAgent(); @@ -48,77 +56,77 @@ int OnSave() { xml x = new xml; - x.setNativePointer(xml::CreateInstance()); + dw_base.AcceptText(); - dw_base.DwUpdateAllTo(x.GetXmlDoc()); - xaserverarg arg = new xaserverarg; + dw_base.DwUpdateAllTo(x); + xaserverarg arg; arg.setNativePointer(xaserverarg::CreateInstance()); - arg.AddArg("content", x.GetXml()); - //trace(x.GetXml()); - if (url::get("/sale/data/ManpowerFile/update", arg.GetString(), x) != 1) + arg.AddArg(L"content", x.xml()); + //trace(x.xml()); + if (xurl::get(L"/sale/data/ManpowerFile/update", arg.GetString(), x) != 1) { - string error = x.GetXmlDoc().text; - alert("err:" + error); + xstring error = x.text(); + alert(L"err:" + error); return 1; } - //trace("返回值="+x.GetXml()); - string str = x.GetXmlDoc().documentElement.getAttribute("text"); - if (str == "true") + //trace(L"返回值=L"+x.xml()); + xstring str = x.documentElement().getAttribute(L"text"); + if (str == L"true") { dw_base.ResetUpdateStatus(); CloseWindow(); - alert("保存成功!"); + alert(L"保存成功!"); } else { - alert("保存失败!"); + alert(L"保存失败!"); } return 1; } //命令发布函数 - int OnCmdDispatch(string comdid) + int OnCmdDispatch(xstring comdid) { - if (comdid == "xmClose") {//关闭窗口 + if (comdid == L"xmClose") {//关闭窗口 CloseWindow(); return 1; } - else if (comdid == "xmSave") {//保存窗口 + else if (comdid == L"xmSave") {//保存窗口 return OnSave(); } return 0; } //命令处理事件 - int OnXCommand(ref TXCommandEvent evt, int param) + int OnXCommand(TEvent* evt, LPARAM p) { - return OnCmdDispatch(evt.pStrID); + return OnCmdDispatch(evt->xcommand.pStrID); } int OnAttachEvent() { //绑定工具条点击事件 - AttachEvent("WM_XCOMMAND", OnXCommand); + AttachEvent(L"WM_XCOMMAND", (FEvent)&ViewManpowerFileWiondow::OnXCommand); //获取焦点事件,用于重置工具条 - AttachEvent("WM_SETFOCUS", OnSetFocus); - AttachEvent("dw_base", "DWV_ITEMCHANGING", OnItemChanging); + AttachEvent(L"WM_SETFOCUS", (FEvent)&ViewManpowerFileWiondow::OnSetFocus); + AttachEvent(L"dw_base", L"DWV_ITEMCHANGING", (FEvent)&ViewManpowerFileWiondow::OnItemChanging); } - int OnItemChanging(ref TNotifyEvent evt, int p) + int OnItemChanging(TEvent* evt, LPARAM p) { - ref DWNMHDR hdr = trust(evt.pnmh as ref DWNMHDR); - string colname = hdr.colname; - string value = hdr.data; + DWNMHDR& hdr = *(DWNMHDR*)evt->notify.pnmh; + xstring colname = hdr.colname; + xstring value = hdr.data; int row = hdr.row; - if (value == "") return 1; - string cellType = dw_base.GetColumnProp(colname, "celltype"); + if (value == L"") return 1; + xstring cellType = dw_base.GetColumnProp(colname, L"celltype"); //alert(cellType); - if (cellType == "xs:decimal" || cellType == "xs:integer") + if (cellType == L"xs:decimal" || cellType == L"xs:integer") { if (value.isNumber() == false) { - alert(value + "不是数字!"); + alert(value + L"不是数字!"); hdr.idFrom = -1; return 1; } @@ -128,18 +136,18 @@ int OnRetrieve() { xml x = new xml; - x.setNativePointer(xml::CreateInstance()); - xaserverarg arg = new xaserverarg; - arg.setNativePointer(arg.CreateInstance()); - arg.AddArg("mfid", mfid); - if (getUrl("/sale/data/ManpowerFile/getsingle", arg.GetString(), x) != 1) + + xaserverarg arg; + + arg.AddArg(L"mfid", mfid); + if (getUrl(L"/sale/data/ManpowerFile/getsingle", arg.GetString(), x) != 1) { - trace("错误信息=" + x.GetXmlDoc().text); + trace(L"错误信息=L" + xstring(x.text())); return -1; } else { - //trace("返回信息="+x.GetXml()); + //trace(L"返回信息=L"+x.xml()); dw_base.Retrieve(x); dw_base.Redraw(); } @@ -148,12 +156,12 @@ int onload() { - dw_base = GetControl("dw_base"); - dw_base.openUrl("/sale/view/ManpowerFile/template/win"); - mfid = ""; - if (GetParam()) - mfid = GetParam(); - if (mfid != "") + dw_base = GetControl(L"dw_base"); + dw_base.openUrl(L"/sale/view/ManpowerFile/template/win"); + mfid = L""; + if (GetWinParam()) + mfid = GetParamString(); + if (mfid != L"") { OnRetrieve(); } @@ -174,5 +182,4 @@ return 1; } - }; -] \ No newline at end of file + }; \ No newline at end of file -- Gitblit v1.9.3