Beispiel #1
0
 private void btnDelete_Click(object sender, EventArgs e)
 {
     try
     {
         if (sv.OperateDetails.Count < 1)
         {
             MessageBox.Show("没有操作的数据!");
             return;
         }
         if (MessageBox.Show("确定要删除吗?",
                             "提示", MessageBoxButtons.YesNo, MessageBoxIcon.Question, MessageBoxDefaultButton.Button1) == DialogResult.Yes)
         {
             int rindex = dataGrid1.CurrentRowIndex;
             //已扫描数量
             decimal sub      = sv.OperateDetails[rindex].ScanCount;
             string  cinvcode = sv.OperateDetails[rindex].cinvcode;
             string  cbatch   = sv.OperateDetails[rindex].CBATCH;
             dataGrid1.DataSource = null;
             sv.OperateDetails.RemoveAt(rindex);//删除操作数据
             dataGrid1.DataSource = sv.OperateDetails;
             //查询时同时根据存货编码与批次
             SaleBackGSPDetail dd = sv.U8Details.Find((delegate(SaleBackGSPDetail tdd) { return(tdd.cinvcode.Equals(cinvcode) && tdd.CBATCH.Equals(cbatch)); }));
             dd.ScanCount -= sub;
         }
     }
     catch (Exception er)
     {
         MessageBox.Show(er.Message);
     }
 }
Beispiel #2
0
        /// <summary>
        /// 点击提交按钮处理事件
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void btnSubmit_Click(object sender, EventArgs e)
        {
            //验证数量是否已扫描完
            if (salebackgsp.U8Details.Count == salebackgsp.OperateDetails.Count)
            {
                foreach (SaleBackGSPDetail detail in salebackgsp.U8Details)
                {
                    SaleBackGSPDetail ddtmp = salebackgsp.OperateDetails.Find(delegate(SaleBackGSPDetail tdd) { return(tdd.cinvcode.Equals(detail.cinvcode) && tdd.CBATCH.Equals(detail.CBATCH)); });
                    if (ddtmp == null)
                    {
                        MessageBox.Show("还有没扫描的货物:" + detail.cinvname);
                        return;
                    }
                    if (ddtmp.FQUANTITY != ddtmp.ScanCount)
                    {
                        MessageBox.Show("货物:" + detail.cinvname + "的数量与单据数量不符");
                        return;
                    }
                }
            }
            else
            {
                MessageBox.Show("还有没扫描的货物!");
                return;
            }

            salebackgsp.CMAKER = Common.CurrentUser.UserName;
            try
            {
                this.Enabled   = false;
                Cursor.Current = Cursors.WaitCursor;
                string errMsg = "";
                int    rt     = SaleBackGSPBusiness.SaveSaleBackGSP(salebackgsp, out errMsg);
                if (rt == 0)
                {
                    MessageBox.Show("提交成功!");
                }
                else
                {
                    MessageBox.Show("提交失败!" + errMsg);
                }
                Close();
            }
            catch (Exception ex)
            {
                MessageBox.Show("提交失败!" + ex.Message);
            }
            finally
            {
                this.Enabled   = true;
                Cursor.Current = Cursors.Default;
            }
        }
Beispiel #3
0
        /// <summary>
        /// 清空数据
        /// </summary>
        private void Clear()
        {
            lblInvName.Text    = "";
            lblInvStd.Text     = "";
            lblcBatch.Text     = "";
            lblProAddress.Text = "";
            lblEnterprise.Text = "";
            lblProDate.Text    = "";
            lblValidDate.Text  = "";
            lblScanedNum.Text  = "";
            txtCount.Text      = "";
            txtCount.Enabled   = false;
            txtLable.Text      = "";
            txtLable.Focus();
            dd = null;

            //默认为二维码
            IsQR = true;
            cmbCBatch.DataSource = null;
        }
Beispiel #4
0
        /// <summary>
        /// 若为一维码,批次选择改变事件
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void cmbCBatch_SelectedIndexChangeed(object sender, EventArgs e)
        {
            //如果数据源为空,直接返回
            if (cmbCBatch.DataSource == null)
            {
                return;
            }
            //获取选择的对象
            dd = cmbCBatch.SelectedItem as SaleBackGSPDetail;
            lblInvName.Text    = dd.cinvname;
            lblInvStd.Text     = dd.cinvstd;
            lblProAddress.Text = dd.CDEFINE22;
            lblEnterprise.Text = dd.cinvdefine1;
            lblScanedNum.Text  = dd.ScanCount.ToString("F2");
            //lblcBatch.Text = dd.cbatch;
            lblProDate.Text   = Convert.ToDateTime(dd.DPRODATE).ToString("yyyy-MM-dd");
            lblValidDate.Text = Convert.ToDateTime(dd.CVALDATE).ToString("yyyy-MM-dd");

            txtCount.Enabled = true;
            txtCount.Focus();
        }
Beispiel #5
0
        private void txtCount_KeyPress(object sender, KeyPressEventArgs e)
        {
            if (e.KeyChar == 13 && txtCount.Text.Length > 0)
            {
                if (txtCount.Text.Trim() == "")
                {
                    MessageBox.Show("未输入数量!");
                    txtCount.SelectAll();
                    txtCount.Focus();
                    return;
                }
                if (!isNumeric(txtCount.Text))
                {
                    MessageBox.Show("请输入数字!");
                    txtCount.SelectAll();
                    txtCount.Focus();
                    return;
                }
                if (Convert.ToDecimal(txtCount.Text) <= 0)
                {
                    MessageBox.Show("请输入正确的数量!");
                    txtCount.SelectAll();
                    txtCount.Focus();
                    return;
                }
                //添加外观质量情况
                dd.COUTINSTANCE = cmbCoutinstance.SelectedItem.ToString();

                SaleBackGSPDetail ddtmp = salebackgsp.OperateDetails.Find(delegate(SaleBackGSPDetail tdd) { return(tdd.cinvcode.Equals(dd.cinvcode) && tdd.CBATCH.Equals(dd.CBATCH)); });
                {
                    if (ddtmp == null)
                    {
                        ddtmp = dd.CreateAttriveDetail();
                        decimal qty = Convert.ToDecimal(txtCount.Text);
                        if (qty <= ddtmp.FQUANTITY - ddtmp.ScanCount) //这里减去的是已扫描数据中的已扫数量(因为它与来源数据中的已扫描数量一样)
                        {
                            dd.ScanCount    = qty;                    //在来源单据中修改已扫描数据是为了显示“已扫描数量”
                            ddtmp.ScanCount = qty;
                            salebackgsp.OperateDetails.Add(ddtmp);
                            btnDone.Enabled   = true;
                            btnSubmit.Enabled = true;
                            lblScanedNum.Text = ddtmp.ScanCount.ToString("F2");
                            Clear();
                        }
                        else
                        {
                            MessageBox.Show("输入数量大于单据数量");
                            txtCount.SelectAll();
                            txtCount.Focus();
                        }
                    }
                    else
                    {
                        decimal qty = Convert.ToDecimal(txtCount.Text);
                        if (qty <= ddtmp.FQUANTITY - ddtmp.ScanCount)
                        {
                            dd.ScanCount     += qty;
                            ddtmp.ScanCount  += qty;
                            lblScanedNum.Text = ddtmp.ScanCount.ToString("F2");

                            Clear();
                        }
                        else
                        {
                            MessageBox.Show("输入数量大于单据数量");
                            txtCount.SelectAll();
                            txtCount.Focus();
                        }
                    }
                }
            }
        }
Beispiel #6
0
        private void txtLable_KeyPress(object sender, KeyPressEventArgs e)
        {
            //成品标签扫描
            if (e.KeyChar == 13 && txtLable.Text.Length > 0)
            {
                try
                {
                    //首先判断扫描的是一维条码还是二维条码,条件是否包含@
                    string   strBarcode = txtLable.Text.Trim();
                    string[] barcode    = new string[7] {
                        "", "", "", "", "", "", ""
                    };
                    if (strBarcode.IndexOf('@') == -1)//没有  找到@,说明该条码是一维条码
                    {
                        string errMsg   = string.Empty;
                        string cInvCode = string.Empty;//存货编码
                        //根据一维条码查询存货编码
                        bool flag = Common.GetCInvCode(strBarcode, out cInvCode, out errMsg);
                        if (!flag)
                        {
                            MessageBox.Show("没有找到对应的存货编码!" + errMsg);
                            return;
                        }
                        barcode[2] = cInvCode;
                        IsQR       = false;
                    }
                    else //二维码
                    {
                        barcode = strBarcode.Split('@');
                        ///根据20121109日讨论结果:以69码为主,根据69码查询对应的存货编码
                        string errMsg   = string.Empty;
                        string cInvCode = string.Empty;//存货编码
                        //根据一维条码查询存货编码
                        bool flag = Common.GetCInvCode(barcode[0], out cInvCode, out errMsg);
                        if (!flag)
                        {
                            MessageBox.Show("没有找到对应的存货编码!" + errMsg);
                            return;
                        }
                        barcode[2] = cInvCode;
                        IsQR       = true;
                    }

                    /*
                     * dd = salebackgsp.U8Details.Find(delegate(SaleBackGSPDetail tdd) { return tdd.cinvcode.Equals(barcode[2]); }); //&&tdd.CBATCH.Equals(barcode[3]); });
                     * if (dd == null)
                     * {
                     *  MessageBox.Show("条码错误:存货编码不在订单中");
                     *  txtLable.SelectAll();
                     *  txtLable.Focus();
                     *  txtCount.Enabled = false;
                     * }
                     * else
                     * {
                     *  lblInvName.Text = dd.cinvname;
                     *  lblInvStd.Text = dd.cinvstd;
                     *  lblProAddress.Text = dd.CDEFINE22;
                     *  ///查找已扫描集合中是否有该产品,若有则取对应的扫描数据,若没有则取来源集合中的数量(默认为0)
                     *  SaleBackGSPDetail temp = salebackgsp.OperateDetails.Find(delegate(SaleBackGSPDetail s) { return s.cinvcode.Equals(dd.cinvcode); });
                     *  if (temp != null)
                     *  {
                     *      lblScanedNum.Text = temp.ScanCount.ToString("F3");
                     *  }
                     *  else
                     *  {
                     *      lblScanedNum.Text = dd.ScanCount.ToString("F3");
                     *  }
                     *  lblcBatch.Text = dd.CBATCH;
                     *  lblProDate.Text = Convert.ToDateTime(dd.DPRODATE).ToString("yyyy-MM-dd"); //dd.DPRODATE.Substring(0,10);
                     *  lblValidDate.Text = Convert.ToDateTime(dd.DVDATE).ToString("yyyy-MM-dd"); //dd.DVDATE.Substring(0, 10);
                     *  txtCount.Enabled = true;
                     *  txtCount.SelectAll();
                     *  txtCount.Focus();
                     *
                     * }
                     * */
                    ///如果是二维码
                    if (IsQR)
                    {
                        //按存货编码和批次查询
                        dd = salebackgsp.U8Details.Find(delegate(SaleBackGSPDetail tdd) { return(tdd.cinvcode.Equals(barcode[2]) && tdd.CBATCH.Equals(barcode[3])); });
                        if (dd == null)
                        {
                            MessageBox.Show("条码错误:存货编码不在订单中");
                            return;
                        }

                        lblInvName.Text    = dd.cinvname;
                        lblInvStd.Text     = dd.cinvstd;
                        lblProAddress.Text = dd.CDEFINE22;
                        lblEnterprise.Text = dd.cinvdefine1;
                        lblcBatch.Text     = dd.CBATCH;
                        lblScanedNum.Text  = dd.ScanCount.ToString("F2");
                        lblProDate.Text    = Convert.ToDateTime(dd.DPRODATE).ToString("yyyy-MM-dd");
                        lblValidDate.Text  = Convert.ToDateTime(dd.CVALDATE).ToString("yyyy-MM-dd");
                        //txtCount.Text = dd.iquantity.ToString("F3");
                        txtCount.Enabled = true;
                        txtCount.Focus();
                    }
                    //如果是一维码
                    else
                    {
                        //只按存货编码查询
                        dd = salebackgsp.U8Details.Find(delegate(SaleBackGSPDetail tdd) { return(tdd.cinvcode.Equals(barcode[2])); });
                        if (dd == null)
                        {
                            MessageBox.Show("条码错误:存货编码不在订单中");
                            return;
                        }

                        //然后查询该存货编码的所有批次绑定到cmbCbatch中
                        var v = from t in salebackgsp.U8Details where t.cinvcode == dd.cinvcode select t;
                        cmbCBatch.DataSource    = new BindingSource(v, null);
                        cmbCBatch.DisplayMember = "CBATCH";
                        cmbCBatch.ValueMember   = "CBATCH";
                    }
                }
                catch (Exception ex)
                {
                    MessageBox.Show(ex.Message);
                }
            }
        }