unit U_PBCKlistSel; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, Dialogs, ComCtrls, ToolWin, StdCtrls, ExtCtrls, cxStyles, cxCustomData, cxGraphics, cxFilter, cxData, cxDataStorage, cxEdit, DB, cxDBData, cxButtonEdit, cxDropDownEdit, cxGridLevel, cxGridCustomTableView, cxGridTableView, cxGridDBTableView, cxClasses, cxControls, cxGridCustomView, cxGrid, DBClient, ADODB, cxGridCustomPopupMenu, cxGridPopupMenu, RM_Common, RM_Class, RM_e_Xls, RM_GridReport, RM_System, RM_Dataset, cxTextEdit, cxPC, cxCheckBox, Menus; type TfrmPBCKlistSel = class(TForm) ToolBar1: TToolBar; TBRafresh: TToolButton; TBExport: TToolButton; TBClose: TToolButton; Panel1: TPanel; Label1: TLabel; BegDate: TDateTimePicker; EndDate: TDateTimePicker; cxGrid1: TcxGrid; Tv1: TcxGridDBTableView; v1P_CodeName: TcxGridDBColumn; v1P_MF: TcxGridDBColumn; v1P_KZ: TcxGridDBColumn; v1Qty: TcxGridDBColumn; v1QtyUnit: TcxGridDBColumn; v1Note: TcxGridDBColumn; cxGrid1Level1: TcxGridLevel; v1CRType: TcxGridDBColumn; v1CRTime: TcxGridDBColumn; v1CRNO: TcxGridDBColumn; v1Filler: TcxGridDBColumn; v1FillTime: TcxGridDBColumn; Label2: TLabel; CRType: TComboBox; Label5: TLabel; ADOQueryCmd: TADOQuery; ADOQueryTmp: TADOQuery; DataSource1: TDataSource; CDS_Main: TClientDataSet; cxGridPopupMenu1: TcxGridPopupMenu; v1MJXH: TcxGridDBColumn; ADOPrint: TADOQuery; RMXLSExport1: TRMXLSExport; v1P_Code: TcxGridDBColumn; v1inoutNO: TcxGridDBColumn; CRNO: TEdit; Label7: TLabel; v1custName: TcxGridDBColumn; v1TocustName: TcxGridDBColumn; v1Column1: TcxGridDBColumn; v1Column2: TcxGridDBColumn; RMDB_Main: TRMDBDataSet; cxStyleRepository1: TcxStyleRepository; cxStyle1: TcxStyle; cxStyle2: TcxStyle; cxStyle_gridRow: TcxStyle; cxStyle_gridFoot: TcxStyle; cxStyle_gridHead: TcxStyle; cxStyle_gridGroupBox: TcxStyle; cxStyle_yellow: TcxStyle; cxStyle_Red: TcxStyle; cxStyle_fontBlack: TcxStyle; cxStyle_fontclFuchsia: TcxStyle; cxStyle_fontclPurple: TcxStyle; cxStyle_fontclGreen: TcxStyle; cxStyle_fontclBlue: TcxStyle; cxStyle_fontclTeal: TcxStyle; cxStyle_fontclOlive: TcxStyle; Label8: TLabel; ToFactoryName: TEdit; ADOQueryMain: TADOQuery; RM1: TRMGridReport; v1Column5: TcxGridDBColumn; CodeName: TEdit; Label11: TLabel; Code: TEdit; Label14: TLabel; PopupMenu1: TPopupMenu; N1: TMenuItem; N2: TMenuItem; Label9: TLabel; Note: TEdit; v1Column4: TcxGridDBColumn; v1Column3: TcxGridDBColumn; v1Column6: TcxGridDBColumn; v1Column7: TcxGridDBColumn; v1Column8: TcxGridDBColumn; v1Column9: TcxGridDBColumn; v1Column10: TcxGridDBColumn; ToolButton1: TToolButton; cxTabControl1: TcxTabControl; v1Column11: TcxGridDBColumn; procedure FormClose(Sender: TObject; var Action: TCloseAction); procedure FormDestroy(Sender: TObject); procedure OrderNoChange(Sender: TObject); procedure FormShow(Sender: TObject); procedure FormCreate(Sender: TObject); procedure TBCloseClick(Sender: TObject); procedure TBRafreshClick(Sender: TObject); procedure v1Column6CompareRowValuesForCellMerging( Sender: TcxGridColumn; ARow1: TcxGridDataRow; AProperties1: TcxCustomEditProperties; const AValue1: Variant; ARow2: TcxGridDataRow; AProperties2: TcxCustomEditProperties; const AValue2: Variant; var AAreEqual: Boolean); procedure N1Click(Sender: TObject); procedure N2Click(Sender: TObject); procedure ToolButton1Click(Sender: TObject); procedure TBExportClick(Sender: TObject); procedure cxTabControl1Change(Sender: TObject); private procedure InitGrid(); function YSData(ADO:TADOQuery):Boolean; function YSData_Other(ADO:TADOQuery;fYFName:string;fmoney:double):Boolean; procedure SetStatus(); { Private declarations } public fCKName,FZZType:string; canshu1,canshu2:string; { Public declarations } end; var frmPBCKlistSel: TfrmPBCKlistSel; implementation uses U_DataLink,U_Fun10,U_ZDYHelp; {$R *.dfm} procedure TfrmPBCKlistSel.SetStatus(); begin end; function TfrmPBCKlistSel.YSData(ADO:TADOQuery):Boolean; var CRID,YFID,Price,PriceUnit,OrderUnit,FComTaiTou,cust:String; begin Result:=False; with ADOQueryTmp do begin Close; SQL.Clear; sql.Add('select * from YF_Money_KC where FactoryName='''+Trim(ADO.fieldbyname('custName').asstring)+''' and YFDefFlag1=0 '); Open; end; if not ADOQueryTmp.IsEmpty then begin CRID:=ADOQueryTmp.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(ADO.fieldbyname('custName').asstring); FieldByName('ZdyStr1').Value:='应收收'; Post; end; end; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('delete from YF_Money_CR '); sql.Add(' where MainID='''+Trim(ADO.fieldbyname('CRNO').AsString)+''''); sql.Add(' and subID='''+Trim(ADO.fieldbyname('CRID').AsString)+''''); sql.Add(' and YFName=''产品销售'' '); execsql; end; with ADOQueryTmp do begin Close; sql.Clear; sql.Add('select * from YF_Money_CR '); sql.Add(' where MainID='''+Trim(ADO.fieldbyname('CRNO').AsString)+''''); sql.Add(' and subID='''+Trim(ADO.fieldbyname('CRID').AsString)+''''); sql.Add(' and YFName=''产品销售'' '); Open; end; if ADOQueryTmp.IsEmpty then begin if GetLSNo(ADOQueryCmd,YFID,'CS','YF_Money_CR',4,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(ADO.fieldbyname('CRNO').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(ADO.fieldbyname('custName').asstring); FieldByName('CRTime').Value:=Trim(FormatDateTime('yyyy-MM-dd',ADO.fieldbyname('CRTime').AsDateTime)); FieldByName('YFType').Value:='自动生成'; FieldByName('ps').Value:=ADO.fieldbyname('RollNum').AsFloat; FieldByName('Qty').Value:=ADO.fieldbyname('Qty').AsFloat; FieldByName('Price').Value:=ADO.fieldbyname('Price').AsFloat; FieldByName('Money').Value:=ADO.fieldbyname('Money').AsFloat; FieldByName('BBMoney').Value:=ADO.fieldbyname('Money').AsFloat; FieldByName('HuiLv').Value:=1; FieldByName('BZType').Value:='人民币'; FieldByName('QtyUnit').Value:=Trim(ADO.fieldbyname('QtyUnit').AsString); FieldByName('ComTaiTou').Value:=Trim(cust); FieldByName('YFName').Value:='产品销售'; FieldByName('MainId').Value:=Trim(ADO.fieldbyname('CRNO').AsString); FieldByName('subID').Value:=Trim(ADO.fieldbyname('CRID').AsString); FieldByName('status').Value:='0'; Post; end; end else begin YFID:=Trim(ADOQueryTmp.fieldbyname('YFID').AsString); 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; function TfrmPBCKlistSel.YSData_Other(ADO:TADOQuery;fYFName:string;fmoney:double):Boolean; var CRID,YFID,Price,PriceUnit,OrderUnit,FComTaiTou,cust:String; begin Result:=False; with ADOQueryTmp do begin Close; SQL.Clear; sql.Add('select * from YF_Money_KC where FactoryName='''+Trim(ADO.fieldbyname('custName').asstring)+''' and YFDefFlag1=0 '); Open; end; if not ADOQueryTmp.IsEmpty then begin CRID:=ADOQueryTmp.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(ADO.fieldbyname('custName').asstring); FieldByName('ZdyStr1').Value:='应收收'; Post; end; end; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('delete from YF_Money_CR '); sql.Add(' where MainID='''+Trim(ADO.fieldbyname('CRNO').AsString)+''''); sql.Add(' and subID='''+Trim(ADO.fieldbyname('CRID').AsString)+''''); sql.Add(' and YFName='''+trim(fYFName)+''' '); execsql; end; with ADOQueryTmp do begin Close; sql.Clear; sql.Add('select * from YF_Money_CR '); sql.Add(' where MainID='''+Trim(ADO.fieldbyname('CRNO').AsString)+''''); sql.Add(' and subID='''+Trim(ADO.fieldbyname('CRID').AsString)+''''); sql.Add(' and YFName='''+trim(fYFName)+''' '); Open; end; if ADOQueryTmp.IsEmpty then begin if GetLSNo(ADOQueryCmd,YFID,'CS','YF_Money_CR',4,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(ADO.fieldbyname('CRNO').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(ADO.fieldbyname('custName').asstring); FieldByName('CRTime').Value:=Trim(FormatDateTime('yyyy-MM-dd',ADO.fieldbyname('CRTIme').AsDateTime)); FieldByName('YFType').Value:='自动生成'; FieldByName('Qty').Value:=1; FieldByName('Price').Value:=fmoney; FieldByName('Money').Value:=fmoney; FieldByName('BBMoney').Value:=fmoney; FieldByName('HuiLv').Value:=1; FieldByName('BZType').Value:='人民币'; FieldByName('QtyUnit').Value:='个'; FieldByName('ComTaiTou').Value:=Trim(cust); FieldByName('YFName').Value:=fYFName; FieldByName('MainId').Value:=Trim(ADO.fieldbyname('CRNO').AsString); FieldByName('subID').Value:=Trim(ADO.fieldbyname('CRID').AsString); FieldByName('status').Value:='0'; Post; end; end else begin YFID:=Trim(ADOQueryTmp.fieldbyname('YFID').AsString); 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 TfrmPBCKlistSel.InitGrid(); begin try with ADOQueryMain do begin close; sql.Clear; sql.Add('select A.* '); SQL.Add(' from CK_PB_CR A '); sql.Add('where CRTime>='''+formatdateTime('yyyy-MM-dd',begdate.Date)+''' '); sql.Add('and CRTime<'''+formatdateTime('yyyy-MM-dd',enddate.Date+1)+''' '); sql.Add('and CRType in (''销售出库'',''销售退回'') and A.valid=''Y'' and CKName=''坯布仓库'' '); IF cxTabControl1.TabIndex=0 then SQL.Add(' and not exists(select YFPZNO from YF_Money_CR_Sub X where X.YFPZNO=A.CRID ) ') else SQL.Add(' and exists(select YFPZNO from YF_Money_CR_Sub X where X.YFPZNO=A.CRID )'); sql.Add('order by A.CRNO,A.Code '); open; end; SCreateCDS20(ADOQueryMain,CDS_Main); SInitCDSData20(ADOQueryMain,CDS_Main); finally end; end; procedure TfrmPBCKlistSel.FormClose(Sender: TObject; var Action: TCloseAction); begin Action:=caHide; end; procedure TfrmPBCKlistSel.FormDestroy(Sender: TObject); begin frmPBCKlistSel:=nil; end; procedure TfrmPBCKlistSel.OrderNoChange(Sender: TObject); begin if ADOQuerymain.Active=False then Exit; SDofilter(ADOQuerymain,SGetFilters(Panel1,1,2)); SCreateCDS20(ADOQuerymain,CDS_Main); SInitCDSData20(ADOQuerymain,CDS_Main); end; procedure TfrmPBCKlistSel.FormShow(Sender: TObject); begin readCxGrid(self.Caption,Tv1,'面料仓库'); if trim(self.Caption)='坯布出库查询(纬编)' then begin canshu1:='查询'; end; SetStatus(); InitGrid(); end; procedure TfrmPBCKlistSel.FormCreate(Sender: TObject); begin EndDate.Date:=SGetServerDate10(ADOQueryTmp); BegDate.Date:=EndDate.Date-1; cxGrid1.Align:=alclient; end; procedure TfrmPBCKlistSel.TBCloseClick(Sender: TObject); begin writeCxGrid(self.Caption,Tv1,'面料仓库'); close; end; procedure TfrmPBCKlistSel.TBRafreshClick(Sender: TObject); begin initGrid(); end; procedure TfrmPBCKlistSel.v1Column6CompareRowValuesForCellMerging( Sender: TcxGridColumn; ARow1: TcxGridDataRow; AProperties1: TcxCustomEditProperties; const AValue1: Variant; ARow2: TcxGridDataRow; AProperties2: TcxCustomEditProperties; const AValue2: Variant; var AAreEqual: Boolean); var colIdx0,colIdx1:integer; begin colIdx0:= tv1.GetColumnByFieldName('CRNO').Index; if (ARow1.Values[colIdx0] = ARow2.Values[colIdx0]) then AAreEqual := True else AAreEqual := False; end; procedure TfrmPBCKlistSel.N1Click(Sender: TObject); begin SelOKNo(CDS_Main,True); end; procedure TfrmPBCKlistSel.N2Click(Sender: TObject); begin SelOKNo(CDS_Main,False); end; procedure TfrmPBCKlistSel.ToolButton1Click(Sender: TObject); begin if ADOQuerymain.Active=False then Exit; SDofilter(ADOQuerymain,SGetFilters(Panel1,1,2)); SCreateCDS20(ADOQuerymain,CDS_Main); SInitCDSData20(ADOQuerymain,CDS_Main); end; procedure TfrmPBCKlistSel.TBExportClick(Sender: TObject); begin if cxTabControl1.TabIndex<>0 then exit; ModalResult:=1; end; procedure TfrmPBCKlistSel.cxTabControl1Change(Sender: TObject); begin InitGrid(); end; end.