unit U_SXCKOutPut; 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, cxSpinEdit, StdCtrls; type TfrmSXCKOutPut = class(TForm) ToolBar1: TToolBar; TBAdd: TToolButton; TBDel: TToolButton; TBSave: TToolButton; TBClose: TToolButton; DataSource3: TDataSource; CDS_Sub: TClientDataSet; ADOQueryCmd: TADOQuery; ADOQueryMain: TADOQuery; ADOQueryTemp: TADOQuery; cxGridPopupMenu2: TcxGridPopupMenu; cxGrid2: TcxGrid; Tv1: TcxGridDBTableView; v1Column6: TcxGridDBColumn; v1Column2: TcxGridDBColumn; v1CRType: TcxGridDBColumn; v1Column13: TcxGridDBColumn; v1Column14: TcxGridDBColumn; v2Column1: TcxGridDBColumn; v1Column8: TcxGridDBColumn; v1Column7: TcxGridDBColumn; v1Column1: TcxGridDBColumn; v1Column10: TcxGridDBColumn; v1Column11: TcxGridDBColumn; v1Column9: TcxGridDBColumn; v2Column6: TcxGridDBColumn; v1Column3: TcxGridDBColumn; v1Column16: TcxGridDBColumn; v1Column12: TcxGridDBColumn; cxGrid2Level1: TcxGridLevel; v1Column5: TcxGridDBColumn; Label1: TLabel; v1Column4: TcxGridDBColumn; v1Column15: TcxGridDBColumn; v1Column17: 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 v1Column1PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); procedure v1Column11PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); procedure Tv1MouseDown(Sender: TObject; Button: TMouseButton; Shift: TShiftState; X, Y: Integer); procedure v1Column15PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); private { Private declarations } function SaveCKData():Boolean; public { Public declarations } FBCId:String; end; var frmSXCKOutPut: TfrmSXCKOutPut; implementation uses U_DataLink,U_RTFun,U_ClothContractListHZCX,U_ZDYHelp,U_SXCKKCSelList, U_GYSSelList, U_ZdyAttachGYS, U_ProductOrderListSel; {$R *.dfm} procedure TfrmSXCKOutPut.FormClose(Sender: TObject; var Action: TCloseAction); begin Action:=caFree; end; procedure TfrmSXCKOutPut.TBAddClick(Sender: TObject); begin try frmSXCKKCSelList:=TfrmSXCKKCSelList.Create(Application); with frmSXCKKCSelList do begin ToolButton1.Visible:=True; if ShowModal=1 then begin frmSXCKKCSelList.CDS_Main.DisableControls; with frmSXCKKCSelList.CDS_Main do begin First; while frmSXCKKCSelList.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(frmSXCKKCSelList.CDS_Main.fieldbyname('ORDMainIdRK').AsString); FieldByName('ORDSubIdRK').Value:=Trim(frmSXCKKCSelList.CDS_Main.fieldbyname('ORDSubIdRK').AsString); FieldByName('OrderNo').Value:=frmSXCKKCSelList.CDS_Main.fieldbyname('OrderNo').Value; FieldByName('QCOrderNo').Value:=frmSXCKKCSelList.CDS_Main.fieldbyname('QCOrderNo').Value; FieldByName('SCOrderNo').Value:=frmSXCKKCSelList.CDS_Main.fieldbyname('SCOrderNo').Value; FieldByName('QCSCOrderNo').Value:=frmSXCKKCSelList.CDS_Main.fieldbyname('QCSCOrderNo').Value; FieldByName('FactoryName').Value:=frmSXCKKCSelList.CDS_Main.fieldbyname('FactoryName').Value; FieldByName('FactoryNo').Value:=frmSXCKKCSelList.CDS_Main.fieldbyname('FactoryNo').Value; FieldByName('SSType').Value:=frmSXCKKCSelList.CDS_Main.fieldbyname('SSType').Value; FieldByName('SPName').Value:=frmSXCKKCSelList.CDS_Main.fieldbyname('SPName').Value; FieldByName('SPCode').Value:=frmSXCKKCSelList.CDS_Main.fieldbyname('SPCode').Value; FieldByName('CPID').Value:=frmSXCKKCSelList.CDS_Main.fieldbyname('CPID').Value; FieldByName('SPSpec').Value:=frmSXCKKCSelList.CDS_Main.fieldbyname('SPSpec').Value; FieldByName('SPCF').Value:=frmSXCKKCSelList.CDS_Main.fieldbyname('SPCF').Value; FieldByName('SPMF').Value:=frmSXCKKCSelList.CDS_Main.fieldbyname('SPMF').Value; FieldByName('SPKZ').Value:=frmSXCKKCSelList.CDS_Main.fieldbyname('SPKZ').Value; FieldByName('FromFactoryName').Value:=frmSXCKKCSelList.CDS_Main.fieldbyname('ToFactoryName').Value; FieldByName('FromFactoryNo').Value:=frmSXCKKCSelList.CDS_Main.fieldbyname('ToFactoryNo').Value; FieldByName('ToFactoryName').Value:=frmSXCKKCSelList.CDS_Main.fieldbyname('ToFactoryName').Value; FieldByName('ToFactoryNo').Value:=frmSXCKKCSelList.CDS_Main.fieldbyname('ToFactoryNo').Value; FieldByName('QtyUnit').Value:=frmSXCKKCSelList.CDS_Main.fieldbyname('QtyUnit').Value; FieldByName('PiQty').Value:=frmSXCKKCSelList.CDS_Main.fieldbyname('MXKCPiQty').Value; FieldByName('Qty').Value:=frmSXCKKCSelList.CDS_Main.fieldbyname('MXKCQty').Value; FieldByName('FZSPID').Value:=frmSXCKKCSelList.CDS_Main.fieldbyname('SPID').Value; end; frmSXCKKCSelList.CDS_Main.Delete; end; end; frmSXCKKCSelList.CDS_Main.EnableControls; end; end; finally frmSXCKKCSelList.Free; end; end; function TfrmSXCKOutPut.SaveCKData():Boolean; var FCRID,Maxno,FSPID,MaxPYNo,FPYID: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_CR where SPID='''+Trim(CDS_Sub.fieldbyname('SPID').AsString)+''''); Open; end; FSPID:=Trim(ADOQueryTemp.fieldbyname('SPID').AsString); if Trim(FSPID)='' then begin if GetLSNo(ADOQueryCmd,Maxno,'PC','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('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('QCOrderNo').Value:=Trim(CDS_Sub.fieldbyname('QCOrderNo').AsString); FieldByName('QCSCOrderNo').Value:=Trim(CDS_Sub.fieldbyname('QCSCOrderNo').AsString); FieldByName('CPID').Value:=Trim(CDS_Sub.fieldbyname('CPID').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); FieldByName('CKName').Value:='坯布'; if Trim(CDS_Sub.fieldbyname('CRType').AsString)='平移出库' then begin FieldByName('PYID').Value:=Trim(Maxno); end; 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(' where SPID='''+Trim(CDS_Sub.fieldbyname('FZSPID').AsString)+''''); ExecSQL; end; with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from CK_SXPB_CR where SPID='''+Trim(CDS_Sub.fieldbyname('FZSPID').AsString)+''''); Open; end; if ADOQueryTemp.FieldByName('MXKCQty').Value<0 then begin CDS_Sub.DisableControls; ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('出库数大于库存数不能保存!','提示',0); Exit; end; if Trim(CDS_Sub.fieldbyname('CRType').AsString)='平移出库' then begin with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from CK_SXPB_CR where PYID='''+Trim(Maxno)+''''); sql.Add(' and isnull(CRType,'''')=''平移入库'' '); Open; end; FPYID:=Trim(ADOQueryTemp.fieldbyname('SPID').AsString); if Trim(FPYID)='' then begin if GetLSNo(ADOQueryCmd,MaxPYNo,'YR','CK_SXPB_CR',3,1)=False then begin Result:=False; ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('取坯布平移入库编号失败!','提示',0); Exit; end; end else begin MaxPYNo:=Trim(FPYID); end; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('select * from CK_SXPB_CR where SPID='''+Trim(MaxPYNo)+''''); Open; end; with ADOQueryCmd do begin if Trim(FPYID)='' then begin Append; end else begin Edit; end; FieldByName('SPID').Value:=Trim(MaxPYNo); FieldByName('ORDMainIdRK').Value:=Trim(CDS_Sub.fieldbyname('ORDMainIdCK').AsString); FieldByName('ORDSubIdRK').Value:=Trim(CDS_Sub.fieldbyname('ORDSubIdCK').AsString); {FieldByName('ORDMainIdCK').Value:=Trim(CDS_Sub.fieldbyname('ORDMainIdCK').AsString); FieldByName('ORDSubIdCK').Value:=Trim(CDS_Sub.fieldbyname('ORDSubIdCK').AsString);} FieldByName('FZSPID').Value:=Trim(MaxPYNo); 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('QCOrderNo').Value:=Trim(CDS_Sub.fieldbyname('QCOrderNo').AsString); FieldByName('QCSCOrderNo').Value:=Trim(CDS_Sub.fieldbyname('QCSCOrderNo').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); FieldByName('CKName').Value:='坯布'; FieldByName('CRType').Value:='平移入库'; FieldByName('PYID').Value:=Trim(Maxno); if Trim(FPYID)='' 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(' where SPID='''+Trim(MaxPYNo)+''''); ExecSQL; end; with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from CK_SXPB_CR where SPID='''+Trim(MaxPYNo)+''''); Open; end; if ADOQueryTemp.FieldByName('MXKCQty').Value<0 then begin CDS_Sub.DisableControls; ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('出库数大于库存数不能保存!','提示',0); Exit; end; 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 TfrmSXCKOutPut.TBCloseClick(Sender: TObject); begin WriteCxGrid('坯布出库登记PMD',Tv1,'坯布仓库'); Close; end; procedure TfrmSXCKOutPut.FormShow(Sender: TObject); begin ReadCxGrid('坯布出库登记PMD',Tv1,'坯布仓库'); with ADOQueryTemp do begin Close; sql.Clear; sql.Add(' select A.* '); sql.Add(' from CK_SXPB_CR A'); sql.Add(' where SPID='''+Trim(FBCId)+''''); Open; end; SCreateCDS20(ADOQueryTemp,CDS_Sub); SInitCDSData20(ADOQueryTemp,CDS_Sub); end; procedure TfrmSXCKOutPut.TBDelClick(Sender: TObject); begin if CDS_Sub.IsEmpty 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='); sql.Add('(select SPID from CK_SXPB_CR where PYID='''+Trim(CDS_Sub.fieldbyname('SPID').AsString)+''''); sql.Add(' and isnull(CRType,'''')=''平移入库'')'); sql.Add(' and CRQtyFlag=-1'); Open; end; if ADOQueryTemp.IsEmpty=False then begin Application.MessageBox('已有出库记录,不能删除!','提示',0); Exit; end; if Application.MessageBox('确定要删除数据吗?','提示',32+4)<>IDYES then Exit; 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)+''''); sql.Add('Update CK_SXPB_CR Set MXKCKgQty=(select sum(isnull(KGQty,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(' where SPID='''+Trim(CDS_Sub.fieldbyname('FZSPID').AsString)+''''); {sql.Add('Update CK_SXPB_KC Set KCKGQty=(select sum(KGQty*CRQtyFlag) from CK_SXPB_CR A where A.CRID=CK_SXPB_KC.CRID)'); sql.Add(',KCPiQty=(select sum(PiQty*CRQtyFlag) from CK_SXPB_CR A where A.CRID=CK_SXPB_KC.CRID)'); sql.Add(' where CRID='+Trim(CDS_Sub.fieldbyname('CRID').AsString));} ExecSQL; end; ADOQueryCmd.Connection.CommitTrans; except ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('删除异常!','提示',0); end; end; CDS_Sub.Delete; end; procedure TfrmSXCKOutPut.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 CDS_Sub.Locate('ToFactoryName',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('PiQty',null,[])=True then begin Application.MessageBox('匹数不能为空!','提示',0); Exit; end; if CDS_Sub.Locate('CRType;CKOrderNo',VarArrayOf(['加工出库',Null]),[loPartialKey])=True then begin Application.MessageBox('加工出库的数据出到指示单号不能为空!','提示',0); Exit; end; if CDS_Sub.Locate('CRType;ToFactoryName',VarArrayOf(['加工出库',Null]),[loPartialKey])=True then begin Application.MessageBox('加工出库的数据出到加工厂不能为空!','提示',0); Exit; end; if CDS_Sub.Locate('CRType;ToKHName',VarArrayOf(['销售出库',Null]),[loPartialKey])=True then begin Application.MessageBox('销售出库的数据出到客户不能为空!','提示',0); Exit; end; if CDS_Sub.Locate('CRType;ToFactoryName',VarArrayOf(['退货',Null]),[loPartialKey])=True then begin Application.MessageBox('退货的数据出到供应商不能为空!','提示',0); Exit; end; if CDS_Sub.Locate('CRType;ToFactoryName',VarArrayOf(['平移出库',Null]),[loPartialKey])=True then begin Application.MessageBox('平移出库的数据出到加工厂不能为空!','提示',0); Exit; end; if SaveCKData() then begin Application.MessageBox('保存成功!','提示',0); //ModalResult:=1; Exit; end; end; procedure TfrmSXCKOutPut.v1Column1PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmClothContractListHZCX:=TfrmClothContractListHZCX.Create(Application); with frmClothContractListHZCX do begin if ShowModal=1 then begin with Self.CDS_Sub do begin Edit; FieldByName('CGConNo').Value:=Trim(frmClothContractListHZCX.Order_Main.fieldbyname('ConNo').AsString); FieldByName('CGConMainId').Value:=Trim(frmClothContractListHZCX.Order_Main.fieldbyname('MainId').AsString); FieldByName('CGConSubId').Value:=Trim(frmClothContractListHZCX.Order_Main.fieldbyname('SubId').AsString); FieldByName('FactoryName').Value:=Trim(frmClothContractListHZCX.Order_Main.fieldbyname('FactoryNoName').AsString); FieldByName('SXName').Value:=Trim(frmClothContractListHZCX.Order_Main.fieldbyname('C_CodeName').AsString); //Post; end; end; end; finally frmClothContractListHZCX.Free; end; end; procedure TfrmSXCKOutPut.v1Column11PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmZDYHelp:=TfrmZDYHelp.Create(Application); with frmZDYHelp do begin flag:='YFFactory'; flagname:='加工厂/供应商'; if ShowModal=1 then begin with Self.CDS_Sub do begin Edit; FieldByName('ToFactoryNo').Value:=Trim(ClientDataSet1.fieldbyname('ZdyNo').AsString); FieldByName('ToFactoryName').Value:=Trim(ClientDataSet1.fieldbyname('ZdyName').AsString); //Post; end; end; end; finally frmZDYHelp.Free; end; end; procedure TfrmSXCKOutPut.Tv1MouseDown(Sender: TObject; Button: TMouseButton; Shift: TShiftState; X, Y: Integer); var FFSPID:String; begin if CDS_Sub.IsEmpty 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 SPID='''+Trim(CDS_Sub.fieldbyname('SPID').AsString)+''''); Open; end; FFSPID:=Trim(ADOQueryTemp.fieldbyname('SPID').AsString); if Trim(FFSPID)<>'' then begin v1CRType.Options.Editing:=False; end; end; end; procedure TfrmSXCKOutPut.v1Column15PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmZDYHelp:=TfrmZDYHelp.Create(Application); with frmZDYHelp do begin flag:='CustomerNoName'; flagname:='客户'; if ShowModal=1 then begin with Self.CDS_Sub do begin Edit; FieldByName('ToKHNo').Value:=Trim(ClientDataSet1.fieldbyname('ZdyNo').AsString); FieldByName('ToKHName').Value:=Trim(ClientDataSet1.fieldbyname('ZdyName').AsString); //Post; end; end; end; finally frmZDYHelp.Free; end; end; end.