pan
2025-11-12 d44b4cfa1bf7858236f928488f3777617b6c7449
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
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using WIDESEA_Core;
using WIDESEA_Core.BaseRepository;
using WIDESEA_Core.BaseServices;
using WIDESEA_Core.CodeConfigEnum;
using WIDESEA_Core.Enums;
using WIDESEA_IBasicService;
using WIDESEA_Model.Models;
using WIDESEA_Model.Models.Basic;
 
namespace WIDESEA_BasicService
{
 
    internal class MaterialExpirationDateService : ServiceBase<Dt_MaterialExpirationDate, IRepository<Dt_MaterialExpirationDate>>, IMaterialExpirationDateService
    {
 
        public MaterialExpirationDateService(IRepository<Dt_MaterialExpirationDate> BaseDal) : base(BaseDal)
        {
        }
 
        public IRepository<Dt_MaterialExpirationDate> Repository => BaseDal;
 
 
        public WebResponseContent ReceiveMaterialExpirationDate(Dt_MaterialExpirationDate model, int operateType)
        {
            try
            {
                return operateType switch
                {
                    1 => AddMaterialExpirationDate(model),
                    2 => UpdateMaterialExpirationDate(model),
                    3 => DeleteMaterialExpirationDate(model),
 
                    _ => WebResponseContent.Instance.OK(),
                };
            }
            catch (Exception ex)
            {
                return WebResponseContent.Instance.Error(ex.Message);
            }
        }
 
        public WebResponseContent AddMaterialExpirationDate(Dt_MaterialExpirationDate model)
        {
            try
            {
                var dbdata = Db.Queryable<Dt_MaterialExpirationDate>().Where(x => x.MaterialCode == model.MaterialCode).First();
                if (dbdata!= null)
                {
                    UpdateMaterialExpirationDate(model);
                }
                else
                {
                    model.Creater = "MES";
                    model.CreateDate = DateTime.Now;
 
                    BaseDal.AddData(model);
                }
                return WebResponseContent.Instance.OK();
            }
            catch (Exception ex)
            {
                return WebResponseContent.Instance.Error(ex.Message);
            }
        }
        public WebResponseContent UpdateMaterialExpirationDate(Dt_MaterialExpirationDate model)
        {
            try
            {
 
                var dbdata = Db.Queryable<Dt_MaterialExpirationDate>().Where(x => x.MaterialCode == model.MaterialCode).First();
                if (dbdata == null)
                {
                    return WebResponseContent.Instance.Error($"未找到物料信息");
                }
 
                dbdata.ThreeExtensionDays = model.ThreeExtensionDays;
                dbdata.OneExtensionDays = model.OneExtensionDays;
                dbdata.TwoExtensionDays = model.TwoExtensionDays;
                dbdata.Enable=model.Enable; 
                dbdata.ValidityDays = model.ValidityDays;
                dbdata.Modifier = "MES";
                dbdata.ModifyDate =DateTime.Now;
                BaseDal.UpdateData(dbdata);
                return WebResponseContent.Instance.OK();
            }
            catch (Exception ex)
            {
                return WebResponseContent.Instance.Error(ex.Message);
            }
        }
 
        public WebResponseContent DeleteMaterialExpirationDate(Dt_MaterialExpirationDate model)
        {
            try
            {
                var dbdata = Db.Queryable<Dt_MaterialExpirationDate>().Where(x => x.MaterialCode == model.MaterialCode).First();
                if (dbdata == null)
                {
                    return WebResponseContent.Instance.Error($"未找到物料信息");
                }
                BaseDal.DeleteData( dbdata );   
 
                return WebResponseContent.Instance.OK();
            }
            catch (Exception ex)
            {
                return WebResponseContent.Instance.Error(ex.Message);
            }
        }
 
    }
}