/// <summary> /// 判断日志中记录的单据在账套中是否真的存在 added by liuxzha 2015.03.23 /// 日志查询界面使用 /// </summary> /// <param name="autoid"></param> /// <returns> 0 本节点没有生成,子结点也没生成; /// 10 本节点生成,子结点没有生成,单据为未审核状态 /// 11 本节点生成,子结点没有生成,单据为已审核状态 /// 100 本节点没有生成,子结点已经生成 /// 110 本节点生成,子结点也已经生成,单据为未审核状态 /// 111 本节点生成,子结点也已经生成,单据为已审核状态</returns> public int ChkExistsInData(string autoid) { int res = 0; //bool bHasCreateChild = false; //在日志中是否已生成子节点 DAL.TaskLog.ITaskLogDetail daldt = ClassFactory.GetITaskLogDetailDAL(3); BLL.TaskLog.ITaskLogDetail logdtbll = ClassFactory.GetITaskLogDetailBLL(3); Model.Synergismlogdt dt = daldt.GetModel(autoid); List <Model.Synergismlogdt> nextlist = logdtbll.GetNext(dt, null); foreach (Model.Synergismlogdt next in nextlist) { if (!string.IsNullOrEmpty(next.Cvoucherno)) { //bHasCreateChild = true; res += 100; } } BaseData bd = ClassFactory.GetBaseData(dt); bd.Dodelete = true; bd.Synergismlogdt = dt; bd.Fristsynergismlogdt = daldt.GetFirst(dt); BaseOp op = ClassFactory.GetBaseOp(dt); op.MakeData(dt, bd); Model.APIData apidata = bd as Model.APIData; string vouchid = op.GetCodeorID(dt.Cvoucherno, bd, "id"); if (!string.IsNullOrEmpty(vouchid)) { res += 10; //本节点已生成 if (((APIOp)op).CheckAuditStatus(dt.Cvoucherno, apidata.ConnectInfo.Constring)) { res += 1; } } return(res); }
/// <summary> /// 重做 /// </summary> /// <param name="autoid"></param> /// <param name="id"></param> public void ReDo(string autoid, string id) { DAL.TaskLog.ITaskLogDetail dal = ClassFactory.GetITaskLogDetailDAL(3); Model.Synergismlogdt dt = dal.GetModel(autoid); dt.Cstatus = Constant.SynergisnLogDT_Cstatus_NoDeal; dt.Cerrordesc = string.Empty; //如果有单号,先删除再重发 if (string.IsNullOrEmpty(dt.Cvoucherno)) { DeleteSyncDt(1, autoid, id); } dal.Update(dt); DAL.TaskLog.ITaskLogMain logdal = ClassFactory.GetITaskLogMainDAL(3); Model.Synergismlog log = logdal.GetModel(id); log.Cstatus = Constant.SynerginsLog_Cstatus_Dealing; logdal.Update(log); }
/// <summary> /// 删除 /// </summary> /// <param name="taskType">任务类别 0 CQ 1 XT</param> /// <param name="autoid"></param> /// <param name="id"></param> /// <returns></returns> public DealResult DeleteSyncDt(int tasktype, string autoid, string id) { DealResult dr = new DealResult(); try { DAL.TaskLog.ITaskLogDetail daldt = ClassFactory.GetITaskLogDetailDAL(tasktype); BLL.TaskLog.ITaskLogDetail logdtbll = ClassFactory.GetITaskLogDetailBLL(tasktype); Model.Synergismlogdt dt = daldt.GetModel(autoid); #region 协同 校验 if (tasktype.Equals("1")) { List <Model.Synergismlogdt> nextlist = logdtbll.GetNext(dt, null); foreach (Model.Synergismlogdt next in nextlist) { if (!string.IsNullOrEmpty(next.Cvoucherno)) { dr.ResultNum = -1; dr.ResultMsg = "下游单据未删除,请先删除下游单据"; return(dr); } } } #endregion BaseData bd = ClassFactory.GetBaseData(dt); bd.Dodelete = true; bd.Synergismlogdt = dt; bd.Fristsynergismlogdt = daldt.GetFirst(dt); BaseOp op = ClassFactory.GetBaseOp(dt); op.MakeData(dt, bd); string vouchid = op.GetCodeorID(dt.Cvoucherno, bd, "id"); if (!string.IsNullOrEmpty(vouchid)) { dr = op.UndoMake(bd, dt); } if (dr.ResultNum < Constant.ResultNum_NoError) { return(dr); } dt.Cstatus = Constant.SynergisnLogDT_Cstatus_Delete; dt.Cvoucherno = string.Empty; daldt.Update(dt); DAL.TaskLog.ITaskLogMain logdal = ClassFactory.GetITaskLogMainDAL(3); Model.Synergismlog log = logdal.GetModel(id); log.Cstatus = Constant.SynerginsLog_Cstatus_Wait; logdal.Update(log); } catch (Exception ex) { dr.ResultMsg = ex.ToString(); dr.ResultNum = -1; } return(dr); }