private bool grdTrafficsGoods_Restore() { oTrafficGood.ClearError(); oTrafficGood.ClearFilters(); // собираем услови¤ TermsSelect(); grdTrafficsGoods.GetGridState(); Report oReportTrafficsGoods = new Report(); oReportTrafficsGoods.ReportTraffics("Goods", oCellSource.MainTable, oCellTarget.MainTable, dDateBegBirth, dDateEndBirth, dDateBegConfirm, dDateEndConfirm, bConfirmed, bSuccess, null, sSelectedUsersIDList, null, "", sSelectedPackingsIDList); grdTrafficsGoods.IsLockRowChanged = true; grdTrafficsGoods.Restore(oReportTrafficsGoods.MainTable); return(oReportTrafficsGoods.ErrorNumber == 0); }
private void btnEdit_Click(object sender, EventArgs e) { if (grdData.CurrentRow == null) { return; } // перечитаем текущее состояние задания oTrafficCur.ClearError(); oTrafficCur.ClearData(); oTrafficCur.ClearFilters(); oTrafficCur.ID = (int)grdData.CurrentRow.Cells["grcID"].Value; oTrafficCur.FillData(); if (oTrafficCur.ErrorNumber != 0 || oTrafficCur.MainTable.Rows.Count != 1) { return; } DataRow r = oTrafficCur.MainTable.Rows[0]; if ((bool)r["IsConfirmed"]) { RFMMessage.MessageBoxError("Задание уже подтверждено.\n" + "Изменение невозможно."); return; } if (r["DateAccept"] != DBNull.Value) { RFMMessage.MessageBoxError("Задание уже выполняется.\n" + "Изменение невозможно."); return; } if (StartForm(new frmTrafficsGoodsEdit((int)oTrafficCur.ID)) == DialogResult.Yes) { grdData_Restore(); } }
private void btnSave_Click(object sender, EventArgs e) { if (oTraffic.ID == null) { RFMMessage.MessageBoxError("Не определена операция перемещения штук/коробок..."); return; } decimal?nQntConfirmed = numBoxConfirmed.Value * _nInBox + numRestQntConfirmed.Value; int? nCellFinishID = null; int? nTrafficErrorID = null; bool bLockCellFinish = false; if (optNoChanges.Checked) { if (RFMMessage.MessageBoxYesNo("Положение товара не меняется.\nСохранить только сведения и пользователе, устройстве и приоритете задания?") != DialogResult.Yes) { return; } nQntConfirmed = null; } if (optCellTarget.Checked) { if (cboCellTargetAddress.SelectedValue == null || cboCellTargetAddress.SelectedIndex < 0) { RFMMessage.MessageBoxError("Не определена ячейка-приемник...\nСохранение невозможно."); return; } if (nQntConfirmed > _nQntWished) { if (RFMMessage.MessageBoxYesNo("Количество фактически перемещенного товара больше, чем заказано.\nВсе-таки сохранить?") != DialogResult.Yes) { return; } } if (nQntConfirmed == 0) { if (RFMMessage.MessageBoxYesNo("Не указано количество фактически перемещенного товара.\nВсе-таки сохранить?") != DialogResult.Yes) { return; } } if (RFMMessage.MessageBoxYesNo("Регистрируется перемещение товара в ячейку-приемник " + cboCellTargetAddress.Text + ".\nСохранить?") == DialogResult.Yes) { nCellFinishID = (int)cboCellTargetAddress.SelectedValue; } else { return; } } if (optError.Checked) { if (cboTrafficError.SelectedValue == null || cboTrafficError.SelectedIndex < 0) { RFMMessage.MessageBoxError("Не указана ошибка при неудачном выполнении задания...\nУкажите характер ошибки."); return; } bLockCellFinish = chkLockCellFinish.Checked; if (RFMMessage.MessageBoxYesNo("Регистрируется неудачное выполнение задания с ошибкой.\n" + "Товар считается размещенным в ячейке-источнике " + cboCellSourceAddress.Text + ".\n" + ((bLockCellFinish) ? "Ячейка-приемник " + cboCellTargetAddress.Text + " блокируется.\n\n" : "") + "Сохранить?") == DialogResult.Yes) { nTrafficErrorID = (int)cboTrafficError.SelectedValue; nCellFinishID = (int)cboCellTargetAddress.SelectedValue; nQntConfirmed = 0; } else { return; } } int?nUserID, nDeviceID, nPriority; nUserID = nDeviceID = null; if (cboUser.SelectedValue != null && (int)cboUser.SelectedValue > 0) { nUserID = (int)cboUser.SelectedValue; } if (cboDevice.SelectedValue != null && (int)cboDevice.SelectedValue > 0) { nDeviceID = (int)cboDevice.SelectedValue; } nPriority = Convert.ToInt32(numPriority.Value); oTraffic.ClearError(); oTraffic.SaveDataPartial((int)oTraffic.ID, nQntConfirmed, nUserID, nDeviceID, nPriority, nTrafficErrorID, bLockCellFinish); if (oTraffic.ErrorNumber == 0) { RFMMessage.MessageBoxInfo((optNoChanges.Checked) ? "Сохранено." : "Подтверждено."); { DialogResult = DialogResult.Yes; Dispose(); } } }
private bool grdData_Restore() { RFMCursorWait.Set(true); RFMCursorWait.LockWindowUpdate(FindForm().Handle); oTrafficCur.ID = null; oTrafficList.ClearError(); oTrafficList.ClearFilters(); oTrafficList.ID = null; oTrafficList.IDList = null; // собираем условия // штрих-код //if (txtBarCode.Text.Trim().Length > 0) // oTrafficList.BarCode = txtBarCode.Text.Trim(); // даты if (!dtrDates.dtpBegDate.IsEmpty) { oTrafficList.FilterDateBeg = dtrDates.dtpBegDate.Value.Date; } if (!dtrDates.dtpEndDate.IsEmpty) { oTrafficList.FilterDateEnd = dtrDates.dtpEndDate.Value.Date; } // ИСТОЧНИК // ячейка Cell oCellSource = new Cell(); oCellSource.ClearData(); if ((txtCellSourceBarCode.Text.Trim().Length > 0) | (txtCellSourceAddress.Text.Trim().Length > 0)) { if (txtCellSourceBarCode.Text.Trim().Length > 0) { oCellSource.BarCode = txtCellSourceBarCode.Text.Trim(); } if (txtCellSourceAddress.Text.Trim().Length > 0) { oCellSource.FilterAddress = txtCellSourceAddress.Text.Trim(); } oCellSource.FillData(); if (oCellSource.MainTable.Rows.Count > 0) { StringBuilder sbCS = new StringBuilder(""); foreach (DataRow r in oCellSource.MainTable.Rows) { sbCS = sbCS.Append(r["ID"].ToString() + ","); } if (sbCS.Length > 0) { oTrafficList.FilterCellsSourceList = sbCS.ToString(); } } else { oTrafficList.FilterCellsSourceList = "-1"; } } // зоны if (sSelectedStoresZonesSourceIDList.Length > 0) { oTrafficList.FilterStoresZonesSourceList = sSelectedStoresZonesSourceIDList; } if (sSelectedStoresZonesTypesSourceIDList.Length > 0) { oTrafficList.FilterStoresZonesTypesSourceList = sSelectedStoresZonesTypesSourceIDList; } // ПРИЕМНИК // ячейка Cell oCellTarget = new Cell(); oCellTarget.ClearData(); if ((txtCellTargetBarCode.Text.Trim().Length > 0) | (txtCellTargetAddress.Text.Trim().Length > 0)) { if (txtCellTargetBarCode.Text.Trim().Length > 0) { oCellTarget.BarCode = txtCellTargetBarCode.Text.Trim(); } if (txtCellTargetAddress.Text.Trim().Length > 0) { oCellTarget.FilterAddress = txtCellTargetAddress.Text.Trim(); } oCellTarget.FillData(); if (oCellTarget.MainTable.Rows.Count > 0) { StringBuilder sbCT = new StringBuilder(""); foreach (DataRow r in oCellTarget.MainTable.Rows) { sbCT = sbCT.Append(r["ID"].ToString() + ","); } if (sbCT.Length > 0) { oTrafficList.FilterCellsTargetList = sbCT.ToString(); } } else { oTrafficList.FilterCellsTargetList = "-1"; } } // зоны if (sSelectedStoresZonesTargetIDList.Length > 0) { oTrafficList.FilterStoresZonesTargetList = sSelectedStoresZonesTargetIDList; } if (sSelectedStoresZonesTypesTargetIDList.Length > 0) { oTrafficList.FilterStoresZonesTypesTargetList = sSelectedStoresZonesTypesTargetIDList; } // состояние операций if (optNotConfirmed.Checked) { oTrafficList.FilterConfirmed = false; } if (optSuccess.Checked) { oTrafficList.FilterConfirmed = true; oTrafficList.FilterSuccess = true; } if (optNotSuccess.Checked) { oTrafficList.FilterConfirmed = true; oTrafficList.FilterSuccess = false; } // приходы-расходы if (txtInputBarCode.Text.Length > 0) { Input oInputFilter = new Input(); oInputFilter.BarCode = txtInputBarCode.Text.Trim(); oInputFilter.FillData(); // если не нашли ни одного прихода по указанному штрих-коду, // все равно должны передать "", чтобы не получить ни одного перемещения string sInputBarCode = ""; foreach (DataRow r in oInputFilter.MainTable.Rows) { sInputBarCode = sInputBarCode + "," + r["ID"].ToString(); } oTrafficList.FilterInputsList = sInputBarCode; } if (txtOutputBarCode.Text.Length > 0) { Output oOutputFilter = new Output(); oOutputFilter.BarCode = txtOutputBarCode.Text.Trim(); oOutputFilter.FillData(); // если не нашли ни одного прихода по указанному штрих-коду, // все равно должны передать "", чтобы не получить ни одного перемещения string sOutputBarCode = ""; foreach (DataRow r in oOutputFilter.MainTable.Rows) { sOutputBarCode = sOutputBarCode + "," + r["ID"].ToString(); } oTrafficList.FilterOutputsList = sOutputBarCode; } // пользователи if (sSelectedUsersIDList.Length > 0) { oTrafficList.FilterUsersList = sSelectedUsersIDList; } // выбранные товары if (sSelectedPackingIDList.Length > 0) { oTrafficList.FilterPackingsList = sSelectedPackingIDList; } // grdData.GetGridState(); oTrafficList.FillData(); grdData.IsLockRowChanged = true; grdData.Restore(oTrafficList.MainTable); //grdData.GridSource.Sort = "ID desc"; RFMCursorWait.LockWindowUpdate(IntPtr.Zero); RFMCursorWait.Set(false); return(oTrafficList.ErrorNumber == 0); }