1
yhj
2024-07-24 5e5d945e91568b973faa27d8ab0bcef99fc4a6c5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
using System;
using System.Data;
using CSFrameworkV5.Models;
using CSFrameworkV5.Core;
using CSFrameworkV5.Common;
using CSFrameworkV5.Interfaces;
using CSFrameworkV5.Business;
using CSFrameworkV5.DataAccess;
using CSFrameworkV5.WebRef;
 
/*===================================================================
 *   程序说明: DH2的业务逻辑层源码
 *   作者资料: 孙中吕
 *   创建日期: 2022/07/03 01:09:09
 *   最后修改: 2022/07/03 01:09:09
 *   
 *   注: 本文件由代码生成器(Code Generator)自动生成。
 *   (此源码文件请放置在 YourProject.Business 模块) 
 *   版权所有 Copyright 2006~2022, C/S框架网(www.cscode.net)
 *===================================================================*/
 
namespace CSFrameworkV5.Business
{
    /// <summary>
    /// 业务逻辑层:bllDH2
    /// </summary>
    public class bllDH2 : bllBaseBusiness
    {
         private dalDH2 _DAL = null;
 
         /// <summary>
         /// 构造器
         /// </summary>
         public bllDH2()
         {
             _KeyFieldName = PURDHA.__KeyName; //主键字段
             _SummaryTableName = PURDHA.__TableName;//表名
             _WriteDataLog = false;//保存数据修改日志
             _DAL = new dalDH2(Loginer.CurrentUser);//实例化DAL层
         }
 
          /// <summary>
          ///根据单据号码取业务数据
          /// </summary>
          public override DataSet GetDataByKey(string keyValue, bool resetCurrent)
          {
              DataSet ds = _DAL.GetDataByKey(keyValue); 
              this.SetNumericDefaultValue(ds); //设置预设值
              if (resetCurrent) _CurrentBusiness = ds; //保存当前业务数据的对象引用
              return ds;
           }
 
          /// <summary>
          ///删除单据
          /// </summary>
          public override bool Delete(string keyValue)
          {
              return _DAL.Delete(keyValue);
          }
 
          /// <summary>
          ///检查单号是否存在
          /// </summary>
          public bool CheckNoExists(string keyValue)
          {
              return _DAL.CheckNoExists(keyValue);
          }
 
          /// <summary>
          ///保存数据
          /// </summary>
          public override SaveResult Update(DataSet saveData)
          {
              return _DAL.Update(saveData); //交给数据层处理
          }
 
          /// <summary>
          ///审核单据
          /// </summary>
          public override bool ApprovalBusiness(DataRow summaryRow)
          {
               string key = ConvertEx.ToString(summaryRow[_KeyFieldName]);
 
               QueryApproval P = new QueryApproval
               {
                   DBID = Loginer.CurrentUser.DBID,
                   TableName = _SummaryTableName,
                   KeyFieldName = _KeyFieldName,
                   KeyValue = key,
                   AppDate = DateTime.Now,
                   AppUser = Loginer.CurrentUser.Account,
                   FlagApp = "Y"
               };
 
               if (_DAL.ApprovalBusiness(P))
               {
                   summaryRow[CommonFields.AppDate] = DateTime.Now;
                   summaryRow[CommonFields.AppUser] = Loginer.CurrentUser.Account;
                   summaryRow[CommonFields.FlagApp] = "Y";
                   return true;
               }
               else
                   return false;
          }
 
          /// <summary>
          ///反审核单据。
          /// </summary>
          public override bool ApprovalBusinessUndo(DataRow summaryRow)
          {
               string key = ConvertEx.ToString(summaryRow[_KeyFieldName]);
 
               QueryApproval P = new QueryApproval
               {
                   DBID = Loginer.CurrentUser.DBID,
                   TableName = _SummaryTableName,
                   KeyFieldName = _KeyFieldName,
                   KeyValue = key,
                   AppDate = DateTime.Now,
                   AppUser = Loginer.CurrentUser.Account,
                   FlagApp = "N"
               };
 
               if (_DAL.ApprovalBusiness(P))
               {
                   summaryRow[CommonFields.AppDate] = DateTime.Now;
                   summaryRow[CommonFields.AppUser] = Loginer.CurrentUser.Account;
                   summaryRow[CommonFields.FlagApp] = "N";
                   return true;
               }
               else
                   return false;
          }
 
          /// <summary>
          ///新增一张业务单据
          /// </summary>
          public override void NewBusiness()
          {
              DataTable summaryTable = _CurrentBusiness.Tables[PURDHA.__TableName];
              DataRow row = summaryTable.Rows.Add();     
 
              //新增状态:主表记录设置初始值
              row[PURDHA.__KeyName] = "*自动生成*";
              row[PURDHA.CREATEUSER] = Loginer.CurrentUser.Account;
              row[PURDHA.CREATETIME] = DateTime.Now;
              row[PURDHA.MODIFYUSER] = Loginer.CurrentUser.Account;
              row[PURDHA.MODIFYTIME] = DateTime.Now;
           }
 
          /// <summary>
          ///创建用于保存的临时数据
          /// </summary>
          public override DataSet CreateSaveData(DataSet sourceData)
          {
             this.DataBindRow.EndEdit();
 
             //创建用于保存的临时数据,包含主表或明细表
             DataSet save = new DataSet();
             save.Tables.Add(this.DataBinder.Copy());//将<主表>添加到数据集
 
             this.UpdateCommonFieldsValue(save.Tables[0]); //更新公共字段数据
 
             //收集明细表数据
             DataTable detail = sourceData.Tables[PURDHB.__TableName].GetChanges();
             if (detail != null)
             {
                this.UpdateCommonFieldsValue(detail); //更新明细表的公共字段数据
                save.Tables.Add(detail); //将<明细表>添加到数据集 
             }
 
 
             return save;
          }
 
          /// <summary>
          ///查询数据
          /// </summary>
        public DataTable Query(QueryDH2 P)
        {
            return _DAL.Query(P);
        }
 
          /// <summary>
          ///获取报表数据
          /// </summary>
          public DataSet QueryReportData(QueryDH2 P)
          {
              return _DAL.QueryReportData(P);
          }
 
     }
}