コード例 #1
0
        public async Task <ActionResult> Delete(Guid id)
        {
            IBLL.IGoodsManager goodsManager = new GoodsManager();
            await goodsManager.DeleteGoods(id);

            return(RedirectToAction("GoodsList"));
        }
コード例 #2
0
 public void TestDeleteGoods()
 {
     try
     {
         //删除主商品
         string errorMessage;
         _goodManager.DeleteGoods(null, "", Guid.Empty, out errorMessage);
     }
     catch (Exception ex)
     {
         Assert.IsTrue(!string.IsNullOrEmpty(ex.Message));
     }
 }
コード例 #3
0
ファイル: NewGoods.aspx.cs プロジェクト: mkbiltek2019/ERP_6.0
        //批量删除
        protected void btn_Del_Click(object sender, EventArgs e)
        {
            if (Request["ckId"] != null)
            {
                IGoodsOrder       goodsOrder        = new GoodsOrder(GlobalConfig.DB.FromType.Read);
                var               purchasingManager = new PurchasingManager(new Purchasing(GlobalConfig.DB.FromType.Read), _goodsCenterSao, null, null, null);
                IStorageRecordDao storageRecordDao  = new StorageRecordDao(GlobalConfig.DB.FromType.Read);

                var        errorMsg    = new StringBuilder();
                var        goodsIdList = new List <Guid>();
                var        goodsIdsAndGoodsNamesAndGoodsAuditState = Request["ckId"].Split(',');
                List <int> stockStates = new List <int>
                {
                    (int)StorageRecordState.WaitAudit,
                    (int)StorageRecordState.Refuse,
                    (int)StorageRecordState.Refuse,
                    (int)StorageRecordState.Approved,
                    (int)StorageRecordState.Finished
                };
                foreach (var item in goodsIdsAndGoodsNamesAndGoodsAuditState)
                {
                    var    goodsId   = new Guid(item.Split('&')[0]);
                    string goodsName = item.Split('&')[1];
                    if (goodsOrder.SelectSemiStockAtOneYearByGoodsId(goodsId, null, null, 365, stockStates))
                    {
                        errorMsg.Append("“").Append(goodsName).Append("”该商品1年内有进行过出入库记录,不允许删除!").Append("\\n");
                        continue;
                    }
                    if (purchasingManager.SelectPurchasingNoCompleteByGoodsId(goodsId, null))
                    {
                        errorMsg.Append("“").Append(goodsName).Append("”该商品存在未完成的采购单,不允许删除!").Append("\\n");
                        continue;
                    }
                    if (storageRecordDao.IsExistNormalStorageRecord(goodsId, null))
                    {
                        errorMsg.Append("“").Append(goodsName).Append("”该商品存在未审核的出入库单据,不允许删除!").Append("\\n");
                        continue;
                    }
                    if (CacheCollection.Filiale.GetHeadList().Where(f => f.FilialeTypes.Contains((int)FilialeType.EntityShop)).Any(source => StockSao.IsExistGoodsStock(source.ID, goodsId, new List <Guid>())))
                    {
                        errorMsg.Append("“").Append(goodsName).Append("”此商品门店有库存,不允许删除!").Append("\\n");
                        continue;
                    }

                    goodsIdList.Add(goodsId);
                }
                if (!string.IsNullOrEmpty(errorMsg.ToString()))
                {
                    MessageBox.Show(this, errorMsg.ToString());
                }
                else
                {
                    //删除主商品
                    string errorMessage;
                    var    personnel = CurrentSession.Personnel.Get();
                    var    isSuccess = _goodManager.DeleteGoods(goodsIdList, personnel.RealName, personnel.PersonnelId, out errorMessage);
                    if (isSuccess)
                    {
                        MessageBox.AppendScript(this, "setTimeout(function(){ refreshGrid(); }, " + GlobalConfig.PageAutoRefreshDelayTime + ");");
                        MessageBox.Show(this, "主商品删除成功!");
                    }
                    else
                    {
                        MessageBox.Show(this, "主商品删除失败!");
                    }
                }
            }
            else
            {
                MessageBox.Show(this, "请选择相关数据!");
            }
        }