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
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
using CSFramework.DB;
using CSFrameworkV5.Common;
using CSFrameworkV5.Core;
using CSFrameworkV5.DataAccess;
using CSFrameworkV5.Interfaces;
using CSFrameworkV5.Models;
using CSFrameworkV5.Order.womdaa;
using System;
using System.Data;
 
/*===================================================================
 *   程序说明: MES_LINE的业务逻辑层源码
 *   作者资料: 孙中吕
 *   创建日期: 2024/05/30 04:02:30
 *   最后修改: 2024/05/30 04:02:30
 *
 *   注: 本文件由代码生成器(Code Generator)自动生成。
 *   (此源码文件请放置在 YourProject.Business 模块)
 *   版权所有 Copyright 2006~2024, C/S框架网(www.cscode.net)
 *===================================================================*/
 
namespace CSFrameworkV5.Business
{
    /// <summary>
    /// 业务逻辑层:bllMES_LINE
    /// </summary>
    public class bllMES_LINE : bllBaseBusiness
    {
        private dalMES_LINE _DAL = null;
 
        /// <summary>
        /// 构造器
        /// </summary>
        public bllMES_LINE()
        {
            _KeyFieldName = MES_LINE.__KeyName; //主键字段
            _SummaryTableName = MES_LINE.__TableName; //表名
            _WriteDataLog = false; //保存数据修改日志
            _CurrentAppNAME = "产线维护";
            _DAL = new dalMES_LINE(Loginer.CurrentUser); //实例化DAL层
        }
 
        /// <summary>
        ///根据单据号码取业务数据
        /// </summary>
        public override DataSet GetDataByKey(string keyValue, bool resetCurrent)
        {
            var ds = _DAL.GetDataByKey(keyValue);
            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)
        {
            var key = ConvertEx.ToString(summaryRow[_KeyFieldName]);
 
            var P = new QueryApproval
            {
                DBID = Loginer.CurrentUser.DBID,
                TableName = _SummaryTableName,
                KeyFieldName = _KeyFieldName,
                KeyValue = key,
                AppDate = DateTime.Now,
                AppUser = Loginer.CurrentUser.Account,
                FlagApp = "Y",
                AppNAME = _CurrentAppNAME
            };
 
            if (_DAL.ApprovalBusiness(P))
            {
                summaryRow[CommonFields.AppDate] = DateTime.Now;
                summaryRow[CommonFields.AppUser] = Loginer.CurrentUser.Account;
                summaryRow[CommonFields.FlagApp] = "Y";
                summaryRow[CommonFields.AppNAME] = _CurrentAppNAME;
                return true;
            }
            else
            {
                return false;
            }
        }
 
        /// <summary>
        ///反审核单据。
        /// </summary>
        public override bool ApprovalBusinessUndo(DataRow summaryRow)
        {
            var key = ConvertEx.ToString(summaryRow[_KeyFieldName]);
 
            var P = new QueryApproval
            {
                DBID = Loginer.CurrentUser.DBID,
                TableName = _SummaryTableName,
                KeyFieldName = _KeyFieldName,
                KeyValue = key,
                AppDate = DateTime.Now,
                AppUser = Loginer.CurrentUser.Account,
                FlagApp = "N",
                AppNAME = _CurrentAppNAME
            };
 
            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()
        {
            var summaryTable =
                _CurrentBusiness.Tables[MES_LINE.__TableName];
            var row = summaryTable.Rows.Add();
 
//新增状态:主表记录设置初始值
            row[MES_LINE.__KeyName] = Guid.NewGuid();
        }
 
        /// <summary>
        ///创建用于保存的临时数据
        /// </summary>
        public override DataSet CreateSaveData(DataSet sourceData)
        {
            DataBindRow.EndEdit();
 
//创建用于保存的临时数据,包含主表或明细表
            var save = new DataSet();
            save.Tables.Add(DataBinder.Copy()); //将<主表>添加到数据集
 
            var row = save.Tables[0].Rows[0];
 
            var lineNo = row["LINE_NO"].ToString();
            var lineName = row["LINE_NAME"].ToString();
 
            if (string.IsNullOrEmpty(lineNo))
            {
                Msg.Warning("线体编号不能为空!");
                return null;
            }
 
            if (string.IsNullOrEmpty(lineName))
            {
                Msg.Warning("线体名称不能为空!");
                return null;
            }
 
            var db = SqlSugarHelper.GetInstance();
 
            //如果是新增状态下就校验工单是否重复
            if (row.RowState == DataRowState.Added)
            {
                var count = db.Queryable<MesLine>()
                    .Where(a => a.LineNo == lineNo || a.LineName == lineName)
                    .Count();
                if (count > 0)
                {
                    Msg.Warning("产线编号或机台已存在,不允许重复!");
                    return null;
                }
            }
 
            UpdateCommonFieldsValue(save.Tables[0]); //更新公共字段数据
 
            return save;
        }
 
        /// <summary>
        ///查询数据
        /// </summary>
        public DataTable Query(QueryMES_LINE P)
        {
            return _DAL.Query(P);
        }
 
        /// <summary>
        ///获取报表数据
        /// </summary>
        public DataSet QueryReportData(QueryMES_LINE P)
        {
            return _DAL.QueryReportData(P);
        }
 
        public DataTable GETDAT(string sql)
        {
            return _DAL.GetDataTable(sql);
        }
    }
}