Esempio n. 1
0
        public bool Update(EF.Factory entity)
        {
            var code      = entity.Code.ToUpper();
            var item      = _dbContext.Factorys.FirstOrDefault(x => x.ID == entity.ID);
            var kpiLevels = _dbContext.KPILevels.Where(f => f.TableID == item.Code).ToList();

            kpiLevels.ForEach(a =>
            {
                a.TableID = entity.Code;
            });


            var SOP = _dbContext.Factorys.Find(entity.ID);

            SOP.Name    = entity.Name;
            SOP.Code    = code;
            SOP.LevelID = entity.LevelID;
            try
            {
                _dbContext.SaveChanges();
                return(true);
            }
            catch
            {
                //logging
                return(false);
            }
        }
Esempio n. 2
0
        public int Add(EF.Factory entity)
        {
            var code = entity.Code.ToUpper();
            List <EF.KPILevel> kpiLevelList = new List <EF.KPILevel>();

            if (_dbContext.Factorys.FirstOrDefault(x => x.Code == code) != null)
            {
                return(2);
            }
            if (_dbContext.KPILevels.FirstOrDefault(x => x.KPICode == entity.Code) != null)
            {
                return(2);
            }
            //get all kpi
            var kpis = new KPIAdminDAO().GetAll();

            foreach (var kpi in kpis)
            {
                var kpilevel = new EF.KPILevel();
                kpilevel.TableID = code;
                kpilevel.KPICode = kpi.Code;
                kpilevel.Name    = kpi.Name;
                kpilevel.Checked = false;
                kpiLevelList.Add(kpilevel);
            }
            try
            {
                entity.Code = entity.Code.ToUpper();
                _dbContext.Factorys.Add(entity);
                _dbContext.KPILevels.AddRange(kpiLevelList);
                _dbContext.SaveChanges();
                return(1);
            }
            catch
            {
                return(0);
            }
        }