📄 stocktransfersubmitframe.java
字号:
}
//表格行选择事件
public void jTable1_valueChanged(ListSelectionEvent e) {
//重新计算金额
this.recountGoodsAmount();
}
//查询方法
public void search(){
//取得查询选项
int selectedIndex = jComboBox1.getSelectedIndex();
//取得编辑框的变量
String searchValue = jTextField1.getText().trim();
String startDateStr = jTextField2.getText().trim();
String endDateStr = jTextField3.getText().trim();
if (selectedIndex == 0 | selectedIndex == 1 | selectedIndex == 2 |
selectedIndex == 3 | selectedIndex == 4) {
if (searchValue.length() == 0) {
JOptionPane.showMessageDialog(null, "请输入查询值");
return;
}
switch (selectedIndex) {
case 0:
//根据商品调出单编号取得记录
stockLedgers = stockManagementData.getStockLedgerByStringField(
ledgerDate, "orderId", searchValue, 2);
break;
case 1:
//根据商品调出员取得记录
stockLedgers = stockManagementData.getStockLedgerByStringField(
ledgerDate, "submitUser", searchValue, 2);
break;
case 2:
//根据商品验收员取得记录
stockLedgers = stockManagementData.getStockLedgerByStringField(
ledgerDate, "checkUser", searchValue, 2);
break;
case 3:
//根据调出仓库名字取得记录
stockLedgers = stockManagementData.getStockLedgerByStringField(
ledgerDate, "warehouse", searchValue, 2);
break;
case 4:
//根据调入仓库名字取得记录,调入仓库名字保存在调出单的commitUser字段
stockLedgers = stockManagementData.getStockLedgerByStringField(
ledgerDate, "commitUser", searchValue, 2);
break;
}
}else{
java.sql.Timestamp startDate = dataMethod.transferDate(startDateStr);
java.sql.Timestamp endDate = dataMethod.transferEndDate(endDateStr);
if(startDate == null | endDate == null){
JOptionPane.showMessageDialog(null, "日期输入错误,正确的日期格式是"
+ "yyyy-mm-dd(年-月-日),如2004-1-1");
return;
}
//根据日期取得记录
stockLedgers = stockManagementData.getStockLedgerByOrderDate(ledgerDate,
startDate, endDate, 2);
}
this.showSearchStockLedger();
}
//单击事件
public void actionPerformed(ActionEvent e) {
//取得按钮的动作字符串
String actionCommand = e.getActionCommand().trim();
//检查打开的账套是否当前账套
if (actionCommand.equals("createStockLedger") |
actionCommand.equals("updateStockLedger") |
actionCommand.equals("cancelStockLedger") |
actionCommand.equals("restoreStockLedger")) {
int result = stockManagementData.isCurrentLedger(ledgerDate);
if(result == 0){
JOptionPane.showMessageDialog(null, ledgerDate + "是往期账套,不能进行添加、修改和撤消操作.");
return;
}
}
//检查商品调出单是否完成
if (actionCommand.equals("updateStockLedger") |
actionCommand.equals("cancelStockLedger") |
actionCommand.equals("restoreStockLedger")) {
if(jList1.isSelectionEmpty()){
JOptionPane.showMessageDialog(null, "请选择商品调出单.");
return;
}
int selectedIndex = jList1.getSelectedIndex();
int onProcess = Integer.parseInt(stockLedgers[selectedIndex][11]);
if(onProcess == 2){
JOptionPane.showMessageDialog(null, stockLedgers[selectedIndex][0]
+ "商品调出单已经完成,不可以进行修改和撤消操作.");
return;
}
}
if (actionCommand.equals("search")) {
//查询
search();
}else if(actionCommand.equals("createStockLedger")){
action = "create";
this.clearStockLedger();
this.checkBtn(true);
this.checkSubBtn(true);
}else if(actionCommand.equals("updateStockLedger")){
action = "update";
this.checkBtn(true);
}else if(actionCommand.equals("cancelStockLedger")){
action = "cancel";
this.checkBtn(true);
}else if(actionCommand.equals("restoreStockLedger")){
action = "restore";
this.checkBtn(true);
}else if(actionCommand.equals("ok")){
int selectedIndex = jList1.getSelectedIndex();
//创建库存账套数据表的单个记录数组
String[] stockLedger = new String[13];
//取得商品调出单的值
stockLedger[0] = ""; //单据编号
stockLedger[1] = "2"; //2表示商品调出单
stockLedger[2] = ""; //关联标识
stockLedger[3] = user.getUserName(); //调出用户
stockLedger[4] = jTextField9.getText().trim(); //调入仓库
stockLedger[5] = ""; //验收用户
stockLedger[6] = "";
stockLedger[7] = "";
stockLedger[8] = jTextField8.getText().trim(); //调出仓库
stockLedger[9] = jTextField10.getText().trim(); //调出日期
stockLedger[10] = jTextField11.getText().trim(); //验收日期
stockLedger[11] = "0";
stockLedger[12] = jTextArea1.getText().trim();
int result = 0;
if(action.equals("update") | action.equals("create")){
//检查商品调出单的调出仓库名字
result = stockManagementData.checkWarehouse(stockLedger[8]);
if(result == 0){
JOptionPane.showMessageDialog(null, stockLedger[8] + "在仓库数据库中"
+ "不存在,请打开仓库数据管理窗口添加.");
return;
}
//检查商品调出单的调入仓库名字
result = stockManagementData.checkWarehouse(stockLedger[4]);
if(result == 0){
JOptionPane.showMessageDialog(null, stockLedger[4] + "在仓库数据库中"
+ "不存在,请打开仓库数据管理窗口添加.");
return;
}
//检查商品调出日期
if(dataMethod.transferDateTime(stockLedger[9]) == null){
JOptionPane.showMessageDialog(null, "调出日期输入错误,正确的日期格式是"
+ "yyyy-mm-dd(年-月-日),如2004-1-1");
return;
}
//检查商品验收日期
if(dataMethod.transferDateTime(stockLedger[10]) == null){
JOptionPane.showMessageDialog(null, "验收日期输入错误,正确的日期格式是"
+ "yyyy-mm-dd(年-月-日),如2004-1-1");
return;
}
//检查商品调出单明细账的商品条形码、调出数量是否为负、日期
result = this.checkStockSubLedgerGoodsBarCode();
if(result == 0) return;
result = this.checkStockSubLedgerQuantity();
if(result == 0) return;
result = this.checkStockSubLedgerDate();
if(result == 0) return;
//转换表格数组
this.transferTableData();
}
if(action.equals("create")){
//检查明细账是否为空
if(stockSubLedgerObjects.length == 0){
JOptionPane.showMessageDialog(null, "明细账数据表为空,不可以创建商品调出单.");
return;
}
//添加商品调出单
result = stockManagementData.createTransferOrder(ledgerDate,
stockLedger, stockSubLedgers);
if(result == 1){
JOptionPane.showMessageDialog(null, "商品调出单添加成功,请重新执行查询操作显示新的商品调出单.");
}else{
JOptionPane.showMessageDialog(null, "商品调出单添加失败,请检查输入值是否大于字段范围.");
}
}else if (action.equals("update")){
//取得原来的单据编号
stockLedger[0] = stockLedgers[selectedIndex][0].trim();
//取得原来的关联标识
stockLedger[2] = stockLedgers[selectedIndex][2].trim();
//修改商品调出单
result = stockManagementData.updateTransferOrder(ledgerDate,
stockLedger, stockSubLedgers);
if(result == 1){
JOptionPane.showMessageDialog(null, "商品调出单修改成功.");
//更新数组的数据
for (int i = 0; i < 13; i++) {
stockLedgers[selectedIndex][i] = stockLedger[i];
}
}else{
JOptionPane.showMessageDialog(null, "商品调出单修改失败,请检查输入值是否大于字段范围.");
}
}else if (action.equals("cancel")){
//撤消商品调出单
result = stockManagementData.cancelOrRestoreTransferOrder(ledgerDate,
stockLedgers[selectedIndex][0], stockLedgers[selectedIndex][2], 1, stockLedger[12]);
if(result == 1){
JOptionPane.showMessageDialog(null, "商品调出单撤消成功.");
//更新完成状态编辑框的值
jTextField12.setText(onProcesses[1]);
//更新数组的数据
stockLedgers[selectedIndex][11] = "1";
stockLedgers[selectedIndex][12] = stockLedger[12];
}else{
JOptionPane.showMessageDialog(null, "商品调出单撤消失败.");
}
}else if (action.equals("restore")){
//恢复商品调出单
result = stockManagementData.cancelOrRestoreTransferOrder(ledgerDate,
stockLedgers[selectedIndex][0], stockLedgers[selectedIndex][2], 0, stockLedger[12]);
if(result == 1){
JOptionPane.showMessageDialog(null, "商品调出单恢复成功.");
//更新完成状态编辑框的值
jTextField12.setText(onProcesses[0]);
//更新数组的数据
stockLedgers[selectedIndex][11] = "0";
stockLedgers[selectedIndex][12] = stockLedger[12];
}else{
JOptionPane.showMessageDialog(null, "商品调出单恢复失败.");
}
}
this.checkSubBtn(false);
this.checkBtn(false);
}else if(actionCommand.equals("cancel")){
this.jList1_valueChanged(null);
this.checkBtn(false);
this.checkSubBtn(false);
}else if(actionCommand.equals("createSub")){
//为库存账套明细表添加一个空行
int objectsLength = stockSubLedgerObjects.length;
Object[][] tempObjs = new Object[objectsLength + 1][7];
System.arraycopy(stockSubLedgerObjects, 0, tempObjs, 0, objectsLength);
tempObjs[objectsLength][0] = new Integer(0);
tempObjs[objectsLength][1] = new String("");
tempObjs[objectsLength][2] = new String("");
tempObjs[objectsLength][3] = new Double(0);
tempObjs[objectsLength][4] = new Integer(0);
tempObjs[objectsLength][5] = new Double(0);
tempObjs[objectsLength][6] = new String("");
stockSubLedgerObjects = tempObjs;
this.showTableData(stockSubLedgerObjects);
}else if(actionCommand.equals("deleteSub")){
if(jTable1.getSelectedRowCount() == 0){
JOptionPane.showMessageDialog(null, "请选择明细记录.");
return;
}
//删除选择的记录
int selectedIndex = jTable1.getSelectedRow();
Object[][] tempObjs = new Object[stockSubLedgerObjects.length - 1][7];
int line = 0;
for(int i = 0; i < stockSubLedgerObjects.length; i++){
if(i == selectedIndex){
continue;
}else{
for(int j = 0; j < 7; j++){
tempObjs[line][j] = stockSubLedgerObjects[i][j];
}
line++;
}
}
stockSubLedgerObjects = tempObjs;
this.showTableData(stockSubLedgerObjects);
}else if(actionCommand.equals("exit")){
exit();
}
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -