From de9349d5502e956b09cebccb2c9dbb66f62a42f0 Mon Sep 17 00:00:00 2001
From: LiFan <2308045698@qq.com>
Date: 星期一, 15 七月 2024 17:34:05 +0800
Subject: [PATCH] update
---
jrj/project/business/Company/HrPosition.cpp | 419 ++++++++++++++++++++++++++++++++++-------------------------
1 files changed, 241 insertions(+), 178 deletions(-)
diff --git a/jrj/project/business/Company/HrPosition.cpp b/jrj/project/business/Company/HrPosition.cpp
index cb4571d..de946c5 100644
--- a/jrj/project/business/Company/HrPosition.cpp
+++ b/jrj/project/business/Company/HrPosition.cpp
@@ -1,211 +1,274 @@
#include <wobject/xstring.hpp>
#include <xcontrol/xtreeview.hpp>
#include <xcontrol/xdwgrid.hpp>
+#include <wobject/xdouble.hpp>
+#include <xcontrol/xlayersheet.hpp>
#include "vbusiness/vframe/listwin.vframe.vbusiness.hpp"
#include "viewobject/view.base.hpp"
using xml = KXMLDOMDocument;
- class __declspec(dllexport) Deduction : public xframe
+class __declspec(dllexport) HrPosition : public xframe
+{
+public:
+ xtreeview tv_org;
+ xdwgrid dw_list;
+ xstring sOrgID;
+ xstring sOrgName;
+
+ xnode m_agentNode; //Agent Condition
+ xstring m_agentCond; //Agent Node
+public:
+ HrPosition(void* implPtr, HWND hWnd) :xframe(implPtr, hWnd) {}
+public:
+ static HrPosition* CreateInstance(void* implPtr, void* hWnd)
{
- public:
- xdwgrid dw_list;
- xstring EntityID;
- xstring InvoiceNo;
-
- xnode m_agentNode; //Agent Condition
-
- public:
- Deduction(void* implPtr, HWND hWnd) :xframe(implPtr, hWnd) {}
- public:
- static Deduction* CreateInstance(void* implPtr, void* hWnd)
+ HrPosition* pWin = new HrPosition(implPtr, (HWND)hWnd);
+ return pWin;
+ }
+ int SetAgent()
+ {
+ xstring xfNodeAgentArea = L"agentarea";
+ xnode anode = GetAgentNode(xfNodeAgentArea);
+ if (m_agentNode)
{
- Deduction* pWin = new Deduction(implPtr, (HWND)hWnd);
- return pWin;
+ SetAgentNode(anode, m_agentNode);
}
- int SetAgent()
+ else
{
- xstring xfNodeAgentArea = L"agentarea";
- xnode anode = GetAgentNode(xfNodeAgentArea);
- if (m_agentNode)
+ KXMLDOMElement xframeElement = GetElement();
+ KXMLDOMElement agent = xframeElement.selectSingleNode(L"agent/" + xfNodeAgentArea + L"[1]/*");
+ if (agent)
{
- SetAgentNode(anode, m_agentNode);
+ xstring s = agent.xml();
+ m_agentNode = SetAgentNode(anode, s);
}
- else
- {
- KXMLDOMElement xframeElement = GetElement();
- KXMLDOMElement agent = xframeElement.selectSingleNode(L"agent/" + xfNodeAgentArea + L"[1]/*");
- if (agent)
+ }
+ return 1;
+ }
+
+ //焦点激活处理函数
+ int OnSetFocus(TEvent* evt, LPARAM param)
{
- xstring s = agent.xml();
- m_agentNode = SetAgentNode(anode, s);
+ SetAgent();
+
+ //重置工具条
+ return 1;
}
- }
- return 1;
- }
- int OnRowChanged(TEvent* evt, LPARAM p)
- {
- DWNMHDR& hdr = *(DWNMHDR*)evt->notify.pnmh;
- int row = hdr.row;
- SetAgent();
- return 1;
- }
+ int OnRetrieve(xstring ls_orgid)
+ {
+ xstring query = L"[MSSqlHrPosition.xq]";
+ xml x;
- //焦点激活处理函数
- int OnSetFocus(TEvent* evt, LPARAM param)
- {
- //重置工具条
- SetAgent();
- return 1;
- }
+ xaserverarg arg;
- //命令发布函数
- int OnCmdDispatch(xstring comdid)
- {
- if (comdid == L"xmSave")
- {
- OnSave();
- return 1;
- }
- if (comdid == L"xmSearch")
- {
- OnRetrieve(InvoiceNo, EntityID);
- return 1;
- }
- if (comdid == L"xmClose")
- {
- CloseWindow();
- return 1;
- }
- return 0;
- }
+ arg.AddArg(L"orgID", ls_orgid);
+ //if (xaserver::ExecXQuery(GetServerUrl(),query,arg.GetString(),x)!=1)
+ if (xurl::post(L"OrganizationStruct/list.Position", arg.GetString(), x) != 1)
+ {
+ trace(x.text());
+ return -1;
+ }
+ else
+ {
+ //trace(x.GetXml());
+ //dw_list.openUrl(L"组织架构.vface/template/HrPosition/list");
+ dw_list.Retrieve(x);
+ dw_list.Redraw();
+ }
+ return 1;
+ }
- //命令处理事件
- int OnXCommand(TEvent* evt, LPARAM param)
- {
- return OnCmdDispatch(evt->xcommand.pStrID);
- }
+ int OnTreeSelChanged(TEvent* evt, int p)
+ {
+ //int wid = tv_org.GetId();
+ HTREEITEM hitem = tv_org.GetSelectedItem();
+ KXMLDOMElement ele = tv_org.GetItemData(hitem);
+ xstring ls_orgid = ele.selectSingleNode(L"@guid").text();
+ sOrgID = ls_orgid + L"";
+ sOrgName = ele.selectSingleNode(L"OrgName").text();
+ OnRetrieve(ls_orgid);
+ return 1;
+ }
- xstring GetGuid()
- {
- return publiccode::GetGuid();
- }
+ int OnSave()
+ {
+ xml x;
- int OnSave()
- {
- xml x;
-
- dw_list.AcceptText();
- dw_list.DwUpdateAllToEx(x);
- xaserverarg arg ;
-
- arg.AddArg(L"content", x.xml());
- trace(x.xml());
- if (xurl::get(L"/sale/data/AR/update/ARDeduction", arg.GetString(), x) != 1)
- {
- xstring error = x.text();
- alert(L"err:" + error);
- return 1;
- }
- xstring str = x.documentElement().getAttribute(L"text");
- if (str == L"true")
- {
- dw_list.ResetUpdateStatus();
- alert(L"保存成功!");
- }
- else
- {
- alert(L"保存失败!");
- }
- return 1;
- }
+ dw_list.AcceptText();
+ dw_list.DwUpdateAllToEx(x);
- int OnItemChanged(TEvent* evt, LPARAM p)
- {
- DWNMHDR& hdr = *(DWNMHDR*)evt->notify.pnmh;
- xstring colname = hdr.colname;
- xstring value = hdr.data;
- int row = hdr.row;
- xstring dwname = L"dw_list";
- if (colname == L"DeductionAmount")
- {
- dw_list.SetItemString(row, L"SettlementAdjustID", EntityID);
- xstring id = publiccode::GetGuid();
- KXMLDOMElement ele = dw_list.GetRowElement(row);
- ele.setAttribute(L"guid", id);
- //dw_list.SetGuid(row,id);
- //alert(ele.xml);
- //alert(dw_list.GetGuid(row));
- }
- dw_list.Redraw();
- return 1;
- }
+ xstring xdata = x.xml();
+ xaserverarg arg;
- int OnAttachEvent()
- {
- //绑定工具条点击事件
- AttachEvent(L"WM_XCOMMAND", (FEvent)&Deduction::OnXCommand);
- //获取焦点事件,用于重置工具条
- AttachEvent(L"WM_SETFOCUS", (FEvent)&Deduction::OnSetFocus);
- AttachEvent(L"dw_list", L"DWV_ROWFOCUSCHANGED", (FEvent)&Deduction::OnRowChanged);
- AttachEvent(L"dw_list", L"DWV_ITEMCHANGED", (FEvent)&Deduction::OnItemChanged);
- return 1;
- }
+ arg.AddArg(L"xdata", xdata);
+ //trace(x.GetXml());
+ //return 1;
+ //xstring xAction=L"[MSSqlHrPositionUpdate.xa]";
+ //if(xaserver::ExecXAction(GetServerUrl(),xAction,arg.GetString())!=1)
+ if (xurl::post(L"OrganizationStruct/update.Position", arg.GetString(), x) != 1)
+ {
+ trace(x.documentElement().text());
+ alert(L"保存失败1");
+ }
+ else
+ {
+ dw_list.ResetUpdateStatus();
+ alert(L"保存成功");
+ }
+ return 1;
+ }
- int OnRetrieve(xstring InvoiceNo, xstring EntityID)
- {
- xml x;
-
- xaserverarg arg ;
-
- arg.AddArg(L"InvoiceNo", InvoiceNo);
- arg.AddArg(L"InvoiceNoEx", xcontrol(GetControl(L"search")).GetText());
- arg.AddArg(L"EntityID", EntityID);
+ int OnAddRow()
+ {
+ //int wid = tv_org.GetId();
+ HTREEITEM hitem = tv_org.GetSelectedItem();
+ if (!hitem)
+ {
+ alert(L"请选择组织架构!");
+ return 0;
+ }
+ //openUrl(L"组织架构.vface/xpage/Hr/HrPositionAdd", this);
+ OpenWindow(L"dev:xpage[HrPositionAdd.vx]", this);
+ return 1;
+ }
- //trace(GetControl(L"search").GetText());
- if (getUrl(L"/sale/data/AR/DeductionList", arg.GetString(), x) != 1)
- {
- trace(x.text());
- return -1;
- }
- else
- {
- dw_list.Retrieve(x);
- dw_list.Redraw();
- }
- dw_list.SetSelectionMode(1);
- return 1;
- }
+ int OnInsertRow()
+ {
+ int row = dw_list.GetRow();
+ dw_list.InsertRow(row);
+ return 1;
+ }
- int onload()
- {
- SetArg();
- dw_list = GetControl(L"dw_list");
- dw_list.openUrl(L"/sale/view/AR/template/Deduction");
+ int OnDeleteRow()
+ {
+ int row = dw_list.GetRow();
+ if (row > 0)
+ {
+ xstring sPositionName = dw_list.GetItemString(row, L"PositionName");
+ int del_flog =MessageBox(0, L"确定要删除选中的岗位 " + sPositionName + L" 吗?", L"提示", 4);
+ if (del_flog == 7) { return 0; }
+ //判断HrEmployee里面是否存在该岗位
+ //xstring sPositionID = dw_list.GetItemString(row,L"PositionID",0);
+ KXMLDOMElement e = dw_list.GetRowElement(row);
+ xstring sPositionID = e.selectSingleNode(L"@guid").text();
+ xml x;
- dw_list.SetColumnState(L"ID", false);
- dw_list.SetColumnState(L"GDNLineID", false);
- dw_list.SetColumnState(L"SettlementAdjustID", false);
+ xaserverarg args;
+
+ args.AddArg(L"guid", sPositionID);
+ //if(xaserver::ExecXQuery(GetServerUrl(),L"[HrpositionSel.xq]",args.GetString(),x)!=1)
+ if (xurl::post(L"OrganizationStruct/select.Position", args.GetString(), x) != 1)
+ {
+ trace(x.xml());
+ return 0;
+ }
+ var doc = x;
+ xstring cnt = doc.text();
+ int ll_cnt = cnt.toInt();
+ if (ll_cnt == 0) //判断HrEmploee里面是否存在该岗位
+ {
+ args.ClearArgs();
+ //xaserverarg Args;
+ //Args.setNativePointer(Args.CreateInstance());
+ args.AddArg(L"guid", sPositionID);
+ //if(xaserver::ExecXAction(GetServerUrl(),L"[HrPositionDel.xa]",Args.GetString(),x)!=1)
+ if (xurl::post(L"OrganizationStruct/delete.Position", args.GetString(), x) != 1)
+ {
+ trace(x.documentElement().text());
+ alert(L"删除失败");
+ }
+ else {
+ dw_list.DeleteRow(row);
+ alert(L"删除成功");
+ }
+ }
+ else
+ {
+ alert(L"其他地方已经使用该岗位,不允许删除!");
+ return 0;
+ }
+ }
+ return 1;
+ }
+ int OnChildContent(TEvent* evt, int p)
+ {
+ DWNMHDR& dwhdr = *(DWNMHDR*)evt->notify.pnmh;
+ xstring col = dwhdr.colname;
+ if (col != L"") {
+ xml x;
- if (GetWinParam())
- {
- xaserverarg arg = GetArg();
- EntityID = arg.GetArgString(L"EntityID");
- InvoiceNo = arg.GetArgString(L"InvoiceNo");
- }
- trace(InvoiceNo);
- OnRetrieve(InvoiceNo, EntityID);
- OnAttachEvent();
- return 1;
- }
+ xaserverarg arg;
- int onloaded()
- {
- SetAgent();
+ xstring query;
+ query = L"[IResourceMSSql.xq]";
+ if (col == L"OrgID") {
+ arg.AddArg(L"ResourceType", L"HrOrg");
+ }
+ else if (col == L"JobID") {
+ arg.AddArg(L"ResourceType", L"HrJob");
+ }
+ if (xaserver::ExecXQuery(GetServerUrl(), query, arg.GetString(), x) == 1)
+ dwhdr.data = x.xml();
+ //trace(x.GetXml());
+ }
+ return 1;
+ }
- return 1;
- }
- };
+ //命令发布函数
+ int OnCmdDispatch(xstring comdid)
+ {
+ if (comdid == L"Save") OnSave();
+ else if (comdid == L"AddRow") OnAddRow();
+ else if (comdid == L"InsertRow") OnInsertRow();
+ else if (comdid == L"DeleteRow") OnDeleteRow();
+ return 0;
+ }
+
+ //命令处理事件
+ int OnXCommand(TEvent* evt, LPARAM param)
+ {
+ return OnCmdDispatch(evt->xcommand.pStrID);
+ }
+
+ int OnAttachEvent()
+ {
+ //绑定工具条点击事件
+ AttachEvent(L"WM_XCOMMAND", (FEvent)&HrPosition::OnXCommand);
+ //获取焦点事件,用于重置工具条
+ AttachEvent(L"WM_SETFOCUS", (FEvent)&HrPosition::OnSetFocus);
+ //获得树的选择事件
+ AttachEvent(L"tv_org", L"TVN_SELCHANGED", (FEvent)&HrPosition::OnTreeSelChanged);
+ //AttachEvent(L"dw_list",L"DWV_CHILDCONTENT",OnChildContent);
+ //AttachEvent(L"dw_list",L"DWV_ITEMCHANGED",OnItemChanged);
+ return 1;
+ }
+
+ int OnInitial()
+ {
+ SetAgent();
+ OnAttachEvent();
+ return 1;
+ }
+
+ int onload()
+ {
+ tv_org = new treeview;
+ tv_org.setNativePointer(GetControl(L"tv_org"));
+ dw_list = new xdwgrid;
+ dw_list.setNativePointer(GetControl(L"dw_list"));
+ dw_list.openUrl(L"组织架构.vface/template/HrPosition/list");
+
+ OnInitial();
+
+ //int wid = tv_org.GetId();
+ HTREEITEM root = tv_org.GetRootItem();
+ tv_org.ExpandItem( root);
+ //OnRetrieve();
+
+ return 1;
+ }
+};
\ No newline at end of file
--
Gitblit v1.9.3