unit U_RCKCList; 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, BtnEdit; type TfrmRCKCList = class(TForm) ToolBar1: TToolBar; TBRafresh: TToolButton; TBFind: TToolButton; TBExport: TToolButton; TBClose: TToolButton; Panel1: TPanel; ADOQueryCmd: TADOQuery; ADOQueryMain: TADOQuery; ADOQueryTemp: TADOQuery; DataSource1: TDataSource; cxGridPopupMenu1: TcxGridPopupMenu; Label2: TLabel; BegDate: TDateTimePicker; EndDate: TDateTimePicker; CDS_Main: TClientDataSet; RM1: TRMGridReport; RMDBMain: TRMDBDataSet; RMXLSExport1: TRMXLSExport; RMDBHZ: TRMDBDataSet; CDS_HZ: TClientDataSet; CDS_PRT: TClientDataSet; PopupMenu1: TPopupMenu; N1: TMenuItem; N2: TMenuItem; Label4: TLabel; CheckBox1: TCheckBox; Panel4: TPanel; Label1: TLabel; Button1: TButton; Button2: TButton; YWNOTE: TEdit; cxGrid2: TcxGrid; TV1: TcxGridDBBandedTableView; V1Column1: TcxGridDBBandedColumn; V1Column2: TcxGridDBBandedColumn; V1Column4: TcxGridDBBandedColumn; V1Column9: TcxGridDBBandedColumn; V1Column12: TcxGridDBBandedColumn; V1Column15: TcxGridDBBandedColumn; V1Column3: TcxGridDBBandedColumn; V1Column10: TcxGridDBBandedColumn; V1Column11: TcxGridDBBandedColumn; V1Column13: TcxGridDBBandedColumn; V1Column14: TcxGridDBBandedColumn; V1Column21: TcxGridDBBandedColumn; TV1Column4: TcxGridDBBandedColumn; cxGridLevel1: TcxGridLevel; TV1Column1: TcxGridDBBandedColumn; cxStyleRepository1: TcxStyleRepository; cxStyle1: TcxStyle; cxStyleRepository2: TcxStyleRepository; cxStyle2: TcxStyle; TV1Column2: TcxGridDBBandedColumn; TV1Column3: TcxGridDBBandedColumn; FactoryName: TComboBox; Label10: TLabel; SPCODE: TEdit; 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 SPSpecChange(Sender: TObject); procedure FactoryNameChange(Sender: TObject); procedure SPCodeKeyPress(Sender: TObject; var Key: Char); procedure CRTypeChange(Sender: TObject); procedure CheckBox1Click(Sender: TObject); procedure ToolButton1Click(Sender: TObject); procedure Button2Click(Sender: TObject); procedure Button1Click(Sender: TObject); procedure TV1CustomDrawCell(Sender: TcxCustomGridTableView; ACanvas: TcxCanvas; AViewInfo: TcxGridTableDataCellViewInfo; var ADone: Boolean); procedure factoryNameBtnClick(Sender: TObject); procedure SPCODEChange(Sender: TObject); private canshu1, canshu2, canshu3: string; procedure InitGrid(); { Private declarations } public { Public declarations } end; var frmRCKCList: TfrmRCKCList; implementation uses U_DataLink, U_RTFun, U_SXCKInPut, U_ZdyAttachGYS; {$R *.dfm} procedure TfrmRCKCList.FormDestroy(Sender: TObject); begin frmRCKCList := nil; end; procedure TfrmRCKCList.FormClose(Sender: TObject; var Action: TCloseAction); begin Action := caFree; end; procedure TfrmRCKCList.FormCreate(Sender: TObject); begin //cxGrid1.Align:=alClient; EndDate.DateTime := SGetServerDate10(ADOQueryTemp); BegDate.DateTime := EndDate.DateTime; canshu1 := Trim(DParameters1); canshu2 := Trim(DParameters2); canshu3 := Trim(DParameters3); end; procedure TfrmRCKCList.InitGrid(); var pwhere: string; begin // if trim(factoryName.Text) = '' then // begin // application.MessageBox('请输入客户,以便提高查询速度!', '提示信息', MB_ICONERROR); // exit; // end; try ADOQueryMain.DisableControls; with ADOQueryMain do begin Filtered := False; Close; sql.Clear; sql.Add(' exec P_View_RCKCB '); if CheckBox1.Checked = True then begin sql.Add(' @begdate=' + quotedstr(Trim(FormatDateTime('yyyy-MM-dd', begdate.DateTime)))); sql.Add(',@Enddate=' + quotedstr(Trim(FormatDateTime('yyyy-MM-dd', Enddate.DateTime + 1)))); end else begin sql.Add(' @begdate=''2000-01-01'''); sql.Add(',@Enddate=''2099-12-12'''); end; sql.Add(',@factoryName=' + quotedstr(Trim(factoryName.Text))); Open; //ShowMessage(SQL.Text); end; SCreateCDS20(ADOQueryMain, CDS_Main); SInitCDSData20(ADOQueryMain, CDS_Main); finally ADOQueryMain.EnableControls; end; end; procedure TfrmRCKCList.TBRafreshClick(Sender: TObject); begin BegDate.SetFocus; InitGrid(); end; procedure TfrmRCKCList.ConNoMChange(Sender: TObject); begin if ADOQueryMain.Active then begin SDofilter(ADOQueryMain, SGetFilters(Panel1, 1, 2)); end; end; procedure TfrmRCKCList.TBCloseClick(Sender: TObject); begin WriteCxBandedGrid('坯布入库列表', Tv1, '染厂库存表'); Close; end; procedure TfrmRCKCList.FormShow(Sender: TObject); var fsj: string; begin ReadCxBandedGrid('坯布入库列表', Tv1, '染厂库存表'); fsj := ' select distinct name= FactoryName from ( select distinct FactoryName=ToFactoryName from CK_SXPB_CR A where A.CRType<>''销售出库'' and A.CRFlag=''出库'' and ckname=''坯布'' '; fsj := fsj + ' union all select distinct FactoryName from CK_SXPB_CR A where A.crtype in (''加工完成'',''回修完成'') and ckname=''待检布'''; fsj := fsj + ' union all select distinct CustomerNoName from FHSQ_Main A where CRType=''回修出库'' and fhpshz>0 ) aa order by FactoryName'; SInitComBoxBySql(ADOQueryCmd, FactoryName, False, fsj); //InitGrid(); end; procedure TfrmRCKCList.TBExportClick(Sender: TObject); begin if ADOQueryMain.IsEmpty then exit; TcxGridToExcel('坯布入库列表', cxGrid2); end; procedure TfrmRCKCList.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 TfrmRCKCList.N1Click(Sender: TObject); begin SelOKNo(CDS_Main, True); end; procedure TfrmRCKCList.N2Click(Sender: TObject); begin SelOKNo(CDS_Main, False); end; procedure TfrmRCKCList.TBDelClick(Sender: TObject); begin if CDS_Main.IsEmpty then Exit; if trim(CDS_Main.FieldByName('Filler').AsString) <> Trim(DName) then begin Application.MessageBox('不能操作他人数据!', '提示', 0); Exit; end; 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; 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) + ''''); ExecSQL; end; ADOQueryCmd.Connection.CommitTrans; CDS_Main.Delete; except ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('删除异常!', '提示', 0); end; end else begin CDS_Main.Delete; end; end; procedure TfrmRCKCList.TBAddClick(Sender: TObject); begin try frmSXCKInPut := TfrmSXCKInPut.Create(Application); with frmSXCKInPut do begin FBCId := ''; frmSXCKInPut.canshu3 := Trim(Self.canshu3); if ShowModal = 1 then begin Self.InitGrid(); end; end; finally frmSXCKInPut.Free; end; end; procedure TfrmRCKCList.TBEditClick(Sender: TObject); begin if CDS_Main.IsEmpty then Exit; // if trim(CDS_Main.FieldByName('Filler').AsString) <> Trim(DName) then // begin // Application.MessageBox('不能操作他人数据!', '提示', 0); // Exit; // end; if Trim(CDS_Main.fieldbyname('CRType').AsString) = '平移入库' then begin Application.MessageBox('平移入库的数据为自动生成,不能修改!', '提示', 0); Exit; end; try frmSXCKInPut := TfrmSXCKInPut.Create(Application); with frmSXCKInPut do begin if Trim(CDS_Main.fieldbyname('filler').AsString) <> Trim(DName) then begin fzdr := '1'; end; FBCId := Trim(CDS_Main.fieldbyname('SPID').AsString); TBDel.Visible := False; TBAdd.Visible := False; if ShowModal = 1 then begin Self.InitGrid(); end; end; finally frmSXCKInPut.Free; end; end; procedure TfrmRCKCList.SPIDKeyPress(Sender: TObject; var Key: Char); begin if Key = #13 then begin InitGrid(); end; end; procedure TfrmRCKCList.SPSpecChange(Sender: TObject); begin TBFind.Click; end; procedure TfrmRCKCList.FactoryNameChange(Sender: TObject); begin TBRafresh.Click; end; procedure TfrmRCKCList.SPCodeKeyPress(Sender: TObject; var Key: Char); begin if Key = #13 then begin InitGrid(); end; end; procedure TfrmRCKCList.CRTypeChange(Sender: TObject); begin InitGrid(); end; procedure TfrmRCKCList.CheckBox1Click(Sender: TObject); begin InitGrid(); end; procedure TfrmRCKCList.ToolButton1Click(Sender: TObject); begin Panel4.Visible := true; end; procedure TfrmRCKCList.Button2Click(Sender: TObject); begin Panel4.Visible := False; end; procedure TfrmRCKCList.Button1Click(Sender: TObject); begin if Application.MessageBox('修改编号会同时修改出库编号,确定吗?', '提示', 32 + 4) <> IDYES then Exit; if trim(YWNOTE.Text) = '' then begin Application.MessageBox('编号不能为空!', '提示', 0); Exit; end; try CDS_Main.DisableControls; ADOQueryCmd.Connection.BeginTrans; with CDS_Main do begin with ADOQueryCmd do begin Close; sql.Clear; sql.Add('Update CK_SXPB_CR Set spcode=''' + trim(YWNOTE.Text) + ''' '); sql.Add('where FZSPID=''' + Trim(CDS_Main.fieldbyname('spid').AsString) + ''''); ExecSQL; end; end; ADOQueryCmd.Connection.CommitTrans; CDS_Main.EnableControls; application.MessageBox('数据保存成功!', '提示信息'); Panel4.Visible := false; TBRafresh.Click; exit; except ADOQueryCmd.Connection.RollbackTrans; CDS_Main.EnableControls; application.MessageBox('数据保存失败!', '提示信息', 0); end; end; procedure TfrmRCKCList.TV1CustomDrawCell(Sender: TcxCustomGridTableView; ACanvas: TcxCanvas; AViewInfo: TcxGridTableDataCellViewInfo; var ADone: Boolean); begin // if (AViewInfo.GridRecord.Values[TcxGridDBTableView(Sender).GetColumnByFieldName('keyNO').Index]) mod 2 = 0 then // begin // ACanvas.Brush.Color := $EEF5FF; // end // else // begin // ACanvas.Brush.Color := $FFF8F0; // end; end; procedure TfrmRCKCList.factoryNameBtnClick(Sender: TObject); begin try frmZdyAttachGYS := TfrmZdyAttachGYS.Create(Application); with frmZdyAttachGYS do begin if ShowModal = 1 then begin FactoryName.Text := Trim(CDS_HZ.fieldbyname('CoName').AsString); InitGrid(); end; end; finally frmZdyAttachGYS.Free; end; end; procedure TfrmRCKCList.SPCODEChange(Sender: TObject); begin TBFind.Click(); end; end.