unit U_DJBCKInPut; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, Dialogs, cxStyles, cxCustomData, cxGraphics, cxFilter, cxData, cxDataStorage, cxEdit, DB, cxDBData, cxCalendar, cxDropDownEdit, ComCtrls, ToolWin, cxGridLevel, cxGridCustomTableView, cxGridTableView, cxGridDBTableView, cxClasses, cxControls, cxGridCustomView, cxGrid, cxGridCustomPopupMenu, cxGridPopupMenu, ADODB, DBClient, cxButtonEdit, cxTextEdit, cxLookAndFeels, cxLookAndFeelPainters, cxNavigator, dxSkinsCore, dxSkinBlack, dxSkinBlue, dxSkinBlueprint, dxSkinCaramel, dxSkinCoffee, dxSkinDarkRoom, dxSkinDarkSide, dxSkinDevExpressDarkStyle, dxSkinDevExpressStyle, dxSkinFoggy, dxSkinGlassOceans, dxSkinHighContrast, dxSkiniMaginary, dxSkinLilian, dxSkinLiquidSky, dxSkinLondonLiquidSky, dxSkinMcSkin, dxSkinMetropolis, dxSkinMetropolisDark, dxSkinMoneyTwins, dxSkinOffice2007Black, dxSkinOffice2007Blue, dxSkinOffice2007Green, dxSkinOffice2007Pink, dxSkinOffice2007Silver, dxSkinOffice2010Black, dxSkinOffice2010Blue, dxSkinOffice2010Silver, dxSkinOffice2013DarkGray, dxSkinOffice2013LightGray, dxSkinOffice2013White, dxSkinPumpkin, dxSkinSeven, dxSkinSevenClassic, dxSkinSharp, dxSkinSharpPlus, dxSkinSilver, dxSkinSpringTime, dxSkinStardust, dxSkinSummer2008, dxSkinTheAsphaltWorld, dxSkinsDefaultPainters, dxSkinValentine, dxSkinVS2010, dxSkinWhiteprint, dxSkinXmas2008Blue, dxSkinscxPCPainter; type TfrmDJBCKInPut = class(TForm) cxGrid2: TcxGrid; Tv1: TcxGridDBTableView; v1Column2: TcxGridDBColumn; v2Column1: TcxGridDBColumn; v1Column9: TcxGridDBColumn; v2Column6: TcxGridDBColumn; cxGrid2Level1: TcxGridLevel; ToolBar1: TToolBar; TBAdd: TToolButton; TBDel: TToolButton; TBSave: TToolButton; TBClose: TToolButton; v1Column4: TcxGridDBColumn; DataSource3: TDataSource; CDS_Sub: TClientDataSet; ADOQueryCmd: TADOQuery; ADOQueryMain: TADOQuery; ADOQueryTemp: TADOQuery; cxGridPopupMenu2: TcxGridPopupMenu; v1Column12: TcxGridDBColumn; v1Column14: TcxGridDBColumn; v1Column6: TcxGridDBColumn; v1Column7: TcxGridDBColumn; v1Column8: TcxGridDBColumn; v1Column10: TcxGridDBColumn; v1Column1: TcxGridDBColumn; v1Column3: TcxGridDBColumn; v1Column11: TcxGridDBColumn; v1Column13: TcxGridDBColumn; v1Column16: TcxGridDBColumn; v1Column5: TcxGridDBColumn; v1Column15: TcxGridDBColumn; v1Column17: TcxGridDBColumn; v1Column18: TcxGridDBColumn; v1Column19: TcxGridDBColumn; v1Column20: TcxGridDBColumn; v1Column21: TcxGridDBColumn; ToolButton1: TToolButton; ToolButton2: TToolButton; v1Column22: TcxGridDBColumn; v1Column23: TcxGridDBColumn; ToolButton3: TToolButton; ToolButton4: TToolButton; Tv1Column1: TcxGridDBColumn; Tv1Column2: TcxGridDBColumn; Tv1Column3: TcxGridDBColumn; Tv1Column4: TcxGridDBColumn; Tv1Column5: TcxGridDBColumn; ToolButton5: TToolButton; Tv1Column6: TcxGridDBColumn; Tv1Column7: TcxGridDBColumn; Tv1Column8: TcxGridDBColumn; procedure FormClose(Sender: TObject; var Action: TCloseAction); procedure TBAddClick(Sender: TObject); procedure TBCloseClick(Sender: TObject); procedure FormShow(Sender: TObject); procedure TBDelClick(Sender: TObject); procedure TBSaveClick(Sender: TObject); procedure v1Column3PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); procedure v1Column14PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); procedure v2Column1PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); procedure v1Column5PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); procedure v1Column11PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); procedure v1Column16PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); procedure v1Column13PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); procedure v1Column18PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); procedure ToolButton1Click(Sender: TObject); procedure ToolButton2Click(Sender: TObject); procedure ToolButton4Click(Sender: TObject); procedure Tv1Column1PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); procedure v1Column8PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); procedure v2Column6PropertiesEditValueChanged(Sender: TObject); procedure ToolButton5Click(Sender: TObject); procedure Tv1Column3PropertiesEditValueChanged(Sender: TObject); private { Private declarations } function SaveCKData(): Boolean; function SaveJGCKData(): Boolean; function YSData(Order_Main10: TClientDataSet): Boolean; function YFData1(): Boolean; public { Public declarations } FBCId, FTJWJGID, Fwjgspid: string; end; var frmDJBCKInPut: TfrmDJBCKInPut; implementation uses U_DataLink, U_RTFun, U_ClothContractListHZCX, U_ZDYHelp, U_ZdyAttachGYS, U_WJGCKKCTJList, U_ProductOrderListSel, U_ProductOrderListSel1, U_CPTPJHListSel, U_ProductOrderHzListSel; {$R *.dfm} function TfrmDJBCKInPut.YSData(Order_Main10: TClientDataSet): Boolean; var CRID, YFID, PriceUnit, OrderUnit, FComTaiTou, FromSubID, khName: string; fprice, huilv: double; begin Result := False; fprice := 0; huilv := 0; PriceUnit := 'RMB'; khName := ''; with ADOQueryTemp do begin Close; SQL.Clear; sql.Add('update JYOrder_Sub SET Huilv=isnull((select Huilv from JYOrderCon_Sub X where X.SubId=JYOrder_Sub.SOrddefstr10),1) where Huilv=0'); execsql; end; with Order_Main10 do begin begin with ADOQueryTemp do begin Close; SQL.Clear; sql.Add('select A.*,fPrice=dbo.F_Get_Order_Price(A.MainID,A.subID),B.customerNoName'); sql.Add(' from JYOrder_Sub A '); sql.Add(' inner join JYOrder_main B on B.mainID=A.mainID '); sql.Add(' Where subID=''' + Trim(Order_Main10.fieldbyname('ORDSubIdRK').AsString) + ''''); Open; end; if not ADOQueryTemp.IsEmpty then begin PriceUnit := Trim(ADOQueryTemp.fieldbyname('PriceUnit').AsString); OrderUnit := Trim(ADOQueryTemp.fieldbyname('OrderUnit').AsString); fprice := ADOQueryTemp.fieldbyname('fPrice').AsFloat; huilv := ADOQueryTemp.fieldbyname('huilv').AsFloat; khName := ADOQueryTemp.fieldbyname('customerNoName').AsString; end; if huilv = 0 then huilv := 1; CRID := '0'; with ADOQueryTemp do begin Close; sql.Clear; sql.Add(' select * from YF_Money_CR '); sql.Add(' where mainID=''' + Trim(CDS_Sub.fieldbyname('SPID').AsString) + ''''); sql.Add(' and YFName=''客户退货'' '); Open; end; if ADOQueryTemp.IsEmpty then begin if GetLSNo(ADOQueryCmd, YFID, 'CS', 'YF_Money_CR', 3, 1) = False then begin Application.MessageBox('取成品应收最大号失败!', '提示', 0); Exit; end; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('select * from YF_Money_CR where 1<>1'); Open; end; with ADOQueryCmd do begin Append; FieldByName('YFID').Value := Trim(YFID); FieldByName('YFTypeId').Value := Trim(Order_Main10.fieldbyname('SPID').AsString); FieldByName('CRID').Value := StrToInt(CRID); FieldByName('Filler').Value := Trim(DName); FieldByName('CRType').Value := '应收款登记'; FieldByName('CRFlag').Value := '应收收'; FieldByName('QtyFlag').Value := 1; FieldByName('FactoryName').Value := Trim(khName); FieldByName('CRTime').Value := Trim(FormatDateTime('yyyy-MM-dd', CDS_Sub.fieldbyname('CRTime').AsDateTime)); FieldByName('YFType').Value := '自动生成'; FieldByName('ps').Value := -1 * Order_Main10.fieldbyname('PiQty').AsFloat; FieldByName('Qty').Value := -1 * Order_Main10.fieldbyname('Qty').AsFloat; FieldByName('Price').Value := fprice; FieldByName('HuiLv').Value := huilv; FieldByName('BZType').Value := Trim(PriceUnit); // FieldByName('Money').Value:=-1*format('%.2f',[Order_Main10.fieldbyname('Qty').AsFloat*fprice]); // FieldByName('BBMoney').Value:=-1*format('%.2f',[Order_Main10.fieldbyname('Qty').AsFloat*fprice*huilv]); FieldByName('QtyUnit').Value := Trim(Order_Main10.fieldbyname('QtyUnit').AsString); FieldByName('ComTaiTou').Value := Trim(khName); FieldByName('YFName').Value := '客户退货'; FieldByName('MainId').Value := Trim(Order_Main10.fieldbyname('SPID').AsString); FieldByName('subID').Value := ''; FieldByName('OrderNO').Value := Trim(Order_Main10.fieldbyname('OrderNO').AsString); FieldByName('P_CodeName').Value := Trim(Order_Main10.fieldbyname('SPName').AsString); FieldByName('P_Spec').Value := Trim(Order_Main10.fieldbyname('SPSpec').AsString); FieldByName('P_color').Value := Trim(Order_Main10.fieldbyname('SPColor').AsString); FieldByName('status').Value := '0'; Post; end; end else begin YFID := Trim(ADOQueryTemp.fieldbyname('YFID').AsString); end; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('Update YF_Money_CR Set Money=Price*Qty,BBMoney=Price*Qty*HuiLv'); sql.Add(' where YFID=''' + Trim(YFID) + ''''); ExecSQL; end; //Next; end; end; Result := True; end; procedure TfrmDJBCKInPut.FormClose(Sender: TObject; var Action: TCloseAction); begin Action := caFree; end; procedure TfrmDJBCKInPut.TBAddClick(Sender: TObject); var FCGM, FCGS: string; begin if CDS_Sub.IsEmpty = False then begin CopyAddRowCDS(CDS_Sub); with CDS_Sub do begin Edit; FieldByName('SPID').Value := null; FieldByName('PiQty').Value := '0'; FieldByName('Qty').Value := '0'; post; end; end else begin FCGM := CDS_Sub.fieldbyname('CGMainid').AsString; FCGS := CDS_Sub.fieldbyname('CGSubid').AsString; with CDS_Sub do begin Append; FieldByName('CRTime').Value := Trim(FormatDateTime('yyyy-MM-dd', Now)); FieldByName('CRType').Value := '加工完成'; fieldbyname('CGMainid').AsString := FCGM; fieldbyname('CGSubid').AsString := FCGS; Post; end; end; end; function TfrmDJBCKInPut.SaveCKData(): Boolean; var FCRID, Maxno, FFSPID: string; begin try ADOQueryCmd.Connection.BeginTrans; CDS_Sub.DisableControls; with CDS_Sub do begin First; while not eof do begin {with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from CK_SXPB_KC where BatchNo='''+Trim(CDS_Sub.fieldbyname('BatchNo').AsString)+''''); SQL.Add(' and isnull(CKName,'''')=''纱线'' '); Open; end; if ADOQueryTemp.IsEmpty=False then begin FCRID:=Trim(ADOQueryTemp.fieldbyname('CRID').AsString); end else begin with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from CK_SXPB_CRID'); Open; end; if ADOQueryTemp.IsEmpty then begin with ADOQueryCmd do begin Close; sql.Clear; sql.Add('insert into CK_SXPB_CRID select 0'); sql.Add(' select * from CK_SXPB_CRID'); Open; end; FCRID:=Trim(ADOQueryCmd.fieldbyname('CRID').AsString); end else begin with ADOQueryCmd do begin Close; sql.Clear; sql.Add('Update CK_SXPB_CRID Set CRID=CRID+1'); sql.Add(' select * from CK_SXPB_CRID'); Open; end; FCRID:=Trim(ADOQueryCmd.fieldbyname('CRID').AsString); end; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('select * from CK_SXPB_KC where CRID='+FCRID); Open; end; with ADOQueryCmd do begin Append; FieldByName('CRID').Value:=FCRID; FieldByName('CKName').Value:='纱线'; FieldByName('BatchNo').Value:=CDS_Sub.fieldbyname('BatchNo').Value; FieldByName('SPType').Value:=CDS_Sub.fieldbyname('SPType').Value; FieldByName('FactoryName').Value:=CDS_Sub.fieldbyname('FactoryName').Value; FieldByName('FactoryNo').Value:=CDS_Sub.fieldbyname('FactoryNo').Value; FieldByName('SPName').Value:=CDS_Sub.fieldbyname('SPName').Value; FieldByName('SPCF').Value:=CDS_Sub.fieldbyname('SPCF').Value; FieldByName('ShaZhi').Value:=CDS_Sub.fieldbyname('ShaZhi').Value; FieldByName('SeBie').Value:=CDS_Sub.fieldbyname('SeBie').Value; FieldByName('KCNote').Value:=CDS_Sub.fieldbyname('Note').Value; Post; end; end; } with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from CK_SXPB_CR where SPID=''' + Trim(CDS_Sub.fieldbyname('SPID').AsString) + ''''); open; end; FFSPID := Trim(ADOQueryTemp.fieldbyname('SPID').AsString); if Trim(FFSPID) = '' then begin if GetLSNo(ADOQueryCmd, Maxno, 'DR', 'CK_SXPB_CR', 3, 1) = False then begin Result := False; ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('取待检布入库编号失败!', '提示', 0); Exit; end; end else begin Maxno := Trim(FFSPID); end; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('delete from YF_Money_CR '); sql.Add(' where mainID=''' + Trim(Maxno) + ''''); sql.Add(' and YFName=''客户退货'' '); execsql; end; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('select * from CK_SXPB_CR where SPID=''' + Trim(Maxno) + ''''); Open; end; with ADOQueryCmd do begin if Trim(FFSPID) = '' then begin Append; end else begin Edit; end; FieldByName('SPID').Value := Trim(Maxno); FieldByName('FZSPID').Value := Trim(Maxno); FieldByName('CKName').Value := '待检布'; FieldByName('FromSPID').Value := Trim(CDS_Sub.fieldbyname('FromSPID').AsString); FieldByName('FactoryNo').Value := Trim(CDS_Sub.fieldbyname('FactoryNo').AsString); FieldByName('FromFactoryNo').Value := Trim(CDS_Sub.fieldbyname('FromFactoryNo').AsString); FieldByName('ToFactoryNo').Value := Trim(CDS_Sub.fieldbyname('ToFactoryNo').AsString); FieldByName('ORDMainIdRK').Value := Trim(CDS_Sub.fieldbyname('ORDMainIdRK').AsString); FieldByName('ORDSubIdRK').Value := Trim(CDS_Sub.fieldbyname('ORDSubIdRK').AsString); FieldByName('CRFlag').Value := '入库'; // fieldbyname('SPCode').Value:=Trim(CDS_Sub.fieldbyname('SPCode').AsString); FieldByName('CRQtyFlag').Value := 1; FieldByName('price').Value := CDS_Sub.fieldbyname('price').asfloat; FieldByName('money').Value := cds_sub.fieldbyname('price').AsFloat * cds_sub.fieldbyname('Qty').AsFloat; //FieldByName('CRID').Value:=FCRID; RTSetSaveDataCDS(ADOQueryCmd, Tv1, CDS_Sub, 'CK_SXPB_CR', 2); FieldByName('CGMainId').Value := Trim(CDS_Sub.fieldbyname('CGMainId').AsString); FieldByName('CGSubId').Value := Trim(CDS_Sub.fieldbyname('CGSubId').AsString); FieldByName('sccw').Value := '是'; if Trim(FFSPID) = '' then FieldByName('Filler').Value := Trim(DName) else begin FieldByName('Editer').Value := Trim(DName); FieldByName('EditTime').Value := SGetServerDate(ADOQueryTemp); end; if Trim(CDS_Sub.fieldbyname('OrderNo').AsString) <> '' then begin FieldByName('QCOrderNo').Value := Trim(CDS_Sub.fieldbyname('OrderNo').AsString); end; Post; end; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('Update CK_SXPB_CR Set MXKCQty=(select sum(isnull(Qty,0)*CRQtyFlag) from CK_SXPB_CR A where A.FZSPID=CK_SXPB_CR.SPID)'); sql.Add(',MXKCPiQty=(select sum(isnull(PiQty,0)*CRQtyFlag) from CK_SXPB_CR A where A.FZSPID=CK_SXPB_CR.SPID)'); sql.Add(',MXKCzhis=(select sum(isnull(zhis,0)*CRQtyFlag) from CK_SXPB_CR A where A.FZSPID=CK_SXPB_CR.SPID)'); sql.Add(' where SPID=''' + Trim(Maxno) + ''''); ExecSQL; end; // with ADOQueryCmd do // begin // Close; // sql.Clear; // sql.Add('Update YF_Money_CR Set factoryName='''+trim(CDS_Sub.fieldbyname('FactoryName').AsString)+''''); // sql.Add(' where mainid='''+Trim(Maxno)+''''); // SQL.Add('and CRType=''应付款登记'''); // ExecSQL; // end; with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from CK_SXPB_CR where SPID=''' + Trim(Maxno) + ''''); Open; end; if ADOQueryTemp.FieldByName('MXKCQty').Value < 0 then begin CDS_Sub.DisableControls; ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('入库数小于出库数不能保存!', '提示', 0); Exit; end; {with ADOQueryCmd do begin Close; sql.Clear; sql.Add('Update CK_SXPB_KC Set KCKGQty=(select sum(isnull(KGQty,0)*CRQtyFlag) from CK_SXPB_CR A where A.CRID=CK_SXPB_KC.CRID)'); sql.Add(',KCPiQty=(select sum(isnull(PiQty,0)*CRQtyFlag) from CK_SXPB_CR A where A.CRID=CK_SXPB_KC.CRID)'); sql.Add(' where CRID='+FCRID); ExecSQL; end; with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from CK_SXPB_KC where CRID='+Trim(FCRID)); Open; end; if ADOQueryTemp.FieldByName('KCKGQty').Value<0 then begin CDS_Sub.DisableControls; ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('入库公斤数小于出库公斤数不能保存!','提示',0); Exit; end; } { if ADOQueryTemp.FieldByName('KCKeQty').Value<0 then begin CDS_Sub.DisableControls; ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('入库颗数小于出库颗数不能保存!','提示',0); Exit; end; } Edit; FieldByName('SPID').Value := Trim(Maxno); //FieldByName('CRID').Value:=Trim(FCRID); Post; // if CDS_Sub.fieldbyname('crtype').asstring='加工完成' then // begin // IF not YFData1() then // begin // ADOQueryCmd.Connection.RollbackTrans; // application.MessageBox('生成应付款失败!','提示信息',0); // end; // end; // if CDS_Sub.fieldbyname('crtype').asstring='染色完成' then // begin // IF not YFData1() then // begin // ADOQueryCmd.Connection.RollbackTrans; // application.MessageBox('生成应付款失败!','提示信息',0); // end; // end; // if CDS_Sub.fieldbyname('crtype').asstring='回修完成' then // begin // IF not YFData1() then // begin // ADOQueryCmd.Connection.RollbackTrans; // application.MessageBox('生成应付款失败!','提示信息',0); // end; // end; // if CDS_Sub.fieldbyname('crtype').asstring='成品采购入库' then // begin // IF not YFData1() then // begin // ADOQueryCmd.Connection.RollbackTrans; // application.MessageBox('生成应付款失败!','提示信息',0); // end; // end; // // if Trim(CDS_Sub.fieldbyname('CRType').AsString)='客户退货' then // begin // if not YSData(CDS_Sub) then // begin // ADOQueryCmd.Connection.RollbackTrans; // Application.MessageBox('保存异常!','提示',0); // exit; // end; // end; // SaveJGCKData(); Next; end; end; CDS_Sub.EnableControls; ADOQueryCmd.Connection.CommitTrans; Result := True; except Result := False; ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('保存异常!', '提示', 0); end; end; function TfrmDJBCKInPut.YFData1(): Boolean; var CRID, OrdMainId, YFID, FComTaiTou, FCRID, FFactoryName: string; begin Result := False; with ADOQueryTemp do begin Close; SQL.Clear; sql.Add('select * from YF_Money_KC where FactoryName=' + quotedstr(Trim(cds_sub.fieldbyname('factoryName').AsString))); Open; end; if ADOQueryTemp.IsEmpty = False then begin CRID := ADOQueryTemp.fieldbyname('CRID').AsString; end else begin with ADOQueryCmd do begin Close; sql.Clear; sql.Add('Update YF_Money_CRID set CRID=CRID+1'); sql.Add('select * from YF_Money_CRID '); Open; end; CRID := ADOQueryCmd.fieldbyname('CRID').AsString; with ADOQueryCmd do begin Close; SQL.Clear; sql.Add('select * from YF_Money_KC where 1<>1'); Open; end; with ADOQueryCmd do begin Append; FieldByName('CRID').Value := StrToInt(CRID); FieldByName('FactoryName').Value := Trim(cds_sub.fieldbyname('factoryName').AsString); FieldByName('ZdyStr1').Value := '应付付'; Post; end; end; with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from YF_Money_CR where FactoryName=' + quotedstr(Trim(cds_sub.fieldbyname('factoryName').AsString))); sql.Add(' and mainID=''' + Trim(cds_sub.fieldbyname('SPID').AsString) + ''''); // sql.Add(' and subID='''+Trim(Order_Sub.fieldbyname('subID').AsString)+''''); Open; end; if ADOQueryTemp.IsEmpty then begin if GetLSNo(ADOQueryCmd, YFID, 'YF', 'YF_Money_CR', 3, 1) = False then begin Application.MessageBox('取坯布应付最大号失败!', '提示', 0); Exit; end; end else begin YFID := Trim(ADOQueryTemp.fieldbyname('YFID').AsString); end; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('select * from YF_Money_CR where YFID=''' + Trim(YFID) + ''''); Open; end; with ADOQueryCmd do begin if ADOQueryTemp.IsEmpty then Append else Edit; FieldByName('YFID').Value := Trim(YFID); FieldByName('YFTypeId').Value := Trim(cds_sub.fieldbyname('SPID').AsString); FieldByName('CRID').Value := StrToInt(CRID); FieldByName('Filler').Value := Trim(DName); FieldByName('CRType').Value := '应付款登记'; FieldByName('CRFlag').Value := '应付付'; FieldByName('QtyFlag').Value := 1; FieldByName('FactoryName').Value := Trim(cds_sub.fieldbyname('factoryName').AsString); FieldByName('CRTime').Value := cds_sub.fieldbyname('CRTime').AsDateTime; FieldByName('Qty').Value := cds_sub.fieldbyname('Qty').AsFloat; FieldByName('PS').Value := cds_sub.fieldbyname('PiQty').AsFloat; FieldByName('YFType').Value := '自动生成'; FieldByName('Price').Value := cds_sub.fieldbyname('price').AsFloat; FieldByName('money').Value := cds_sub.fieldbyname('price').AsFloat * cds_sub.fieldbyname('Qty').AsFloat; FieldByName('BBmoney').Value := cds_sub.fieldbyname('price').AsFloat * cds_sub.fieldbyname('Qty').AsFloat; FieldByName('HuiLv').Value := 1; FieldByName('BZType').Value := 'RMB'; FieldByName('ComTaiTou').Value := ''; FieldByName('QtyUnit').Value := Trim(cds_sub.fieldbyname('QtyUnit').AsString); FieldByName('orderNo').Value := Trim(cds_sub.fieldbyname('OrderNo').AsString); FieldByName('P_CodeName').Value := Trim(cds_sub.fieldbyname('SPName').AsString); // FieldByName('P_Color').Value:=Trim(CDS_Main.fieldbyname('QtyUnit').AsString); if Trim(cds_sub.fieldbyname('CRType').AsString) = '染色完成' then FieldByName('YFName').Value := '染费' else if Trim(cds_sub.fieldbyname('CRType').AsString) = '采购入库' then FieldByName('YFName').Value := '坯布费' else if Trim(cds_sub.fieldbyname('CRType').AsString) = '成品采购入库' then FieldByName('YFName').Value := '成品采购费' else if Trim(cds_sub.fieldbyname('CRType').AsString) = '回修完成' then FieldByName('YFName').Value := '回修费' else if Trim(cds_sub.fieldbyname('CRType').AsString) = '退货出库' then FieldByName('YFName').Value := '退货' else FieldByName('YFName').Value := '加工费'; FieldByName('MainId').Value := Trim(cds_sub.fieldbyname('SPID').AsString); // FieldByName('subId').Value:=Trim(Order_Sub.fieldbyname('subId').AsString); FieldByName('status').Value := '0'; Post; end; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('Update YF_Money_KC Set KCMoney=(select isnull(Sum(Money*QtyFlag),0) from YF_Money_CR A where A.CRID=YF_Money_KC.CRID)'); sql.Add(',KCBBMoney=(select isnull(Sum(BBMoney*QtyFlag),0) from YF_Money_CR A where A.CRID=YF_Money_KC.CRID)'); sql.Add(' where CRID=' + CRID); ExecSQL; end; Result := True; end; procedure TfrmDJBCKInPut.TBCloseClick(Sender: TObject); begin WriteCxGrid('待检布入库登记', Tv1, '待检布仓库1'); Close; end; procedure TfrmDJBCKInPut.FormShow(Sender: TObject); var fsj: string; begin ReadCxGrid('待检布入库登记', Tv1, '待检布仓库1'); with ADOQueryTemp do begin Close; sql.Clear; sql.Add(' select A.* '); sql.Add(',OrderNO=(select OrderNO from JYOrder_Main JM where JM.MainId=A.ORDMainIdRK)'); sql.Add(' ,SOrddefstr1=(select SOrddefstr1 from JYOrder_Sub JM where JM.SubId=A.OrdSubIdRK )'); sql.Add(' ,PRTColor=(select PRTColor from JYOrder_Sub JM where JM.SubId=A.OrdSubIdRK )'); sql.Add(' ,SOrddefstr4=(select SOrddefstr4 from JYOrder_Sub JM where JM.SubId=A.OrdSubIdRK )'); sql.Add(' ,PRTHX=(select PRTHX from JYOrder_Sub JM where JM.SubId=A.OrdSubIdRK )'); sql.Add(' ,PRTkuanNo=(select PRTkuanNo from JYOrder_Sub JM where JM.SubId=A.OrdSubIdRK )'); sql.Add(' ,PRTOrderQty=(select PRTOrderQty from JYOrder_Sub JM where JM.SubId=A.OrdSubIdRK )'); sql.Add(' from CK_SXPB_CR A'); sql.Add(' where SPID=''' + Trim(FBCId) + ''''); Open; end; SCreateCDS20(ADOQueryTemp, CDS_Sub); SInitCDSData20(ADOQueryTemp, CDS_Sub); if CDS_Sub.IsEmpty then Exit; with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from CK_SXPB_CR where FZSPID=''' + Trim(CDS_Sub.fieldbyname('SPID').AsString) + ''''); sql.Add(' and CRQtyFlag=-1'); Open; end; if ADOQueryTemp.IsEmpty = False then begin v1Column4.Options.Focusing := False; // v1Column15.Options.Focusing:=False; v1Column13.Options.Focusing := False; // v1Column14.Options.Focusing:=False; v2Column1.Options.Focusing := False; v1Column8.Options.Focusing := False; v1Column7.Options.Focusing := False; v1Column1.Options.Focusing := False; v1Column10.Options.Focusing := False; v1Column11.Options.Focusing := False; Exit; end else begin v1Column4.Options.Focusing := True; //v1Column15.Options.Focusing:=True; v1Column13.Options.Focusing := True; // v1Column14.Options.Focusing:=True; v2Column1.Options.Focusing := True; v1Column8.Options.Focusing := True; v1Column7.Options.Focusing := True; v1Column1.Options.Focusing := True; v1Column10.Options.Focusing := True; v1Column11.Options.Focusing := True; end; end; procedure TfrmDJBCKInPut.TBDelClick(Sender: TObject); begin if CDS_Sub.IsEmpty then Exit; if Application.MessageBox('确定要删除数据吗?', '提示', 32 + 4) <> IDYES then Exit; if Trim(CDS_Sub.fieldbyname('SPID').AsString) <> '' then begin with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from CK_SXPB_CR where FZSPID=''' + Trim(CDS_Sub.fieldbyname('SPID').AsString) + ''''); sql.Add(' and CRQtyFlag=-1'); Open; end; if ADOQueryTemp.IsEmpty = False then begin Application.MessageBox('已有出库记录,不能删除!', '提示', 0); Exit; end; try ADOQueryCmd.Connection.BeginTrans; with ADOQueryCmd do begin Close; sql.Clear; sql.Add(' delete CK_SXPB_CR where SPID=''' + Trim(CDS_Sub.fieldbyname('SPID').AsString) + ''''); ExecSQL; end; ADOQueryCmd.Connection.CommitTrans; CDS_Sub.Delete; except ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('删除异常!', '提示', 0); end; end else begin CDS_Sub.Delete; end; end; procedure TfrmDJBCKInPut.TBSaveClick(Sender: TObject); begin if CDS_Sub.IsEmpty then Exit; if CDS_Sub.Locate('CRTime', null, []) = True then begin Application.MessageBox('入库时间不能为空!', '提示', 0); Exit; end; if CDS_Sub.Locate('CRType', null, []) = True then begin Application.MessageBox('入库类型不能为空!', '提示', 0); Exit; end; if trim(CDS_Sub.fieldbyname('CRType').AsString) <> '期初入库' then begin // if CDS_Sub.Locate('OrderNo', null, []) = True then // begin // Application.MessageBox('订单号不能为空!', '提示', 0); // Exit; // end; end; if CDS_Sub.Locate('ToFactoryName', null, []) = True then begin Application.MessageBox('存放工厂不能为空!', '提示', 0); Exit; end; if trim(CDS_Sub.fieldbyname('CRType').AsString) <> '客户退货' then begin if CDS_Sub.Locate('FactoryName', null, []) = True then begin Application.MessageBox('加工厂不能为空!', '提示', 0); Exit; end; end; // if CDS_Sub.Locate('PiQty', null, []) = True then // begin // Application.MessageBox('匹数不能为空!', '提示', 0); // Exit; // end; // if CDS_Sub.Locate('Qty', null, []) = True then // begin // Application.MessageBox('数量不能为空!', '提示', 0); // Exit; // end; // if CDS_Sub.Locate('QtyUnit', null, []) = True then // begin // Application.MessageBox('数量单位不能为空!', '提示', 0); // Exit; // end; if CDS_Sub.Locate('CRType;FromFactoryName', VarArrayOf(['生产退回', Null]), [loPartialKey]) = True then begin Application.MessageBox('生产退回的数据,来自工厂不能为空!', '提示', 0); Exit; end; if CDS_Sub.Locate('CRType;CGConno', VarArrayOf(['成品采购入库', Null]), [loPartialKey]) = True then begin Application.MessageBox('成品采购入库的数据,采购单号不能为空!', '提示', 0); Exit; end; if SaveCKData() then begin SaveJGCKData(); Application.MessageBox('保存成功!', '提示', 0); //ModalResult:=1; Exit; end; // if SaveJGCKData() then // begin // Application.MessageBox('保存成功!', '提示', 0); // //ModalResult:=1; // Exit; // end; end; function TfrmDJBCKInPut.SaveJGCKData(): Boolean; var FCRID, Maxno, FSPID, MaxPYNo, FPYID, FFZSPID: string; begin try ADOQueryCmd.Connection.BeginTrans; CDS_Sub.DisableControls; with CDS_Sub do begin First; while not eof do begin with ADOQueryTemp do begin Close; sql.Clear; if FBCId = '' then begin sql.Add('select * from CK_SXPB_CR where SPID='''' '); end else begin // sql.Add('select * from CK_SXPB_CR where SPID=''' + Trim(CDS_Sub.fieldbyname('SPID').AsString) + ''''); sql.Add('select * from CK_SXPB_CR where TJWJGID=''' + Trim(CDS_Sub.fieldbyname('SPID').AsString) + ''''); end; Open; end; FSPID := Trim(ADOQueryTemp.fieldbyname('SPID').AsString); if FBCId = '' then begin FFZSPID := Trim(Fwjgspid); end else begin FFZSPID := Trim(ADOQueryTemp.fieldbyname('FZSPID').AsString); end; if Trim(FSPID) = '' then begin if GetLSNo(ADOQueryCmd, Maxno, 'WC', 'CK_SXPB_CR', 3, 1) = False then begin Result := False; ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('取外加工出库编号失败!', '提示', 0); Exit; end; end else begin Maxno := Trim(FSPID); end; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('select * from CK_SXPB_CR where SPID=''' + Trim(Maxno) + ''''); Open; end; with ADOQueryCmd do begin if Trim(FSPID) = '' then begin Append; end else begin Edit; end; FieldByName('SPID').Value := Trim(Maxno); FieldByName('TJWJGID').Value := Trim(CDS_Sub.fieldbyname('SPID').AsString); FieldByName('ORDMainIdRK').Value := Trim(CDS_Sub.fieldbyname('ORDMainIdRK').AsString); FieldByName('ORDSubIdRK').Value := Trim(CDS_Sub.fieldbyname('ORDSubIdRK').AsString); FieldByName('ORDMainIdCK').Value := Trim(CDS_Sub.fieldbyname('ORDMainIdCK').AsString); FieldByName('ORDSubIdCK').Value := Trim(CDS_Sub.fieldbyname('ORDSubIdCK').AsString); FieldByName('FZSPID').Value := Trim(CDS_Sub.fieldbyname('FZSPID').AsString); FieldByName('FactoryNo').Value := Trim(CDS_Sub.fieldbyname('FactoryNo').AsString); FieldByName('FromFactoryNo').Value := Trim(CDS_Sub.fieldbyname('FromFactoryNo').AsString); FieldByName('ToFactoryNo').Value := Trim(CDS_Sub.fieldbyname('ToFactoryNo').AsString); // FieldByName('Qty').Value := Trim(CDS_Sub.fieldbyname('Qty').AsString); // FieldByName('PiQty').Value := Trim(CDS_Sub.fieldbyname('PiQty').AsString); //FieldByName('CRID').Value:=CDS_Sub.fieldbyname('CRID').Value; FieldByName('CRFlag').Value := '出库'; FieldByName('CRQtyFlag').Value := -1; RTSetSaveDataCDS(ADOQueryCmd, Tv1, CDS_Sub, 'CK_SXPB_CR', 2); if FBCId = '' then begin FieldByName('Qty').Value := (CDS_Sub.fieldbyname('Qty').AsFloat); FieldByName('PiQty').Value := (CDS_Sub.fieldbyname('PiQty').AsFloat); end; FieldByName('CKName').Value := '外加工'; if Trim(FSPID) = '' then FieldByName('Filler').Value := Trim(DName) else begin FieldByName('Editer').Value := Trim(DName); FieldByName('EditTime').Value := SGetServerDate(ADOQueryTemp); end; Post; end; with ADOQueryCmd do begin Close; sql.Clear; // sql.Add('Update CK_SXPB_CR Set MXKCQty=(select sum(isnull(Qty,0)*CRQtyFlag) from CK_SXPB_CR A where A.FZSPID=CK_SXPB_CR.SPID)'); // sql.Add(',MXKCPiQty=(select sum(isnull(PiQty,0)*CRQtyFlag) from CK_SXPB_CR A where A.FZSPID=CK_SXPB_CR.SPID)'); // sql.Add(',MXKCzhis=(select sum(isnull(zhis,0)*CRQtyFlag) from CK_SXPB_CR A where A.FZSPID=CK_SXPB_CR.SPID)'); // sql.Add(' where SPID=''' + Trim(CDS_Sub.fieldbyname('FZSPID').AsString) + ''''); sql.Add('Update CK_SXPB_CR Set MXKCQty=0'); sql.Add(',MXKCPiQty=0'); sql.Add(',MXKCzhis=0'); sql.Add(' where SPID=''' + Trim(FFZSPID) + ''''); ExecSQL; end; // with ADOQueryTemp do // begin // Close; // sql.Clear; // sql.Add('select * from CK_SXPB_CR where SPID=''' + Trim(FFZSPID) + ''''); // Open; // end; // if ADOQueryTemp.FieldByName('MXKCQty').Value < 0 then // begin // CDS_Sub.DisableControls; // ADOQueryCmd.Connection.RollbackTrans; // Application.MessageBox('出库数大于库存数不能保存!', '提示', 0); // Exit; // end; Edit; FieldByName('SPID').Value := Trim(Maxno); Post; Next; end; end; CDS_Sub.EnableControls; ADOQueryCmd.Connection.CommitTrans; Result := True; except Result := False; ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('保存异常!', '提示', 0); end; end; procedure TfrmDJBCKInPut.v1Column3PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmZDYHelp := TfrmZDYHelp.Create(Application); with frmZDYHelp do begin flag := 'SXKuWei'; flagname := '库位'; if ShowModal = 1 then begin with Self.CDS_Sub do begin Edit; FieldByName('KuWei').Value := Trim(frmZDYHelp.ClientDataSet1.fieldbyname('ZdyName').AsString); end; end; end; finally frmZDYHelp.Free; end; end; procedure TfrmDJBCKInPut.v1Column14PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmZdyAttachGYS := TfrmZdyAttachGYS.Create(Application); with frmZdyAttachGYS do begin if ShowModal = 1 then begin with Self.CDS_Sub do begin edit; FieldByName('FactoryNo').Value := Trim(frmZdyAttachGYS.CDS_HZ.fieldbyname('ZdyCode').AsString); FieldByName('FactoryName').Value := Trim(frmZdyAttachGYS.CDS_HZ.fieldbyname('ZdyName').AsString); FieldByName('FromFactoryNo').Value := Trim(frmZdyAttachGYS.CDS_HZ.fieldbyname('ZdyCode').AsString); FieldByName('FromFactoryName').Value := Trim(frmZdyAttachGYS.CDS_HZ.fieldbyname('ZdyName').AsString); //Post; end; end; end; finally frmZdyAttachGYS.Free; end; end; procedure TfrmDJBCKInPut.v2Column1PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmZDYHelp := TfrmZDYHelp.Create(Application); with frmZDYHelp do begin flag := 'WJGName'; flagname := '外加工名称'; if ShowModal = 1 then begin with Self.CDS_Sub do begin Edit; FieldByName('SPName').Value := Trim(frmZDYHelp.ClientDataSet1.fieldbyname('ZdyName').AsString); end; end; end; finally frmZDYHelp.Free; end; end; procedure TfrmDJBCKInPut.v1Column5PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmZDYHelp := TfrmZDYHelp.Create(Application); with frmZDYHelp do begin flag := 'KuWei'; flagname := '库位'; if ShowModal = 1 then begin with Self.CDS_Sub do begin Edit; FieldByName('KuWei').Value := Trim(frmZDYHelp.ClientDataSet1.fieldbyname('ZdyName').AsString); end; end; end; finally frmZDYHelp.Free; end; end; procedure TfrmDJBCKInPut.v1Column11PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmZdyAttachGYS := TfrmZdyAttachGYS.Create(Application); with frmZdyAttachGYS do begin if ShowModal = 1 then begin with Self.CDS_Sub do begin edit; FieldByName('ToFactoryNo').Value := Trim(frmZdyAttachGYS.CDS_HZ.fieldbyname('ZdyCode').AsString); FieldByName('ToFactoryName').Value := Trim(frmZdyAttachGYS.CDS_HZ.fieldbyname('ZdyName').AsString); //Post; end; end; end; finally frmZdyAttachGYS.Free; end; end; procedure TfrmDJBCKInPut.v1Column16PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmZdyAttachGYS := TfrmZdyAttachGYS.Create(Application); with frmZdyAttachGYS do begin if ShowModal = 1 then begin with Self.CDS_Sub do begin edit; FieldByName('FromFactoryNo').Value := Trim(frmZdyAttachGYS.CDS_HZ.fieldbyname('ZdyCode').AsString); FieldByName('FromFactoryName').Value := Trim(frmZdyAttachGYS.CDS_HZ.fieldbyname('ZdyName').AsString); //Post; end; end; end; finally frmZdyAttachGYS.Free; end; end; procedure TfrmDJBCKInPut.v1Column13PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmProductOrderListSel := TfrmProductOrderListSel.Create(Application); with frmProductOrderListSel do begin if ShowModal = 1 then begin with Self.CDS_Sub do begin Edit; FieldByName('ORDMainIdRK').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('MainId').AsString); FieldByName('ORDSubIdRK').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('SubId').AsString); FieldByName('OrderNo').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('OrderNo').AsString); FieldByName('SOrddefstr1').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('SOrddefstr1').AsString); FieldByName('PRTColor').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('PRTColor').AsString); FieldByName('PRTkuanNo').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('PRTkuanNo').AsString); FieldByName('SPCode').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('PRTcode').AsString); FieldByName('PRTHX').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('PRTHX').AsString); FieldByName('SPName').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('PRTCodeName').AsString); FieldByName('SPSpec').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('PRTSpec').AsString); // FieldByName('SPCF').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('PRTCF').AsString); FieldByName('SPMF').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('PRTMF').AsString); FieldByName('SPKZ').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('PRTKZ').AsString); FieldByName('PRTOrderQty').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('PRTOrderQty').AsString); if FieldByName('CRType').AsString = '客户退货' then FieldByName('FactoryName').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('customerNOName').AsString); post; end; end; end; finally frmProductOrderListSel.Free; end; tv1.Controller.EditingController.ShowEdit(); end; procedure TfrmDJBCKInPut.v1Column18PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmZDYHelp := TfrmZDYHelp.Create(Application); with frmZDYHelp do begin flag := 'KuWei'; flagname := '库位'; if ShowModal = 1 then begin with Self.CDS_Sub do begin Edit; FieldByName('KuWei').Value := Trim(frmZDYHelp.ClientDataSet1.fieldbyname('ZdyName').AsString); end; end; end; finally frmZDYHelp.Free; end; end; procedure TfrmDJBCKInPut.ToolButton1Click(Sender: TObject); begin try frmProductOrderListSel1 := TfrmProductOrderListSel1.Create(Application); with frmProductOrderListSel1 do begin if ShowModal = 1 then begin Order_Main.DisableControls; order_main.First; while not Order_Main.Eof do begin if Order_Main.FieldByName('ssel').AsBoolean then begin with CDS_Sub do begin Append; FieldByName('CRTime').Value := Trim(FormatDateTime('yyyy-MM-dd', Now)); FieldByName('ORDMainIdRK').Value := Trim(frmProductOrderListSel1.Order_Main.fieldbyname('MainId').AsString); FieldByName('ORDSubIdRK').Value := Trim(frmProductOrderListSel1.Order_Main.fieldbyname('SubId').AsString); FieldByName('OrderNo').Value := Trim(frmProductOrderListSel1.Order_Main.fieldbyname('OrderNo').AsString); FieldByName('SOrddefstr1').Value := Trim(frmProductOrderListSel1.Order_Main.fieldbyname('SOrddefstr1').AsString); FieldByName('PRTColor').Value := Trim(frmProductOrderListSel1.Order_Main.fieldbyname('PRTColor').AsString); FieldByName('SOrddefstr4').Value := Trim(frmProductOrderListSel1.Order_Main.fieldbyname('SOrddefstr4').AsString); FieldByName('PRTkuanNo').Value := Trim(frmProductOrderListSel1.Order_Main.fieldbyname('PRTkuanNo').AsString); FieldByName('PRTHX').Value := Trim(frmProductOrderListSel1.Order_Main.fieldbyname('PRTHX').AsString); FieldByName('SPName').Value := Trim(frmProductOrderListSel1.Order_Main.fieldbyname('PRTCodeName').AsString); FieldByName('SPcode').Value := Trim(frmProductOrderListSel1.Order_Main.fieldbyname('PRTCode').AsString); FieldByName('SPSpec').Value := Trim(frmProductOrderListSel1.Order_Main.fieldbyname('PRTSpec').AsString); // FieldByName('SPCF').Value := Trim(frmProductOrderListSel1.Order_Main.fieldbyname('PRTCF').AsString); FieldByName('SPMF').Value := Trim(frmProductOrderListSel1.Order_Main.fieldbyname('PRTMF').AsString); // FieldByName('MPRTCode').Value:=Trim(frmProductOrderListSel1.Order_Main.fieldbyname('MPRTCode').AsString); FieldByName('SPKZ').Value := Trim(frmProductOrderListSel1.Order_Main.fieldbyname('PRTKZ').AsString); // FieldByName('FactoryName').Value:=Trim(frmProductOrderListSel1.Order_Main.fieldbyname('ToFactoryName').AsString); FieldByName('PRTOrderQty').Value := Trim(frmProductOrderListSel1.Order_Main.fieldbyname('PRTOrderQty').AsString); Post; end; end; Order_Main.Next; end; Order_Main.EnableControls; end; Free; end; finally frmProductOrderListSel1.Free; end; end; procedure TfrmDJBCKInPut.ToolButton2Click(Sender: TObject); var FCGM, FCGS: string; begin if CDS_Sub.IsEmpty then Exit; if Trim(Tv1.Controller.FocusedColumn.DataBinding.FilterFieldName) = 'CGConno' then begin FCGM := CDS_Sub.fieldbyname('CGMainid').AsString; FCGS := CDS_Sub.fieldbyname('CGSubid').AsString; end; OneKeyPost(Tv1, CDS_Sub); if Trim(Tv1.Controller.FocusedColumn.DataBinding.FilterFieldName) = 'CGConno' then begin with CDS_Sub do begin First; while not Eof do begin Edit; fieldbyname('CGMainid').AsString := FCGM; fieldbyname('CGSubid').AsString := FCGS; Post; Next; end; end; end; end; procedure TfrmDJBCKInPut.ToolButton4Click(Sender: TObject); begin try frmCPTPJHListSel := TfrmCPTPJHListSel.Create(Application); with frmCPTPJHListSel do begin if ShowModal = 1 then begin Order_Main.DisableControls; order_main.First; while not Order_Main.Eof do begin if Order_Main.FieldByName('ssel').AsBoolean then begin with CDS_Sub do begin Append; FieldByName('CRTime').Value := Trim(FormatDateTime('yyyy-MM-dd', Now)); FieldByName('ORDMainIdRK').Value := Trim(frmCPTPJHListSel.Order_Main.fieldbyname('ORDMainIdCK').AsString); FieldByName('ORDSubIdRK').Value := Trim(frmCPTPJHListSel.Order_Main.fieldbyname('ORDSubIdCK').AsString); FieldByName('FromSPID').Value := Trim(frmCPTPJHListSel.Order_Main.fieldbyname('SPID').AsString); FieldByName('OrderNo').Value := Trim(frmCPTPJHListSel.Order_Main.fieldbyname('CKOrderNo').AsString); FieldByName('SOrddefstr1').Value := Trim(frmCPTPJHListSel.Order_Main.fieldbyname('SPColorNo').AsString); FieldByName('PRTColor').Value := Trim(frmCPTPJHListSel.Order_Main.fieldbyname('SPColor').AsString); FieldByName('PRTHX').Value := Trim(frmCPTPJHListSel.Order_Main.fieldbyname('SPHX').AsString); FieldByName('SPName').Value := Trim(frmCPTPJHListSel.Order_Main.fieldbyname('SPName').AsString); FieldByName('SPcode').Value := Trim(frmCPTPJHListSel.Order_Main.fieldbyname('SPcode').AsString); FieldByName('SPSpec').Value := Trim(frmCPTPJHListSel.Order_Main.fieldbyname('SPSpec').AsString); FieldByName('SPCF').Value := Trim(frmCPTPJHListSel.Order_Main.fieldbyname('SPCF').AsString); FieldByName('SPMF').Value := Trim(frmCPTPJHListSel.Order_Main.fieldbyname('SPMF').AsString); FieldByName('SPKZ').Value := Trim(frmCPTPJHListSel.Order_Main.fieldbyname('SPKZ').AsString); FieldByName('RCGangNo').Value := Trim(frmCPTPJHListSel.Order_Main.fieldbyname('RCGangNo').AsString); FieldByName('GangNo').Value := Trim(frmCPTPJHListSel.Order_Main.fieldbyname('GangNo').AsString); // FieldByName('PiQty').Value := Trim(frmCPTPJHListSel.Order_Main.fieldbyname('JHPiQty').AsString); // FieldByName('Qty').Value := Trim(frmCPTPJHListSel.Order_Main.fieldbyname('JHQty').AsString); FieldByName('QtyUnit').Value := Trim(frmCPTPJHListSel.Order_Main.fieldbyname('QtyUnit').AsString); FieldByName('ToFactoryName').Value := Trim(frmCPTPJHListSel.Order_Main.fieldbyname('ToFactoryName').AsString); FieldByName('FactoryName').Value := Trim(frmCPTPJHListSel.Order_Main.fieldbyname('FromFactoryName').AsString); FieldByName('ToFactoryNo').Value := Trim(frmCPTPJHListSel.Order_Main.fieldbyname('ToFactoryNo').AsString); FieldByName('FactoryNo').Value := Trim(frmCPTPJHListSel.Order_Main.fieldbyname('FromFactoryNo').AsString); Post; end; end; Order_Main.Next; end; Order_Main.EnableControls; end; Free; end; finally frmCPTPJHListSel.Free; end; end; procedure TfrmDJBCKInPut.Tv1Column1PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmProductOrderHzListSel := TfrmProductOrderHzListSel.Create(Application); with frmProductOrderHzListSel do begin if ShowModal = 1 then begin with Self.CDS_Sub do begin Edit; FieldByName('CGConNo').Value := Trim(frmProductOrderHzListSel.Order_Main.fieldbyname('ConNo').AsString); FieldByName('CGMainid').Value := Trim(frmProductOrderHzListSel.Order_Main.fieldbyname('Mainid').AsString); FieldByName('CGSubid').Value := Trim(frmProductOrderHzListSel.Order_Main.fieldbyname('Subid').AsString); if Self.CDS_Sub.FieldByName('ORDMainIdRK').AsString = '' then begin with ADOQueryCmd do begin close; sql.Clear; SQL.Add('select * from JYOrder_Main where orderNo=''' + Trim(frmProductOrderHzListSel.Order_Main.fieldbyname('BuyConNo').AsString) + ''' '); Open; end; if ADOQueryCmd.IsEmpty = False then begin FieldByName('OrderNo').Value := Trim(frmProductOrderHzListSel.Order_Main.fieldbyname('BuyConNo').AsString); FieldByName('ORDMainIdRK').Value := Trim(ADOQueryCmd.fieldbyname('Mainid').AsString); FieldByName('Note').Value := Trim(frmProductOrderHzListSel.Order_Main.fieldbyname('SCSColor').AsString); end else begin FieldByName('Note').Value := Trim(frmProductOrderHzListSel.Order_Main.fieldbyname('BuyConNo').AsString) + Trim(frmProductOrderHzListSel.Order_Main.fieldbyname('SCSColor').AsString); end; FieldByName('SPcode').Value := Trim(frmProductOrderHzListSel.Order_Main.fieldbyname('SCSPBCODE').AsString); FieldByName('SPName').Value := Trim(frmProductOrderHzListSel.Order_Main.fieldbyname('SCSPBNAME').AsString); FieldByName('SPMF').Value := Trim(frmProductOrderHzListSel.Order_Main.fieldbyname('SCSPBMF').AsString); FieldByName('SPKZ').Value := Trim(frmProductOrderHzListSel.Order_Main.fieldbyname('SCSPBKZ').AsString); end; end; end; end; finally frmProductOrderHzListSel.Free; end; end; procedure TfrmDJBCKInPut.v1Column8PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmZDYHelp := TfrmZDYHelp.Create(Application); with frmZDYHelp do begin flag := 'guige'; flagname := '规格'; if ShowModal = 1 then begin with Self.CDS_Sub do begin Edit; FieldByName('SPSpec').Value := Trim(frmZDYHelp.ClientDataSet1.fieldbyname('ZdyName').AsString); end; end; end; finally frmZDYHelp.Free; end; end; procedure TfrmDJBCKInPut.v2Column6PropertiesEditValueChanged(Sender: TObject); var mvalue, FFieldName: string; FhsxsD, Fhsxs, Fhszhis, FQty: Double; i: Integer; begin mvalue := TcxTextEdit(Sender).EditingText; FFieldName := Trim(Tv1.Controller.FocusedColumn.DataBinding.FilterFieldName); Fhszhis := 0; if Trim(mvalue) = '' then begin mvalue := '0'; end; with CDS_Sub do begin Edit; FieldByName(FFieldName).Value := mvalue; Post; Fhsxs := CDS_Sub.fieldbyname('hsxs').AsFloat; // FhsxsD := CDS_Sub.fieldbyname('hsxsD').AsFloat; FQty := CDS_Sub.fieldbyname('Qty').AsFloat; end; if Fhsxs > 0 then begin Fhszhis := StrToFloatDef(format('%.0f', [(FQty / Fhsxs)]), 0); end; with CDS_Sub do begin Edit; FieldByName('hszhis').Value := Fhszhis; Post; end; tv1.Controller.EditingController.ShowEdit(); end; procedure TfrmDJBCKInPut.ToolButton5Click(Sender: TObject); begin try frmWJGCKKCTJList := TfrmWJGCKKCTJList.Create(Application); with frmWJGCKKCTJList do begin ToolButton1.Visible := True; if ShowModal = 1 then begin frmWJGCKKCTJList.CDS_Main.DisableControls; with frmWJGCKKCTJList.CDS_Main do begin First; while frmWJGCKKCTJList.CDS_Main.Locate('SSel', True, []) do begin with Self.CDS_Sub do begin Append; FieldByName('CRTime').Value := Trim(FormatDateTime('yyyy-MM-dd', Now)); FieldByName('ORDMainIdRK').Value := Trim(frmWJGCKKCTJList.CDS_Main.fieldbyname('ORDMainIdRK').AsString); FieldByName('ORDSubIdRK').Value := Trim(frmWJGCKKCTJList.CDS_Main.fieldbyname('ORDSubIdRK').AsString); FieldByName('ORDMainIdCK').Value := Trim(frmWJGCKKCTJList.CDS_Main.fieldbyname('ORDMainIdRK').AsString); FieldByName('ORDSubIdCK').Value := Trim(frmWJGCKKCTJList.CDS_Main.fieldbyname('ORDSubIdRK').AsString); FieldByName('QCOrderNo').Value := frmWJGCKKCTJList.CDS_Main.fieldbyname('OrderNo').Value; FieldByName('CKOrderNo').Value := frmWJGCKKCTJList.CDS_Main.fieldbyname('OrderNo').Value; FieldByName('OrderNo').Value := frmWJGCKKCTJList.CDS_Main.fieldbyname('OrderNo').Value; FieldByName('SOrddefstr1').Value := frmWJGCKKCTJList.CDS_Main.fieldbyname('SOrddefstr1').AsString; FieldByName('PRTColor').Value := frmWJGCKKCTJList.CDS_Main.fieldbyname('PRTColor').AsString; FieldByName('PRTHX').Value := frmWJGCKKCTJList.CDS_Main.fieldbyname('PRTHX').AsString; FieldByName('FactoryName').Value := frmWJGCKKCTJList.CDS_Main.fieldbyname('FactoryName').Value; FieldByName('FactoryNo').Value := frmWJGCKKCTJList.CDS_Main.fieldbyname('FactoryNo').Value; FieldByName('SSType').Value := frmWJGCKKCTJList.CDS_Main.fieldbyname('SSType').Value; FieldByName('SPName').Value := frmWJGCKKCTJList.CDS_Main.fieldbyname('SPName').Value; FieldByName('SPSpec').Value := frmWJGCKKCTJList.CDS_Main.fieldbyname('SPSpec').Value; FieldByName('SPCF').Value := frmWJGCKKCTJList.CDS_Main.fieldbyname('SPCF').Value; FieldByName('SPMF').Value := frmWJGCKKCTJList.CDS_Main.fieldbyname('SPMF').Value; FieldByName('SPKZ').Value := frmWJGCKKCTJList.CDS_Main.fieldbyname('SPKZ').Value; FieldByName('FromFactoryName').Value := frmWJGCKKCTJList.CDS_Main.fieldbyname('ToFactoryName').Value; FieldByName('FromFactoryNo').Value := frmWJGCKKCTJList.CDS_Main.fieldbyname('ToFactoryNo').Value; FieldByName('ToFactoryName').Value := frmWJGCKKCTJList.CDS_Main.fieldbyname('ToFactoryName').Value; FieldByName('ToFactoryNo').Value := frmWJGCKKCTJList.CDS_Main.fieldbyname('ToFactoryNo').Value; FieldByName('QtyUnit').Value := frmWJGCKKCTJList.CDS_Main.fieldbyname('QtyUnit').Value; FieldByName('PiQty').Value := frmWJGCKKCTJList.CDS_Main.fieldbyname('MXKCPiQty').Value; FieldByName('zhis').Value := frmWJGCKKCTJList.CDS_Main.fieldbyname('MXKCzhis').Value; FieldByName('Qty').Value := frmWJGCKKCTJList.CDS_Main.fieldbyname('MXKCQty').Value; FieldByName('FZSPID').Value := frmWJGCKKCTJList.CDS_Main.fieldbyname('SPID').Value; FieldByName('hsxs').Value := frmWJGCKKCTJList.CDS_Main.fieldbyname('hsxs').Value; FieldByName('hszhis').Value := frmWJGCKKCTJList.CDS_Main.fieldbyname('hszhis').Value; FieldByName('hsxs').Value := frmWJGCKKCTJList.CDS_Main.fieldbyname('WJGXS').Value; FieldByName('CRType').Value := '加工完成'; Fwjgspid := frmWJGCKKCTJList.CDS_Main.fieldbyname('SPID').Value; end; frmWJGCKKCTJList.CDS_Main.Delete; end; end; frmWJGCKKCTJList.CDS_Main.EnableControls; end; end; finally frmWJGCKKCTJList.Free; end; end; procedure TfrmDJBCKInPut.Tv1Column3PropertiesEditValueChanged(Sender: TObject); var mvalue, FFieldName: string; Fzs, Fhszs, Fsunhao: Double; i: Integer; begin mvalue := TcxTextEdit(Sender).EditingText; FFieldName := Trim(Tv1.Controller.FocusedColumn.DataBinding.FilterFieldName); Fsunhao := 0; if Trim(mvalue) = '' then begin mvalue := '0'; end; with CDS_Sub do begin Edit; FieldByName(FFieldName).Value := mvalue; Post; Fhszs := CDS_Sub.fieldbyname('hszhis').AsFloat; Fzs := CDS_Sub.fieldbyname('zhis').AsFloat; end; if (Fzs > 0) and (Fhszs > 0) then begin Fsunhao := Fzs / Fhszs; // StrToFloatDef(format('%.0f', [(FQty / Fhsxs)]), 0); end; with CDS_Sub do begin Edit; FieldByName('sunhao').Value := Fsunhao; Post; end; tv1.Controller.EditingController.ShowEdit(); end; end.