亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專(zhuān)輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? vcreatefromshipment.java

?? Java寫(xiě)的ERP系統(tǒng)
?? JAVA
字號(hào):
/******************************************************************************
 * The contents of this file are subject to the   Compiere License  Version 1.1
 * ("License"); You may not use this file except in compliance with the License
 * You may obtain a copy of the License at http://www.compiere.org/license.html
 * Software distributed under the License is distributed on an  "AS IS"  basis,
 * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License for
 * the specific language governing rights and limitations under the License.
 * The Original Code is                  Compiere  ERP & CRM  Business Solution
 * The Initial Developer of the Original Code is Jorg Janke  and ComPiere, Inc.
 * Portions created by Jorg Janke are Copyright (C) 1999-2001 Jorg Janke, parts
 * created by ComPiere are Copyright (C) ComPiere, Inc.;   All Rights Reserved.
 * Contributor(s): ______________________________________.
 *****************************************************************************/
package org.compiere.grid;

import javax.swing.table.*;
import java.util.*;
import java.sql.*;
import java.math.*;
import java.text.*;
import java.beans.*;
import java.awt.event.*;

import org.compiere.util.*;
import org.compiere.model.*;
import org.compiere.plaf.*;
import org.compiere.grid.ed.*;

/**
 *  Create Transactions for Shipments - from PO Orders or AP Invoices
 *
 *  @author Jorg Janke
 *  @version  $Id: VCreateFromShipment.java,v 1.12 2003/01/27 06:14:49 jjanke Exp $
 */
public class VCreateFromShipment extends VCreateFrom implements VetoableChangeListener
{
	/**
	 *  Protected Constructor
	 *  @param mTab MTab
	 */
	VCreateFromShipment(MTab mTab)
	{
		super (mTab);
	//	Log.trace(Log.l1_User, "VCreateFromShipment");
	}   //  VCreateFromShipment

	/**  Loaded Invoice             */
	private int                     m_C_Invoice_ID = 0;

	/**
	 *  Dynamic Init
	 *  @throws Exception if Lookups cannot be initialized
	 *  @return true if initialized
	 */
	protected boolean dynInit() throws Exception
	{
		Log.trace(Log.l3_Util, "VCreateFromShipment.dynInit");
		setTitle(Msg.getElement(Env.getCtx(), "M_InOut_ID", false) + " .. " + Msg.translate(Env.getCtx(), "CreateFrom"));

		parameterBankPanel.setVisible(false);
		shipmentLabel.setVisible(false);
		shipmentField.setVisible(false);

		//  load Locator
		int AD_Column_ID = 3537;            //  M_InOut.M_Locator_ID
		MLocator locator = new MLocator(Env.getCtx(), m_WindowNo);
		locatorField = new VLocator ("M_Locator_ID", true, false, true,	locator);

		initBPartner(false);
		bPartnerField.addVetoableChangeListener(this);
		return true;
	}   //  dynInit

	/**
	 *  Init Details - load invoices not shipped
	 *  @param C_BPartner_ID BPartner
	 */
	protected void initBPDetails(int C_BPartner_ID)
	{
		Log.trace(Log.l3_Util, "VCreateFromShipment.initBPDetails");

		//  load AP Invoice closed or complete
		invoiceField.removeActionListener(this);
		invoiceField.removeAllItems();
		//	None
		KeyNamePair pp = new KeyNamePair(0,"");
		invoiceField.addItem(pp);
		StringBuffer display = new StringBuffer("i.DocumentNo||' - '||")
			.append(DB.TO_CHAR("DateInvoiced", DisplayType.Date, Env.getAD_Language(Env.getCtx())))
			.append("|| ' - ' ||")
			.append(DB.TO_CHAR("GrandTotal", DisplayType.Amount, Env.getAD_Language(Env.getCtx())));
		//
		StringBuffer sql = new StringBuffer("SELECT i.C_Invoice_ID,").append(display)
		   .append(" FROM C_Invoice i "
		   + "WHERE i.C_BPartner_ID=? AND i.IsSOTrx='N' AND i.DocStatus IN ('CL','CO')"
		   + " AND i.C_Invoice_ID IN "
			   + "(SELECT il.C_Invoice_ID FROM C_InvoiceLine il"
			   + " LEFT OUTER JOIN M_MatchInv mi ON (il.C_InvoiceLine_ID=mi.C_InvoiceLine_ID) "
			   + "GROUP BY il.C_Invoice_ID,mi.C_InvoiceLine_ID,il.QtyInvoiced "
			   + "HAVING (il.QtyInvoiced<>SUM(mi.Qty) AND mi.C_InvoiceLine_ID IS NOT NULL)"
			   + " OR mi.C_InvoiceLine_ID IS NULL) "
		   + "ORDER BY i.DateInvoiced");

		try
		{
			PreparedStatement pstmt = DB.prepareStatement(sql.toString());
			pstmt.setInt(1, C_BPartner_ID);
			ResultSet rs = pstmt.executeQuery();
			while (rs.next())
			{
				pp = new KeyNamePair(rs.getInt(1), rs.getString(2));
				invoiceField.addItem(pp);
			}
			rs.close();
			pstmt.close();
		}
		catch (SQLException e)
		{
			Log.error ("VCreateFromShipment.initBPDetails\nSQL=" + sql, e);
		}
		invoiceField.setSelectedIndex(0);
		invoiceField.addActionListener(this);
	}   //  initBPDetails


	/**
	 *  Action Listener
	 *  @param e event
	 */
	public void actionPerformed(ActionEvent e)
	{
		super.actionPerformed(e);
		Log.trace(Log.l3_Util, "VCreateFromShipment.actionPerformed " + e.getActionCommand());

		//  Order
		if (e.getSource().equals(orderField))
		{
			KeyNamePair pp = (KeyNamePair)orderField.getSelectedItem();
			if (pp == null || pp.getKey() == 0)
				;
			else
			{
				int C_Order_ID = pp.getKey();
				//  set Invoice and Shipment to Null
				invoiceField.setSelectedIndex(-1);
				shipmentField.setSelectedIndex(-1);
				loadOrder(C_Order_ID, false);
			}
		}
		//  Invoice
		else if (e.getSource().equals(invoiceField))
		{
			KeyNamePair pp = (KeyNamePair)invoiceField.getSelectedItem();
			if (pp == null || pp.getKey() == 0)
				;
			else
			{
				int C_Invoice_ID = pp.getKey();
				//  set Order and Shipment to Null
				orderField.setSelectedIndex(-1);
				shipmentField.setSelectedIndex(-1);
				loadInvoice(C_Invoice_ID);
			}
		}
	}   //  actionPerformed


	/**
	 *  Change Listener
	 *  @param e event
	 */
	public void vetoableChange (PropertyChangeEvent e)
	{
		Log.trace(Log.l3_Util, "VCreateFromShipment.vetoableChange " + e.getPropertyName() + "=" + e.getNewValue());

		//  BPartner - load Order/Invoice/Shipment
		if (e.getPropertyName() == "C_BPartner_ID")
		{
			int C_BPartner_ID = ((Integer)e.getNewValue()).intValue();
			initBPartnerOIS (C_BPartner_ID, false);
		}
		tableChanged(null);
	}   //  vetoableChange


	/**
	 *  Load Data - Invoice
	 *  @param C_Invoice_ID Invoice
	 */
	private void loadInvoice (int C_Invoice_ID)
	{
		Log.trace(Log.l3_Util, "VCreateFromShipment.loadInvoice - " + C_Invoice_ID);
		m_C_Invoice_ID = C_Invoice_ID;      //  save

		Vector data = new Vector();
		StringBuffer sql = new StringBuffer("SELECT l.QtyInvoiced-SUM(NVL(mi.Qty,0)),"
			+ " l.C_UOM_ID,uom.UOMSymbol,"   							//  2..3
			+ " l.M_Product_ID,p.Name, l.C_InvoiceLine_ID,l.Line,"      //  4..7
			+ " l.C_OrderLine_ID ");                   					//  8
		if (Env.isBaseLanguage(Env.getCtx(), "C_UOM"))
		{
			sql.append("FROM C_UOM uom, C_InvoiceLine l, M_Product p, M_MatchInv mi ");
			sql.append("WHERE l.C_UOM_ID=uom.C_UOM_ID");
		}
		else
		{
			sql.append("FROM C_UOM_Trl uom, C_InvoiceLine_v l, M_Product p, M_MatchInv mi ");
			sql.append("WHERE l.C_UOM_ID=uom.C_UOM_ID AND uom.AD_Language='").append(Env.getAD_Language(Env.getCtx())).append("'");
		}
		sql.append(" AND l.M_Product_ID=p.M_Product_ID"
			+ " AND l.C_InvoiceLine_ID=mi.C_InvoiceLine_ID(+)"
			+ " AND l.C_Invoice_ID=? " 									//  #1
			+ "GROUP BY l.QtyInvoiced,l.C_UOM_ID,uom.UOMSymbol,l.M_Product_ID,p.Name, l.C_InvoiceLine_ID,l.Line,l.C_OrderLine_ID "
			+ "ORDER BY l.Line");
		try
		{
			PreparedStatement pstmt = DB.prepareStatement(sql.toString());
			pstmt.setInt(1, C_Invoice_ID);
			ResultSet rs = pstmt.executeQuery();
			while (rs.next())
			{
				Vector line = new Vector(7);
				line.add(new Boolean(false));           //  0-Selection
				line.add(new Double(rs.getDouble(1)));  //  1-Qty
				KeyNamePair pp = new KeyNamePair(rs.getInt(2), rs.getString(3).trim());
				line.add(pp);                           //  2-UOM
				pp = new KeyNamePair(rs.getInt(4), rs.getString(5));
				line.add(pp);                           //  3-Product
				int i = rs.getInt(8);
				if (rs.wasNull())
					line.add(null);                     //  4-Order
				else
					line.add(new KeyNamePair(i," "));
				line.add(null);                     	//  5-Ship
				pp = new KeyNamePair(rs.getInt(6), rs.getString(7));
				line.add(pp);                           //  6-Invoice
				data.add(line);
			}
			rs.close();
			pstmt.close();
		}
		catch (SQLException e)
		{
			Log.error ("VCreateFromShipment.loadInvoice", e);
		}
		loadTableOIS (data);
	}   //  loadInvoice


	/**
	 *  List number of rows selected
	 */
	protected void info()
	{
		TableModel model = dataTable.getModel();
		int rows = model.getRowCount();
		int count = 0;
		for (int i = 0; i < rows; i++)
		{
			if (((Boolean)model.getValueAt(i, 0)).booleanValue())
				count++;
		}
		statusBar.setStatusLine(String.valueOf(count));
	}   //  info


	/**
	 *  Save - create Shipments
	 *  @return true if saved
	 */
	protected boolean save()
	{
		Log.trace(Log.l3_Util, "VCreateFromShipment.save");
		//  fixed values

		Integer loc = (Integer)locatorField.getValue();
		if (loc == null || loc.intValue() == 0)
		{
			locatorField.setBackground(CompierePLAF.getFieldBackground_Error());
			return false;
		}
		int M_Locator_ID = loc.intValue();
		//
		int AD_Client_ID = ((Integer)m_mTab.getValue("AD_Client_ID")).intValue();
		int AD_Org_ID = ((Integer)m_mTab.getValue("AD_Org_ID")).intValue();
		int CreatedBy = Env.getContextAsInt(Env.getCtx(), "#AD_User_ID");
		int M_InOut_ID = ((Integer)m_mTab.getValue("M_InOut_ID")).intValue();
		Log.trace( Log.l4_Data, "Client=" + AD_Client_ID + ", Org=" + AD_Org_ID
			+ ", User=" + CreatedBy + ", InOut=" + M_InOut_ID + ", Locator=" + M_Locator_ID);

		/**
		 *  Selected        - 0
		 *  Qty             - 1
		 *  C_UOM_ID        - 2
		 *  M_Product_ID    - 3
		 *  OrderLine       - 4
		 *  ShipmentLine    - 5
		 *  InvoiceLine     - 6
		 */

		//  Lines
		TableModel model = dataTable.getModel();
		int rows = model.getRowCount();
		for (int i = 0; i < rows; i++)
		{
			if (((Boolean)model.getValueAt(i, 0)).booleanValue())
			{
				//  variable values
				int M_InOutLine_ID = DB.getKeyNextNo(Env.getCtx(), m_WindowNo, "M_InOutLine");
				Double d = (Double)model.getValueAt(i, 1);              //  1-Qty
				BigDecimal MovementQty = new BigDecimal(d.doubleValue());
				KeyNamePair pp = (KeyNamePair)model.getValueAt(i, 2);   //  2-UOM
				int C_UOM_ID = pp.getKey();
				pp = (KeyNamePair)model.getValueAt(i, 3);               //  3-Product
				int M_Product_ID = pp.getKey();
				int C_OrderLine_ID = 0;
				pp = (KeyNamePair)model.getValueAt(i, 4);               //  4-OrderLine
				if (pp != null)
					C_OrderLine_ID = pp.getKey();
				int C_InvoiceLine_ID = 0;
				pp = (KeyNamePair)model.getValueAt(i, 6);               //  6-InvoiceLine
				if (pp != null)
					C_InvoiceLine_ID = pp.getKey();
				boolean isInvoiced = (C_InvoiceLine_ID != 0);
				//
				Log.trace(Log.l5_DData, "Line=" + M_InOutLine_ID + ", Qty=" + MovementQty
					+ ", Product=" + M_Product_ID + ", OrderLine=" + C_OrderLine_ID + ", InvoiceLine=" + C_InvoiceLine_ID);
				//
				String Description = null;

				StringBuffer sql = new StringBuffer("INSERT INTO M_InOutLine");
				sql.append("(M_InOutLine_ID,M_InOut_ID,");
				sql.append("AD_Client_ID,AD_Org_ID,IsActive,Created,CreatedBy,Updated,UpdatedBy,");
				sql.append("Line,Description,");
				sql.append("M_Product_ID,C_UOM_ID,MovementQty,");
				sql.append("C_OrderLine_ID,M_Locator_ID,IsInvoiced)");
				sql.append(" VALUES (");
				//
				sql.append(M_InOutLine_ID).append(",").append(M_InOut_ID).append(",");
				sql.append(AD_Client_ID).append(",").append(AD_Org_ID).append(",'Y',");
				sql.append("SysDate,").append(CreatedBy).append(",SysDate,").append(CreatedBy).append(",");
				//  Line,
				sql.append("(SELECT (NVL(Max(Line),0))+10 FROM M_InOutLine WHERE M_InOut_ID=").append(M_InOut_ID).append("),");
				//  Description
				if (Description == null || Description.length() == 0)
					sql.append("NULL,");
				else
					sql.append("'").append(Description).append("',");
				//  M_Product_ID,C_UOM_ID,MovementQty,
				sql.append(M_Product_ID).append(",").append(C_UOM_ID).append(",").append(MovementQty).append(",");
				//  C_OrderLine_ID,M_Locator_ID,IsInvoiced
				if (C_OrderLine_ID == 0)
					sql.append("NULL,");
				else
					sql.append(C_OrderLine_ID).append(",");
				sql.append(M_Locator_ID).append(",");
				sql.append(isInvoiced ? "'Y')" : "'N')");
				//
				int no = DB.executeUpdate(sql.toString());
				if (no != 1)
					Log.error("VCreateFromShipment.save - Line NOT created #" + no);
			}   //   if selected
		}   //  for all rows

		/**
		 *  Update Header
		 *  - if linked to another order/invoice - remove link
		 *  - if no link set it
		 */
		if (m_C_Order_ID != 0)
		{
			String sql = "UPDATE M_InOut SET C_Order_ID=NULL"
				+ " WHERE M_InOut_ID=" + M_InOut_ID
				+ " AND C_Order_ID IS NOT NULL AND C_Order_ID <> " + m_C_Order_ID;
			int no = DB.executeUpdate(sql);
			if (no == 0)
			{
				sql = "UPDATE M_InOut SET C_Order_ID=" + m_C_Order_ID
					+ " WHERE M_InOut_ID=" + M_InOut_ID;
				no = DB.executeUpdate(sql);
			}
		}
		if (m_C_Invoice_ID != 0)
		{
			String sql = "UPDATE M_InOut SET C_Invoice_ID=NULL"
				+ " WHERE M_InOut_ID=" + M_InOut_ID
				+ " AND C_Invoice_ID IS NOT NULL AND C_Invoice_ID <> " + m_C_Invoice_ID;
			int no = DB.executeUpdate(sql);
			if (no == 0)
			{
				sql = "UPDATE M_InOut SET C_Invoice_ID=" + m_C_Invoice_ID
					+ " WHERE M_InOut_ID=" + M_InOut_ID;
				no = DB.executeUpdate(sql);
			}
		}
		return true;
	}   //  save

}   //  VCreateFromShipment

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品人妖ts系列视频| 国产精品视频麻豆| 成人蜜臀av电影| 亚洲成人在线免费| 国产视频一区二区在线| 欧美猛男超大videosgay| 国产精品一级在线| 免费观看一级特黄欧美大片| 国产精品色在线观看| 日韩欧美国产综合在线一区二区三区| 99久久免费国产| 国产精品影视天天线| 日韩国产精品大片| 一个色在线综合| 国产精品久久久久永久免费观看 | 激情图片小说一区| 亚洲日本va午夜在线电影| 337p粉嫩大胆噜噜噜噜噜91av | 紧缚捆绑精品一区二区| 亚洲国产综合人成综合网站| 中文字幕一区二区三区视频| 久久色在线观看| 日韩精品一区二区三区三区免费 | 精品91自产拍在线观看一区| 欧美日韩激情一区| 91免费看片在线观看| 一本到三区不卡视频| 成人一区二区三区| 国产精品一线二线三线精华| 蜜桃在线一区二区三区| 日韩精品一二三区| 午夜久久久久久久久| 亚洲一区二区三区国产| 亚洲桃色在线一区| 亚洲日本韩国一区| 亚洲欧美视频在线观看| 亚洲图片另类小说| 亚洲日本在线a| 亚洲人成7777| 亚洲女同ⅹxx女同tv| 亚洲色图.com| 一区二区三区日韩在线观看| 夜夜精品浪潮av一区二区三区| 亚洲女同一区二区| 亚洲国产欧美在线| 亚洲国产成人va在线观看天堂| 一区二区理论电影在线观看| 亚洲一区在线视频观看| 亚洲成人av中文| 日韩av不卡在线观看| 麻豆精品久久精品色综合| 久久精品国产99国产| 麻豆精品视频在线观看| 国产精品一区二区三区99| 成人免费毛片高清视频| 91蜜桃视频在线| 欧美精品在线一区二区三区| 日韩精品在线一区二区| 国产日韩av一区二区| 国产精品护士白丝一区av| 最新国产精品久久精品| 亚洲午夜羞羞片| 青青草91视频| 懂色av中文字幕一区二区三区 | 欧美刺激午夜性久久久久久久| 欧美成人vps| 亚洲国产精品ⅴa在线观看| 亚洲男人天堂av| 免费人成精品欧美精品| 国产成人综合自拍| 欧美在线免费观看视频| 欧美成人video| 亚洲日本青草视频在线怡红院| 亚洲不卡在线观看| 国产精品亚洲一区二区三区妖精 | 国产成人免费视频精品含羞草妖精| 波多野结衣中文字幕一区二区三区| 色哟哟日韩精品| 日韩欧美色综合网站| 欧美国产乱子伦 | 日本一区二区三区四区在线视频 | 国产美女视频91| 91片在线免费观看| 日韩欧美中文字幕一区| 1000精品久久久久久久久| 丝瓜av网站精品一区二区 | 国产伦精品一区二区三区免费迷| av电影一区二区| 日韩欧美一区二区免费| 最新中文字幕一区二区三区| 91最新地址在线播放| 正在播放一区二区| 国产精品久久久久久久久免费相片 | 美女网站在线免费欧美精品| jlzzjlzz亚洲日本少妇| 日韩亚洲欧美在线观看| 亚洲色图.com| 国产精品一区二区x88av| 欧美理论片在线| 亚洲青青青在线视频| 激情文学综合插| 欧美日本一区二区在线观看| 国产精品无人区| 国产专区综合网| 884aa四虎影成人精品一区| 亚洲色图在线播放| 粉嫩绯色av一区二区在线观看| 在线不卡的av| 一区二区三区在线观看网站| 国产电影精品久久禁18| 日韩欧美在线综合网| 亚洲国产综合色| 色欲综合视频天天天| 欧美国产1区2区| 精品一区二区精品| 欧美一区二区三区电影| 亚洲一区二区四区蜜桃| 91欧美一区二区| 国产精品理论片在线观看| 国产精品一二三在| 欧美zozozo| 麻豆成人久久精品二区三区红 | 国产精品亚洲视频| 精品日韩一区二区| 免费观看30秒视频久久| 欧美日韩高清一区二区| 亚洲午夜精品网| 色成年激情久久综合| 亚洲色图在线播放| 91免费国产视频网站| 综合久久久久综合| 91免费观看国产| 亚洲欧美另类在线| 91精彩视频在线| 亚洲小说春色综合另类电影| 91成人免费网站| 亚洲国产一区在线观看| 欧美色视频在线观看| 亚洲国产精品一区二区www| 欧美怡红院视频| 亚洲第一激情av| 欧美电影在哪看比较好| 蜜桃视频一区二区三区| 日韩精品一区二区三区中文精品 | 99国内精品久久| 国产精品久久毛片a| 成人午夜伦理影院| 亚洲私人黄色宅男| 日本韩国欧美在线| 亚洲成av人片在线观看| 欧美一级爆毛片| 欧美性高清videossexo| 亚洲影视资源网| 制服丝袜亚洲精品中文字幕| 六月丁香综合在线视频| 亚洲精品一区二区在线观看| 国产很黄免费观看久久| 亚洲视频在线一区二区| 欧美网站一区二区| 免费一级欧美片在线观看| 欧美精品一区二区三区很污很色的| 国模一区二区三区白浆| 日本一区二区不卡视频| 色噜噜狠狠色综合欧洲selulu| 亚瑟在线精品视频| 精品国免费一区二区三区| 高清在线不卡av| 亚洲一区二区三区四区在线观看 | 欧美高清视频在线高清观看mv色露露十八 | 中文字幕第一区综合| 色偷偷久久一区二区三区| 日韩精品电影一区亚洲| 久久久精品中文字幕麻豆发布| www.激情成人| 日本欧美一区二区在线观看| 26uuu国产一区二区三区| 99精品视频一区二区三区| 日韩精品国产精品| 国产女人aaa级久久久级| 欧美日免费三级在线| 国产精品一区二区男女羞羞无遮挡| 亚洲欧洲一区二区在线播放| 91精品国产综合久久精品app| 国产精品99久| 亚洲v日本v欧美v久久精品| 久久久久久99久久久精品网站| 一本色道**综合亚洲精品蜜桃冫| 蜜桃av一区二区三区电影| 亚洲少妇最新在线视频| 精品久久久久久久久久久院品网| av一区二区三区| 老色鬼精品视频在线观看播放| 中文字幕在线视频一区| 日韩视频在线永久播放| 91网站最新网址| 国产精品一线二线三线| 日韩中文字幕麻豆| 亚洲欧美激情视频在线观看一区二区三区 | 欧美日韩精品免费| 成人a免费在线看|