unit U_CPRKList; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, Dialogs, cxStyles, cxCustomData, cxGraphics, cxFilter, cxData, cxDataStorage, cxEdit, DB, cxDBData, cxGridCustomTableView, cxGridTableView, cxGridBandedTableView, cxGridDBBandedTableView, cxGridLevel, cxClasses, cxControls, cxGridCustomView, cxGridDBTableView, cxGrid, StdCtrls, ComCtrls, ExtCtrls, ToolWin, cxGridCustomPopupMenu, cxGridPopupMenu, ADODB, DBClient, cxDropDownEdit, cxCheckBox, RM_Common, RM_Class, RM_e_Xls, RM_Dataset, RM_System, RM_GridReport, Menus, cxCalendar, cxButtonEdit, cxTextEdit, cxLookAndFeels, cxLookAndFeelPainters, cxNavigator; type TfrmCPRKList = class(TForm) ToolBar1: TToolBar; TBRafresh: TToolButton; TBFind: TToolButton; TBExport: TToolButton; TBClose: TToolButton; Panel1: TPanel; ADOQueryCmd: TADOQuery; ADOQueryMain: TADOQuery; ADOQueryTemp: TADOQuery; DataSource1: TDataSource; cxGridPopupMenu1: TcxGridPopupMenu; Label1: TLabel; Label2: TLabel; BegDate: TDateTimePicker; EndDate: TDateTimePicker; CDS_Main: TClientDataSet; RM1: TRMGridReport; RMDBMain: TRMDBDataSet; RMXLSExport1: TRMXLSExport; RMDBHZ: TRMDBDataSet; CDS_HZ: TClientDataSet; CDS_PRT: TClientDataSet; TBDel: TToolButton; PopupMenu1: TPopupMenu; N1: TMenuItem; N2: TMenuItem; TBAdd: TToolButton; TBEdit: TToolButton; Label3: TLabel; Label4: TLabel; Label5: TLabel; Label8: TLabel; SPName: TEdit; FactoryName: TEdit; SPID: TEdit; SPSpec: TEdit; Label6: TLabel; SPCF: TEdit; Label7: TLabel; OrderNo: TEdit; cxGrid2: TcxGrid; Tv1: TcxGridDBTableView; v1Column6: TcxGridDBColumn; v1Column2: TcxGridDBColumn; v1Column4: TcxGridDBColumn; v1Column13: TcxGridDBColumn; v1Column5: TcxGridDBColumn; v1Column15: TcxGridDBColumn; v1Column17: 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; Label9: TLabel; ToFactoryName: TEdit; Label12: TLabel; CRType: TComboBox; v1Column18: TcxGridDBColumn; Label10: TLabel; KuWei: TEdit; v1Column19: TcxGridDBColumn; Label11: TLabel; RCGangNo: TEdit; Label13: TLabel; PRTColor: TEdit; Label14: TLabel; SOrddefstr1: TEdit; Label15: TLabel; PRTHX: TEdit; v1Column20: TcxGridDBColumn; ToolButton1: TToolButton; ADOQueryPrint: TADOQuery; v1Column21: TcxGridDBColumn; ToolButton2: TToolButton; v1Column22: TcxGridDBColumn; v1Column23: TcxGridDBColumn; v1Column24: TcxGridDBColumn; v1Column25: TcxGridDBColumn; Tv1Column1: TcxGridDBColumn; Tv1Column2: TcxGridDBColumn; Tv1Column3: TcxGridDBColumn; Tv1Column4: TcxGridDBColumn; Tv1Column5: TcxGridDBColumn; procedure FormDestroy(Sender: TObject); procedure FormClose(Sender: TObject; var Action: TCloseAction); procedure FormCreate(Sender: TObject); procedure TBRafreshClick(Sender: TObject); procedure ConNoMChange(Sender: TObject); procedure TBCloseClick(Sender: TObject); procedure FormShow(Sender: TObject); procedure TBExportClick(Sender: TObject); procedure TBFindClick(Sender: TObject); procedure N1Click(Sender: TObject); procedure N2Click(Sender: TObject); procedure TBDelClick(Sender: TObject); procedure TBAddClick(Sender: TObject); procedure TBEditClick(Sender: TObject); procedure SPIDKeyPress(Sender: TObject; var Key: Char); procedure SPIDChange(Sender: TObject); procedure SPSpecChange(Sender: TObject); procedure FactoryNameChange(Sender: TObject); procedure ToolButton1Click(Sender: TObject); procedure ToolButton2Click(Sender: TObject); private canshu1, canshu2: string; procedure InitGrid(); { Private declarations } public { Public declarations } end; var frmCPRKList: TfrmCPRKList; implementation uses U_DataLink, U_RTFun, U_DJBCKInPut, U_FjList10, U_CPCKInPut; {$R *.dfm} procedure TfrmCPRKList.FormDestroy(Sender: TObject); begin frmCPRKList := nil; end; procedure TfrmCPRKList.FormClose(Sender: TObject; var Action: TCloseAction); begin Action := caFree; end; procedure TfrmCPRKList.FormCreate(Sender: TObject); begin //cxGrid1.Align:=alClient; canshu1 := Trim(DParameters1); canshu2 := Trim(DParameters2); EndDate.DateTime := SGetServerDate10(ADOQueryTemp); BegDate.DateTime := EndDate.DateTime - 90; end; procedure TfrmCPRKList.InitGrid(); begin try ADOQueryMain.DisableControls; with ADOQueryMain do begin Filtered := False; Close; sql.Clear; sql.Add(' select A.* '); sql.Add(',JYBZNOTE=(select JYBZNOTE from JYOrder_Main JM where JM.MainId=A.ORDMainIdRK)'); sql.Add(',JYFHNOTE=(select JYFHNOTE from JYOrder_Main JM where JM.MainId=A.ORDMainIdRK)'); sql.Add(',OrderNO=(select OrderNO from JYOrder_Main JM where JM.MainId=A.ORDMainIdRK)'); sql.Add(' ,DJSOrddefstr1=(case when A.CRType=''期初入库'' then A.SOrddefstr1 else(select SOrddefstr1 from JYOrder_Sub JM where JM.SubId=A.OrdSubIdRK )end)'); sql.Add(' ,DJPRTColor=(case when A.CRType=''期初入库'' then A.PRTColor else(select PRTColor from JYOrder_Sub JM where JM.SubId=A.OrdSubIdRK )end)'); sql.Add(' ,DJPRTHX=(case when A.CRType=''期初入库'' then A.PRTHX else(select PRTHX from JYOrder_Sub JM where JM.SubId=A.OrdSubIdRK )end)'); sql.Add(' ,ZMoney=cast(cast(isnull(A.PBPrice,0) as decimal(18,2))*cast(isnull(A.Qty,0) as decimal(18,2)) as decimal(18,2)) '); sql.Add(' ,DJPRTkuanNo=(case when A.CRType=''期初入库'' then A.PRTkuanNo else(select PRTkuanNo from JYOrder_Sub JM where JM.SubId=A.OrdSubIdRK )end)'); sql.Add(' from CK_SXPB_CR A'); sql.add(' where A.CRTime>=''' + Trim(FormatDateTime('yyyy-MM-dd', BegDate.DateTime)) + ''''); sql.Add(' and A.CRTime<=''' + Trim(FormatDateTime('yyyy-MM-dd', enddate.DateTime + 1)) + ''''); sql.Add(' and isnull(CKName,'''')=''成品'''); SQL.Add(' and CRFlag=''入库'' '); Open; //ShowMessage(SQL.Text); end; SCreateCDS20(ADOQueryMain, CDS_Main); SInitCDSData20(ADOQueryMain, CDS_Main); finally ADOQueryMain.EnableControls; end; end; procedure TfrmCPRKList.TBRafreshClick(Sender: TObject); begin BegDate.SetFocus; InitGrid(); end; procedure TfrmCPRKList.ConNoMChange(Sender: TObject); begin if ADOQueryMain.Active then begin SDofilter(ADOQueryMain, SGetFilters(Panel1, 1, 2)); end; end; procedure TfrmCPRKList.TBCloseClick(Sender: TObject); begin WriteCxGrid('待检布入库列表', Tv1, '待检布仓库'); Close; end; procedure TfrmCPRKList.FormShow(Sender: TObject); begin if Trim(canshu2) = '查看' then begin TBAdd.Visible := False; TBDel.Visible := False; TBEdit.Visible := False; end else begin TBAdd.Visible := True; TBDel.Visible := True; TBEdit.Visible := True; end; ReadCxGrid('待检布入库列表', Tv1, '待检布仓库'); //InitGrid(); end; procedure TfrmCPRKList.TBExportClick(Sender: TObject); begin if ADOQueryMain.IsEmpty then exit; TcxGridToExcel('成品入库列表', cxGrid2); end; procedure TfrmCPRKList.TBFindClick(Sender: TObject); begin if ADOQueryMain.Active then begin SDofilter(ADOQueryMain, SGetFilters(Panel1, 1, 2)); SCreateCDS20(ADOQueryMain, CDS_Main); SInitCDSData20(ADOQueryMain, CDS_Main); end; end; procedure TfrmCPRKList.N1Click(Sender: TObject); begin SelOKNo(CDS_Main, True); end; procedure TfrmCPRKList.N2Click(Sender: TObject); begin SelOKNo(CDS_Main, False); end; procedure TfrmCPRKList.TBDelClick(Sender: TObject); begin if CDS_Main.IsEmpty then Exit; if Trim(CDS_Main.fieldbyname('SPID').AsString) <> '' then begin if Trim(CDS_Main.fieldbyname('CRType').AsString) = '平移入库' then begin Application.MessageBox('平移入库的数据为自动生成,不能删除!', '提示', 0); Exit; end; with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from CK_SXPB_CR where FZSPID=''' + Trim(CDS_Main.fieldbyname('SPID').AsString) + ''''); sql.Add(' and CRQtyFlag=-1'); Open; end; if ADOQueryTemp.IsEmpty = False then begin Application.MessageBox('已有出库记录,不能删除!', '提示', 0); Exit; end; with ADOQueryTemp do begin Close; SQL.Clear; SQL.Add('select * from YF_Money_CR where MainId=' + QuotedStr(Trim(CDS_Main.fieldbyname('SPID').AsString))); SQL.Add('and CRFlag=''应付付'' and yfname<>''待检布其他费'' '); 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_Main.fieldbyname('SPID').AsString) + ''''); if Trim(CDS_Main.fieldbyname('CRType').AsString) = '客户退货' then begin sql.Add('delete from YF_Money_CR '); sql.Add(' where mainID=''' + Trim(CDS_Main.fieldbyname('SPID').AsString) + ''''); end; {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='+Trim(CDS_Main.fieldbyname('CRID').AsString));} ExecSQL; end; with ADOQueryCmd do begin Close; sql.Clear; sql.Add(' delete YF_Money_CR where mainid=''' + Trim(CDS_Main.fieldbyname('SPID').AsString) + ''''); ExecSQL; end; with ADOQueryCmd do begin Close; sql.Clear; sql.Add(' delete YF_Money_LL where frommainid=''' + Trim(CDS_Main.fieldbyname('SPID').AsString) + ''''); ExecSQL; end; { with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select KCKGQty=isnull(KCKGQty,0) from CK_SXPB_KC where CRID='+Trim(CDS_Main.fieldbyname('CRID').AsString)); Open; end; if ADOQueryTemp.IsEmpty=False then begin if ADOQueryTemp.FieldByName('KCKGQty').Value<0 then begin ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('入库公斤数小于出库公斤数不能删除!','提示',0); Exit; end; end; } ADOQueryCmd.Connection.CommitTrans; CDS_Main.Delete; except ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('删除异常!', '提示', 0); end; end else begin CDS_Main.Delete; end; end; procedure TfrmCPRKList.TBAddClick(Sender: TObject); begin try frmCPCKInPut := TfrmCPCKInPut.Create(Application); with frmCPCKInPut do begin FBCId := ''; if ShowModal = 1 then begin Self.InitGrid(); end; end; finally frmCPCKInPut.Free; end; end; procedure TfrmCPRKList.TBEditClick(Sender: TObject); begin if CDS_Main.IsEmpty then Exit; if Trim(CDS_Main.fieldbyname('CRType').AsString) = '平移入库' then begin Application.MessageBox('平移入库的数据为自动生成,不能修改!', '提示', 0); Exit; end; with ADOQueryTemp do begin Close; SQL.Clear; SQL.Add('select * from YF_Money_CR where MainId=' + QuotedStr(Trim(CDS_Main.fieldbyname('SPID').AsString))); SQL.Add('and CRFlag=''应付付'' and yfname<>''待检布其他费'' '); Open; end; if ADOQueryTemp.IsEmpty = False then begin Application.MessageBox('已生成应付款数据,不能修改!', '提示', 0); Exit; end; try frmCPCKInPut := TfrmCPCKInPut.Create(Application); with frmCPCKInPut do begin FBCId := Trim(self.CDS_Main.fieldbyname('SPID').AsString); TBDel.Visible := False; TBAdd.Visible := False; if ShowModal = 1 then begin Self.InitGrid(); end; end; finally frmCPCKInPut.Free; end; end; procedure TfrmCPRKList.SPIDKeyPress(Sender: TObject; var Key: Char); begin if Key = #13 then begin {if Length(Trim(SPID.Text))<4 then Exit; try ADOQueryMain.DisableControls; with ADOQueryMain do begin Filtered:=False; Close; sql.Clear; sql.Add(' select A.* '); sql.Add(',ConNo=(select ConNo from Contract_Main CM where CM.MainId=A.CGMainId)'); //sql.Add(' ,ConNo=(select ConNo from Contract_Main CM where CM.MainId=A.CGMainId )'); sql.Add(' from CK_SXPB_CR A'); sql.add(' where SPID like :SXID'); Parameters.ParamByName('SXID').Value:='%'+Trim(SXID.Text)+'%'; Open; //ShowMessage(SQL.Text); end; SCreateCDS20(ADOQueryMain,CDS_Main); SInitCDSData20(ADOQueryMain,CDS_Main); finally ADOQueryMain.EnableControls; end; } end; end; procedure TfrmCPRKList.SPIDChange(Sender: TObject); begin if Length(Trim(SPID.Text)) < 4 then begin if Trim(SPID.Text) <> '' then Exit; end; TBFind.Click; end; procedure TfrmCPRKList.SPSpecChange(Sender: TObject); begin TBFind.Click; end; procedure TfrmCPRKList.FactoryNameChange(Sender: TObject); begin TBFind.Click; end; procedure TfrmCPRKList.ToolButton1Click(Sender: TObject); var FFacName, FSPID, FCRType, fPrintFile: string; i: Integer; begin if CDS_Main.IsEmpty then Exit; if CDS_Main.Locate('SSel', True, []) = False then begin Application.MessageBox('没有选择数据', '提示', 0); Exit; end; // with ADOQueryCmd do // begin // Close; // sql.Clear; // sql.Add('SELECT * FROM TBSubID where 1=2 '); // open; // end; FFacName := ''; FSPID := ''; FCRType := ''; CDS_Main.DisableControls; try i := 0; ADOQueryCmd.Connection.BeginTrans; // with CDS_Main do begin First; while not Eof do begin if FieldByName('SSel').AsBoolean then begin with ADOQueryPrint do begin Close; sql.Clear; sql.Add('select A.*, '); sql.Add('PRTColor=(select PRTColor from JYOrder_Sub JM where JM.SubId=A.OrdSubIdRK ),'); sql.Add('FromOrderNo=(select X.OrderNo from JYOrder_Main X where X.MainId=A.ORDMainIdRK)'); sql.Add('from CK_SXPB_CR A '); sql.Add(' where A.SPId=''' + Trim(CDS_Main.fieldbyname('SPId').AsString) + ''''); Open; end; if i = 0 then SCreateCDS20(ADOQueryPrint, CDS_PRT); SInitCDSData20(ADOQueryPrint, CDS_PRT); { if Trim(FSPID)='' then begin FSPID:=Trim(CDS_Main.fieldbyname('SPID').AsString); end else begin if Trim(CDS_Main.fieldbyname('SPID').AsString)<>FSPID then begin Application.MessageBox('不同入库单号,不能一起打印!','提示信息',0); ADOQueryPrint.Connection.RollbackTrans; // EnableControls; Exit; end; end; } if Trim(FCRType) = '' then begin FCRType := Trim(CDS_Main.fieldbyname('CRType').AsString); end else begin if Trim(CDS_Main.fieldbyname('CRType').AsString) <> FCRType then begin Application.MessageBox('不同入库类型,不能一起打印!', '提示信息', 0); ADOQueryPrint.Connection.RollbackTrans; // EnableControls; Exit; end; end; if Trim(FFacName) = '' then begin FFacName := Trim(CDS_Main.fieldbyname('FactoryName').AsString); end else begin if Trim(CDS_Main.fieldbyname('FactoryName').AsString) <> FFacName then begin Application.MessageBox('不是来自同一个加工厂,不能一起打印!', '提示信息', 0); ADOQueryPrint.Connection.RollbackTrans; // EnableControls; Exit; end; end; i := i + 1; end; Next; end; end; ADOQueryCmd.Connection.CommitTrans; // except ADOQueryCmd.Connection.RollbackTrans; // end; CDS_Main.EnableControls; // SCreateCDS20(ADOQueryPrint,CDS_PRT); // SInitCDSData20(ADOQueryPrint,CDS_PRT); fPrintFile := ExtractFilePath(Application.ExeName) + 'Report\入库单.rmf'; if FileExists(fPrintFile) then begin RM1.LoadFromFile(fPrintFile); RM1.ShowReport; end else begin Application.MessageBox(PChar('没有找' + fPrintFile), '提示', 0); end; end; procedure TfrmCPRKList.ToolButton2Click(Sender: TObject); begin if CDS_Main.IsEmpty then Exit; try frmFjList10 := TfrmFjList10.Create(Application); with frmFjList10 do begin // PState:=1; fkeyNO := Trim(Self.CDS_Main.fieldbyname('SPID').AsString); fType := '待检布'; if ShowModal = 1 then begin end; end; finally frmFjList10.Free; end; end; end.