2024-04-29 17:57:07 +08:00
|
|
|
|
using E_ZKEcc.Domian;
|
|
|
|
|
|
using E_ZKEcc.Service;
|
2024-05-15 13:56:09 +08:00
|
|
|
|
using E_ZKEcc.Request;
|
2024-04-29 17:57:07 +08:00
|
|
|
|
using Kingdee.BOS.App.Data;
|
|
|
|
|
|
using Kingdee.BOS.Core.DynamicForm.PlugIn;
|
|
|
|
|
|
using Kingdee.BOS.Core.DynamicForm.PlugIn.Args;
|
|
|
|
|
|
using Kingdee.BOS.Orm.DataEntity;
|
|
|
|
|
|
using System;
|
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
|
using System.Linq;
|
2024-05-15 13:56:09 +08:00
|
|
|
|
using Kingdee.BOS.Util;
|
|
|
|
|
|
using System.ComponentModel;
|
2024-07-16 10:33:50 +08:00
|
|
|
|
using Kingdee.BOS.Core.Bill;
|
2024-04-29 17:57:07 +08:00
|
|
|
|
|
2024-05-15 13:56:09 +08:00
|
|
|
|
namespace Demi.GAT_StaffData
|
2024-04-29 17:57:07 +08:00
|
|
|
|
{
|
2024-05-15 13:56:09 +08:00
|
|
|
|
[Description("员工档案-考勤机"), HotUpdate]
|
2024-04-29 17:57:07 +08:00
|
|
|
|
public class OperationEventPlugInEx : AbstractOperationServicePlugIn
|
|
|
|
|
|
{
|
|
|
|
|
|
public override void OnPreparePropertys(PreparePropertysEventArgs e)
|
|
|
|
|
|
{
|
|
|
|
|
|
base.OnPreparePropertys(e);
|
2024-07-16 10:33:50 +08:00
|
|
|
|
//e.FieldKeys.Add("FIDTypeNumber");
|
2024-04-29 17:57:07 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 操作结束-事务内
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <param name="e"></param>
|
|
|
|
|
|
public override void EndOperationTransaction(EndOperationTransactionArgs e)
|
|
|
|
|
|
{
|
|
|
|
|
|
base.EndOperationTransaction(e);
|
|
|
|
|
|
|
|
|
|
|
|
// 保存8提交9审核1反审核26删除3
|
|
|
|
|
|
if (this.FormOperation.OperationId == 1)
|
|
|
|
|
|
{
|
|
|
|
|
|
if (e.DataEntitys.Any())
|
|
|
|
|
|
{
|
|
|
|
|
|
DoUpdateEmployeeFunc(e.DataEntitys);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 审核后进行人员更新
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <param name="DataEntitys"></param>
|
|
|
|
|
|
private void DoUpdateEmployeeFunc(DynamicObject[] DataEntitys)
|
|
|
|
|
|
{
|
|
|
|
|
|
var apiInfo = GetE_ZKEccSDKAPIInfo();
|
|
|
|
|
|
var service = new EmployeeService(apiInfo);
|
|
|
|
|
|
|
2024-07-16 10:33:50 +08:00
|
|
|
|
var datas = new List<EmployeeUpdateRequest>();
|
|
|
|
|
|
var idList = DataEntitys.Select(x => x["Id"].ToString()).ToList();
|
|
|
|
|
|
var dataList = GetDataList(idList);
|
|
|
|
|
|
if (dataList != null && dataList.Count > 0)
|
|
|
|
|
|
foreach (var entity in DataEntitys)
|
|
|
|
|
|
{
|
|
|
|
|
|
var domain = new EmployeeUpdateRequest();
|
2024-05-15 13:56:09 +08:00
|
|
|
|
|
2024-07-16 10:33:50 +08:00
|
|
|
|
domain.pin = entity["FNUMBER"].ToString();
|
|
|
|
|
|
//domain.pin = "99999";
|
|
|
|
|
|
domain.name = entity["FNAME"].ToString();
|
|
|
|
|
|
//domain.deptnumber = item["FDeptName"].ToSafeTurnString();
|
|
|
|
|
|
//暂时固定部门
|
|
|
|
|
|
domain.deptnumber = "999";
|
|
|
|
|
|
domain.comverifys = 15;
|
|
|
|
|
|
domain.zonecode = new string[1] { "1" };
|
|
|
|
|
|
//domain.identitycard = entity["FIDTypeNumber"].ToString();
|
2024-04-29 17:57:07 +08:00
|
|
|
|
|
2024-07-16 10:33:50 +08:00
|
|
|
|
//图片地址
|
|
|
|
|
|
var imageFilePath = entity["FLOCATIONPATH"].ToString();
|
|
|
|
|
|
if (imageFilePath != null)
|
|
|
|
|
|
//图片转换成base64
|
|
|
|
|
|
domain.enrollpic = (imageFilePath == "" ? "" : ImageUtil.ImageFileToBase64(imageFilePath));
|
|
|
|
|
|
|
|
|
|
|
|
datas.Add(domain);
|
2024-05-15 13:56:09 +08:00
|
|
|
|
}
|
2024-04-29 17:57:07 +08:00
|
|
|
|
|
2024-07-16 10:33:50 +08:00
|
|
|
|
var result = service.UpdateEmployee(datas);
|
2024-04-29 17:57:07 +08:00
|
|
|
|
|
|
|
|
|
|
if (result.ret != 0)
|
|
|
|
|
|
throw new Exception(result.msg);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 获取E_ZKEcc考勤机api连接信息
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
|
private ApiInfoDomian GetE_ZKEccSDKAPIInfo()
|
|
|
|
|
|
{
|
|
|
|
|
|
var vSql = "/*dialect*/ SELECT * FROM V_E_ZKEccSDK_API_INFO ";
|
|
|
|
|
|
var dataTable = DBUtils.ExecuteDynamicObject(this.Context, vSql);
|
|
|
|
|
|
var dataRow = dataTable[0];
|
|
|
|
|
|
var apiInfo = new ApiInfoDomian
|
|
|
|
|
|
{
|
|
|
|
|
|
appKey = dataRow["appKey"].ToString(),
|
|
|
|
|
|
apiVersion = dataRow["apiVersion"].ToString(),
|
|
|
|
|
|
serverUrl = dataRow["serverUrl"].ToString()
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
return apiInfo;
|
|
|
|
|
|
}
|
2024-07-16 10:33:50 +08:00
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 获取数据库数据
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <param name="idList"></param>
|
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
|
private DynamicObjectCollection GetDataList(List<string> idList)
|
|
|
|
|
|
{
|
|
|
|
|
|
var sqlL = $@"/*dialect*/
|
|
|
|
|
|
SELECT t0.FID,t0.FNUMBER,t0_l.FNAME,t0.FIDTYPENUMBER,ISNULL(t1.FLOCATIONPATH,'') AS 'FLOCATIONPATH'
|
|
|
|
|
|
FROM T_BD_StaffData t0
|
|
|
|
|
|
INNER JOIN T_BD_StaffData_l t0_l on t0.FID = t0_l.FID AND t0_l.FLOCALEID = 2052
|
|
|
|
|
|
LEFT JOIN T_BAS_FileServerFileInfo t1 on t0.FIMAGE = t1.FFILEID
|
|
|
|
|
|
WHERE 1 = 1
|
|
|
|
|
|
AND t0.FID IN ({string.Join(",", idList)})
|
|
|
|
|
|
";
|
|
|
|
|
|
|
|
|
|
|
|
return DBUtils.ExecuteDynamicObject(this.Context, sqlL);
|
|
|
|
|
|
}
|
2024-04-29 17:57:07 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|