unit U_KCList_Sel; 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, MovePanel, Math, Clipbrd, cxLookAndFeels, cxLookAndFeelPainters, cxNavigator, cxTextEdit, dxDateRanges, dxBarBuiltInMenu, U_BaseList, cxPC, System.StrUtils, cxContainer, dxCore, cxDateUtils, cxMaskEdit, dxScrollbarAnnotations, cxButtonEdit, U_BaseHelp, System.ImageList, Vcl.ImgList; type TfrmKCList_Sel = class(TfrmBaseHelp) ToolBar1: TToolBar; TBRafresh: TToolButton; TBExport: TToolButton; TBClose: TToolButton; ADOQueryCmd: TADOQuery; ADOQueryMain: TADOQuery; ADOQueryTemp: TADOQuery; DS_1: TDataSource; GPM_1: TcxGridPopupMenu; CDS_1: TClientDataSet; TBRKCX: TToolButton; ToolButton2: TToolButton; ToolButton4: TToolButton; PM_1: TPopupMenu; PM11: TMenuItem; ToolButton1: TToolButton; N1: TMenuItem; cxPageControl1: TcxPageControl; cxTabSheet1: TcxTabSheet; cxTabSheet2: TcxTabSheet; Panel6: TPanel; Label31: TLabel; LBCPAP: TLabel; BTLP: TButton; BTNP: TButton; TCBNOR: TComboBox; Pnl_F1: TPanel; Label2: TLabel; begtime: TDateTimePicker; endTime: TDateTimePicker; Pnl_F2: TPanel; Label1: TLabel; DateTimePicker3: TDateTimePicker; DateTimePicker4: TDateTimePicker; GPM_2: TcxGridPopupMenu; CDS_2: TClientDataSet; DS_2: TDataSource; PM_2: TPopupMenu; MenuItem3: TMenuItem; BegDate2: TcxDateEdit; EndDate2: TcxDateEdit; chk_F2: TcxCheckBox; chk_F1: TcxCheckBox; BegDate: TcxDateEdit; EndDate: TcxDateEdit; cxGrid2: TcxGrid; Tv2: TcxGridDBTableView; cxGridDBColumn2: TcxGridDBColumn; v1Column2: TcxGridDBColumn; cxGridDBColumn3: TcxGridDBColumn; cxGridDBColumn4: TcxGridDBColumn; cxGridDBColumn15: TcxGridDBColumn; cxGridDBColumn5: TcxGridDBColumn; cxGridDBColumn6: TcxGridDBColumn; cxGridDBColumn7: TcxGridDBColumn; cxGridDBColumn8: TcxGridDBColumn; cxGridDBColumn9: TcxGridDBColumn; cxGridDBColumn10: TcxGridDBColumn; cxGridDBColumn11: TcxGridDBColumn; cxGridDBColumn12: TcxGridDBColumn; cxGridDBColumn13: TcxGridDBColumn; cxGridDBColumn14: TcxGridDBColumn; cxGridDBColumn16: TcxGridDBColumn; v1Column20: TcxGridDBColumn; cxGridDBColumn17: TcxGridDBColumn; cxGridDBColumn18: TcxGridDBColumn; cxGridDBColumn19: TcxGridDBColumn; cxGridDBColumn20: TcxGridDBColumn; cxGridDBColumn21: TcxGridDBColumn; cxGridDBColumn22: TcxGridDBColumn; cxGridLevel1: TcxGridLevel; Label4: TLabel; Label6: TLabel; Label9: TLabel; Label12: TLabel; Label16: TLabel; Label17: TLabel; Y_name: TcxTextEdit; FromCoName: TcxTextEdit; StkCoName: TcxTextEdit; Y_Spec: TcxComboBox; cxTextEdit1: TcxTextEdit; Yarn_Name: TcxTextEdit; cxGrid1: TcxGrid; Tv1: TcxGridDBTableView; cxGridDBColumn1: TcxGridDBColumn; cxGridDBColumn23: TcxGridDBColumn; cxGridDBColumn24: TcxGridDBColumn; cxGridDBColumn25: TcxGridDBColumn; cxGridDBColumn26: TcxGridDBColumn; cxGridDBColumn27: TcxGridDBColumn; cxGridDBColumn28: TcxGridDBColumn; cxGridDBColumn29: TcxGridDBColumn; cxGridDBColumn30: TcxGridDBColumn; cxGridDBColumn31: TcxGridDBColumn; cxGridDBColumn32: TcxGridDBColumn; cxGridDBColumn33: TcxGridDBColumn; cxGridDBColumn34: TcxGridDBColumn; cxGridDBColumn35: TcxGridDBColumn; cxGridDBColumn36: TcxGridDBColumn; cxGridDBColumn37: TcxGridDBColumn; cxGridDBColumn38: TcxGridDBColumn; cxGridDBColumn39: TcxGridDBColumn; cxGridDBColumn40: TcxGridDBColumn; cxGridDBColumn41: TcxGridDBColumn; cxGridDBColumn42: TcxGridDBColumn; cxGridDBColumn43: TcxGridDBColumn; cxGridDBColumn44: TcxGridDBColumn; cxGridLevel2: TcxGridLevel; Tv1Column1: TcxGridDBColumn; Tv1Column2: TcxGridDBColumn; Tv1Column3: TcxGridDBColumn; Label3: TLabel; Label5: TLabel; Label7: TLabel; Label10: TLabel; Label19: TLabel; Label20: TLabel; cxTextEdit2: TcxTextEdit; cxTextEdit3: TcxTextEdit; cxTextEdit5: TcxTextEdit; cxComboBox1: TcxComboBox; cxTextEdit8: TcxTextEdit; cxTextEdit9: TcxTextEdit; cxTabSheet3: TcxTabSheet; Panel1: TPanel; Label21: TLabel; Label22: TLabel; Button1: TButton; Button2: TButton; ComboBox1: TComboBox; Pnl_F3: TPanel; Label23: TLabel; Label24: TLabel; Label25: TLabel; Label26: TLabel; Label28: TLabel; Label32: TLabel; Label33: TLabel; DateTimePicker1: TDateTimePicker; DateTimePicker2: TDateTimePicker; cxCheckBox1: TcxCheckBox; cxDateEdit1: TcxDateEdit; cxDateEdit2: TcxDateEdit; cxTextEdit10: TcxTextEdit; cxTextEdit11: TcxTextEdit; cxTextEdit13: TcxTextEdit; cxComboBox2: TcxComboBox; cxTextEdit16: TcxTextEdit; cxTextEdit17: TcxTextEdit; cxGrid3: TcxGrid; Tv3: TcxGridDBTableView; cxGridDBColumn45: TcxGridDBColumn; cxGridDBColumn46: TcxGridDBColumn; cxGridDBColumn47: TcxGridDBColumn; cxGridDBColumn48: TcxGridDBColumn; cxGridDBColumn49: TcxGridDBColumn; cxGridDBColumn50: TcxGridDBColumn; cxGridDBColumn51: TcxGridDBColumn; cxGridDBColumn52: TcxGridDBColumn; cxGridDBColumn53: TcxGridDBColumn; cxGridDBColumn54: TcxGridDBColumn; cxGridDBColumn55: TcxGridDBColumn; cxGridDBColumn56: TcxGridDBColumn; cxGridDBColumn57: TcxGridDBColumn; cxGridDBColumn58: TcxGridDBColumn; cxGridDBColumn59: TcxGridDBColumn; cxGridDBColumn60: TcxGridDBColumn; cxGridDBColumn61: TcxGridDBColumn; cxGridDBColumn62: TcxGridDBColumn; cxGridDBColumn63: TcxGridDBColumn; cxGridDBColumn64: TcxGridDBColumn; cxGridDBColumn65: TcxGridDBColumn; cxGridDBColumn66: TcxGridDBColumn; cxGridDBColumn67: TcxGridDBColumn; cxGridDBColumn68: TcxGridDBColumn; cxGridDBColumn69: TcxGridDBColumn; cxGridLevel3: TcxGridLevel; DS_3: TDataSource; CDS_3: TClientDataSet; Tv3Column1: TcxGridDBColumn; Tv3Column2: TcxGridDBColumn; Tv3Column3: TcxGridDBColumn; Tv1Column4: TcxGridDBColumn; Label34: TLabel; Label35: TLabel; BYIOID: TcxTextEdit; FromPurNo: TcxTextEdit; Label36: TLabel; StkPosition: TcxTextEdit; Label37: TLabel; Label38: TLabel; cxTextEdit18: TcxTextEdit; cxTextEdit19: TcxTextEdit; Tv2Column1: TcxGridDBColumn; Tv2Column2: TcxGridDBColumn; Label8: TLabel; BanID: TcxTextEdit; Label11: TLabel; cxTextEdit4: TcxTextEdit; Label13: TLabel; cxTextEdit6: TcxTextEdit; Label14: TLabel; MXID: TcxTextEdit; GPM_3: TcxGridPopupMenu; ToolButton3: TToolButton; Tv2Column3: TcxGridDBColumn; Tv1Column5: TcxGridDBColumn; Tv3Column4: TcxGridDBColumn; Tv2Column4: TcxGridDBColumn; N2: TMenuItem; PM_3: TPopupMenu; MenuItem1: TMenuItem; MenuItem2: TMenuItem; Tv2Column5: TcxGridDBColumn; Tv1Column6: TcxGridDBColumn; Tv3Column5: TcxGridDBColumn; Tv3Column6: TcxGridDBColumn; Tv3Column7: TcxGridDBColumn; procedure FormClose(Sender: TObject; var Action: TCloseAction); procedure FormCreate(Sender: TObject); procedure TBRafreshClick(Sender: TObject); procedure TBCloseClick(Sender: TObject); procedure FormShow(Sender: TObject); procedure TBExportClick(Sender: TObject); procedure orderNoKeyPress(Sender: TObject; var Key: Char); procedure TBRKCXClick(Sender: TObject); procedure BTNPClick(Sender: TObject); procedure BTLPClick(Sender: TObject); procedure TCBNORChange(Sender: TObject); procedure JYTypeChange(Sender: TObject); procedure ToolButton2Click(Sender: TObject); procedure cxPageControl1Change(Sender: TObject); procedure CDS_1BeforeOpen(DataSet: TDataSet); procedure Tv1DataControllerFilterBeforeChange(Sender: TcxDBDataFilterCriteria; ADataSet: TDataSet; const AFilterText: string); procedure Tv1TcxGridDBDataControllerTcxDataSummaryFooterSummaryItems6GetText(Sender: TcxDataSummaryItem; const AValue: Variant; AIsFooter: Boolean; var AText: string); procedure ToolButton4Click(Sender: TObject); procedure ToolButton1Click(Sender: TObject); procedure PM11Click(Sender: TObject); procedure N1Click(Sender: TObject); procedure N2Click(Sender: TObject); procedure TV2CellDblClick(Sender: TcxCustomGridTableView; ACellViewInfo: TcxGridTableDataCellViewInfo; AButton: TMouseButton; AShift: TShiftState; var AHandled: Boolean); procedure MenuItem3Click(Sender: TObject); procedure TV2CustomDrawCell(Sender: TcxCustomGridTableView; ACanvas: TcxCanvas; AViewInfo: TcxGridTableDataCellViewInfo; var ADone: Boolean); procedure FromCoNamePropertiesChange(Sender: TObject); procedure Tv1CellDblClick(Sender: TcxCustomGridTableView; ACellViewInfo: TcxGridTableDataCellViewInfo; AButton: TMouseButton; AShift: TShiftState; var AHandled: Boolean); procedure FormDestroy(Sender: TObject); procedure ToolButton3Click(Sender: TObject); procedure MenuItem1Click(Sender: TObject); procedure MenuItem2Click(Sender: TObject); private CurrentPage, RecordsNumber: Integer; lstCust: TStringList; procedure InitGrid(WSql: string); procedure InitPage(); procedure SetStatus(); { Private declarations } public canshu1, canshu2, FWorkshop, FMXID: string; FFBYIOID, FFBanID, FFMXID, FFStkID, FFOutNo: string; FFQty: Integer; { Public declarations } end; var frmKCList_Sel: TfrmKCList_Sel; implementation uses U_DataLink, U_RTFun, U_LabelPrint; {$R *.dfm} procedure TfrmKCList_Sel.InitPage(); begin CurrentPage := 1; case cxPageControl1.ActivePageIndex of 0: begin InitGrid(SGetHintFilters(Pnl_F2, 1, 2)); end; 1: begin InitGrid(SGetHintFilters(Pnl_F1, 1, 2)); end; 2: begin InitGrid(SGetHintFilters(Pnl_F3, 1, 2)); end; end; end; procedure TfrmKCList_Sel.SetStatus(); begin case cxPageControl1.ActivePageIndex of 0: begin end; 1: begin end; end; end; procedure TfrmKCList_Sel.FormClose(Sender: TObject; var Action: TCloseAction); begin inherited; FreeAndNil(lstCust); Action := caFree; end; procedure TfrmKCList_Sel.FormCreate(Sender: TObject); begin inherited; lstCust := TStringList.Create; EndDate.Date := SGetServerDateTime(ADOQueryTemp); BegDate.Date := EndDate.Date - 20; BegDate2.Date := BegDate.Date; EndDate2.Date := EndDate.Date; end; procedure TfrmKCList_Sel.FormDestroy(Sender: TObject); begin inherited; frmKCList_Sel := nil; end; procedure TfrmKCList_Sel.InitGrid(WSql: string); begin if Trim(WSql) <> '' then WSql := ' and ' + WSql; case cxPageControl1.ActivePageIndex of 0: begin with ADOQueryMain do begin Close; sql.Clear; sql.Add(' select BS= ceiling(1.00*StkPiece/BBBS) '); sql.Add(' ,*,GS=(select Count(*) from BS_Yarn_IO_MX X where A.BYIOID =X.BYIOID and X.IOFlag =''已入库'')'); sql.Add(' from BS_Yarn_IO A '); SQL.Add(' where A.IOFlag=''入库'' and isnull(StkQty,0)>0 '); sql.Add(' and isnull(stkName,'''')=''' + Trim('纱线') + ''''); if trim(FFOutNo) <> '' then begin SQL.Add('and EXISTS (select * from Tat_Cloth_DR_Sub X where X.DRMID =''' + trim(FFOutNo) + ''''); SQL.Add('and isnull(X.Y_Code,'''') = isnull(A.Y_Code,'''') '); SQL.Add('and isnull(X.Yarn_Name,'''') = isnull(A.Yarn_Name,'''') '); SQL.Add('and isnull(X.Y_name,'''') = isnull(A.Y_name,'''') '); SQL.Add('and isnull(X.Y_Spec,'''') = isnull(A.Y_Spec,'''') '); SQL.Add('and isnull(X.Denier,0) = isnull(A.Denier,0) '); SQL.Add('and isnull(X.Z_Number,0) = isnull(A.Z_Number,0) '); SQL.Add('and isnull(X.F_Number,0) = isnull(A.F_Number,0)) '); // SQL.Add('and isnull(X.Y_Type,'''') = isnull(A.Y_Type,'''') '); end; sql.Add(WSql); Open; end; SCreateCDS(ADOQueryMain, CDS_2); SInitCDSData(ADOQueryMain, CDS_2); end; 1: begin with ADOQueryMain do begin Close; sql.Clear; sql.Add(' select AA.* from (select B.BanID,B.BanNo,B.StkPosition,B.GS,A.*'); sql.Add(' from BS_Yarn_IO A '); sql.Add(' inner join BS_Yarn_IO_Ban B on A.BYIOID =B.BYIOID '); SQL.Add(' where A.IOFlag=''入库'' and isnull(A.StkQty,0)>0 and B.IOFlag =''已入库'' '); sql.Add(' and isnull(A.stkName,'''')=''' + Trim('纱线') + ''''); if trim(FFOutNo) <> '' then begin SQL.Add('and EXISTS (select * from Tat_Cloth_DR_Sub X where X.DRMID =''' + trim(FFOutNo) + ''''); SQL.Add('and isnull(X.Y_Code,'''') = isnull(A.Y_Code,'''') '); SQL.Add('and isnull(X.Yarn_Name,'''') = isnull(A.Yarn_Name,'''') '); SQL.Add('and isnull(X.Y_name,'''') = isnull(A.Y_name,'''') '); SQL.Add('and isnull(X.Y_Spec,'''') = isnull(A.Y_Spec,'''') '); SQL.Add('and isnull(X.Denier,0) = isnull(A.Denier,0) '); SQL.Add('and isnull(X.Z_Number,0) = isnull(A.Z_Number,0) '); SQL.Add('and isnull(X.F_Number,0) = isnull(A.F_Number,0)) '); // SQL.Add('and isnull(X.Y_Type,'''') = isnull(A.Y_Type,'''')) '); end; sql.Add(' )AA where 1=1'); sql.Add(WSql); sql.Add('Order by BYIOID,BanNo '); Open; end; SCreateCDS(ADOQueryMain, CDS_1); SInitCDSData(ADOQueryMain, CDS_1); end; 2: begin with ADOQueryMain do begin Close; sql.Clear; sql.Add(' select KeShu=KeShu2,KeKG=KeKG2,AA.* from (select KeShu2=B.KeShu,KeKG2=B.KeKG,B.MXID,B.BaoNo,B.StkPosition,B.BanNo,B.BanID,B.BaoQty,A.*'); sql.Add(' from BS_Yarn_IO A '); sql.Add(' inner join BS_Yarn_IO_MX B on A.BYIOID =B.BYIOID '); SQL.Add(' where A.IOFlag=''入库'' and isnull(A.StkQty,0)>0 and B.IOFlag =''已入库'' '); sql.Add(' and isnull(A.stkName,'''')=''' + Trim('纱线') + ''''); SQL.Add('and EXISTS (select * from Tat_Cloth_DR_Sub X where X.DRMID =''' + trim(FFOutNo) + ''''); SQL.Add('and isnull(X.Y_Code,'''') = isnull(A.Y_Code,'''') '); SQL.Add('and isnull(X.Yarn_Name,'''') = isnull(A.Yarn_Name,'''') '); SQL.Add('and isnull(X.Y_name,'''') = isnull(A.Y_name,'''') '); SQL.Add('and isnull(X.Y_Spec,'''') = isnull(A.Y_Spec,'''') '); SQL.Add('and isnull(X.Denier,0) = isnull(A.Denier,0) '); SQL.Add('and isnull(X.Z_Number,0) = isnull(A.Z_Number,0) '); SQL.Add('and isnull(X.F_Number,0) = isnull(A.F_Number,0)) '); // SQL.Add('and isnull(X.Y_Type,'''') = isnull(A.Y_Type,'''')) '); sql.Add(' )AA where 1=1'); sql.Add(WSql); sql.Add(' Order by BYIOID,BanNo,BaoNo '); // showmessage(Sql.text); Open; end; SCreateCDS(ADOQueryMain, CDS_3); SInitCDSData(ADOQueryMain, CDS_3); end; end; end; procedure TfrmKCList_Sel.TBRafreshClick(Sender: TObject); begin CurrentPage := 1; InitPage(); end; procedure TfrmKCList_Sel.CDS_1BeforeOpen(DataSet: TDataSet); begin lstCust.Clear; end; procedure TfrmKCList_Sel.cxPageControl1Change(Sender: TObject); begin SetStatus(); end; procedure TfrmKCList_Sel.TBCloseClick(Sender: TObject); begin Close; end; procedure TfrmKCList_Sel.FormShow(Sender: TObject); begin inherited; canshu1 := '管理'; canshu2 := '纱线'; ReadCxGrid(trim(self.Caption) + 'Tv1', Tv1, '梭织坯布仓库'); ReadCxGrid(trim(self.Caption) + 'Tv2', Tv2, '梭织坯布仓库'); CurrentPage := 1; RecordsNumber := 500; SetStatus(); InitPage(); end; procedure TfrmKCList_Sel.FromCoNamePropertiesChange(Sender: TObject); begin TBRafresh.Click; end; procedure TfrmKCList_Sel.TBExportClick(Sender: TObject); begin if ADOQueryMain.IsEmpty then exit; TcxGridToExcel(Self.Caption, cxGrid1); end; procedure TfrmKCList_Sel.orderNoKeyPress(Sender: TObject; var Key: Char); begin if Key = #13 then begin CurrentPage := 1; InitPage(); end; end; procedure TfrmKCList_Sel.PM11Click(Sender: TObject); begin SelOKNo(CDS_1, true); end; procedure TfrmKCList_Sel.TBRKCXClick(Sender: TObject); var MCIIDS, MIOIDS, MSTKIDS, MPCIDS: string; begin if CDS_1.IsEmpty then Exit; if not CDS_1.Locate('SSel', True, []) then begin Application.MessageBox('没有选择数据!', '提示', 0); Exit; end; MCIIDS := ''; MIOIDS := ''; MSTKIDS := ''; MPCIDS := ''; CDS_1.DisableControls; with CDS_1 do begin First; while not Eof do begin if CDS_1.fieldbyname('SSel').AsBoolean then begin MCIIDS := MCIIDS + (Trim(CDS_1.fieldbyname('CIID').AsString)) + ','; MIOIDS := MIOIDS + (Trim(CDS_1.fieldbyname('IOID').AsString)) + ','; MSTKIDS := MSTKIDS + (Trim(CDS_1.fieldbyname('STKID').AsString)) + ','; MPCIDS := MPCIDS + (Trim(CDS_1.fieldbyname('PCID').AsString)) + ','; end; Next; end; end; MCIIDS := leftBstr(trim(MCIIDS), length(MCIIDS) - 1); MIOIDS := leftBstr(trim(MIOIDS), length(MIOIDS) - 1); MSTKIDS := leftBstr(trim(MSTKIDS), length(MSTKIDS) - 1); CDS_1.Locate('SSel', True, []); CDS_1.EnableControls; if Application.MessageBox('确定要执行操作吗?', '提示', 32 + 4) <> IDYES then Exit; try ADOQueryCmd.Connection.BeginTrans; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('insert into Tat_Need_Up(UType,UDataId,UOperation,UOperator,UModule,UDetails) '); sql.Add('values(''梭织坯布入库'' '); sql.Add(',' + quotedstr(MPCIDS)); sql.Add(',''撤销入库'' '); sql.Add(',' + quotedstr(DName)); sql.Add(',' + quotedstr(trim(self.Caption))); sql.Add(',' + quotedstr(MSTKIDS)); sql.Add(') '); execsql; end; with ADOQueryCmd do begin Close; Sql.Clear; Sql.Add('exec P_Tat_Cloth_ReIn '); Sql.Add('@StkIds=' + quotedstr(trim(MSTKIDS))); Sql.Add(',@IOIDS=' + quotedstr(trim(MIOIDS))); Sql.Add(',@FillId=' + Quotedstr(DCode)); Sql.Add(',@Filler=' + Quotedstr(DName)); Open; end; if ADOQueryCmd.FieldByName('intReturn').AsInteger = -1 then begin raise Exception.Create(pchar(trim(ADOQueryCmd.FieldByName('ShowMsg').AsString))); end; ADOQueryCmd.Connection.CommitTrans; // with ADOQueryCmd do // begin // Close; // sql.Clear; // sql.Add('exec P_Tat_Card_PSC '); // execsql; // end; InitPage(); except ADOQueryCmd.Connection.RollbackTrans; application.MessageBox(PChar(Exception(ExceptObject).Message), '提示信息', 0); end; end; procedure TfrmKCList_Sel.Tv1CellDblClick(Sender: TcxCustomGridTableView; ACellViewInfo: TcxGridTableDataCellViewInfo; AButton: TMouseButton; AShift: TShiftState; var AHandled: Boolean); begin cxPageControl1.ActivePageIndex := 2; SetStatus(); InitGrid(SGetCDSFilters(Tv1, CDS_1)); end; procedure TfrmKCList_Sel.Tv1DataControllerFilterBeforeChange(Sender: TcxDBDataFilterCriteria; ADataSet: TDataSet; const AFilterText: string); begin lstCust.Clear; end; procedure TfrmKCList_Sel.Tv1TcxGridDBDataControllerTcxDataSummaryFooterSummaryItems6GetText(Sender: TcxDataSummaryItem; const AValue: Variant; AIsFooter: Boolean; var AText: string); begin if lstCust <> nil then AText := IntToStr(lstCust.Count); end; procedure TfrmKCList_Sel.TV2CellDblClick(Sender: TcxCustomGridTableView; ACellViewInfo: TcxGridTableDataCellViewInfo; AButton: TMouseButton; AShift: TShiftState; var AHandled: Boolean); begin BegDate.Date := BegDate2.Date; EndDate.Date := EndDate2.Date; chk_F2.Checked := chk_F1.Checked; cxPageControl1.ActivePageIndex := 1; SetStatus(); InitGrid(SGetCDSFilters(Tv2, CDS_2)); end; procedure TfrmKCList_Sel.TV2CustomDrawCell(Sender: TcxCustomGridTableView; ACanvas: TcxCanvas; AViewInfo: TcxGridTableDataCellViewInfo; var ADone: Boolean); begin // if AViewInfo.GridRecord.Values[TcxGridDBTableView(Sender).GetColumnByFieldName('sh').Index] <> null then // if AViewInfo.GridRecord.Values[TcxGridDBTableView(Sender).GetColumnByFieldName('sh').Index] > 8 then // ACanvas.Brush.Color := $B3DEF5; end; procedure TfrmKCList_Sel.BTNPClick(Sender: TObject); begin if CurrentPage < CDS_1.FieldByName('TotalCount').AsInteger / RecordsNumber then CurrentPage := CurrentPage + 1; InitGrid(SGetHintFilters(Pnl_F1, 1, 2)); end; procedure TfrmKCList_Sel.BTLPClick(Sender: TObject); begin if CurrentPage > 1 then CurrentPage := CurrentPage - 1; InitGrid(SGetHintFilters(Pnl_F1, 1, 2)); end; procedure TfrmKCList_Sel.TCBNORChange(Sender: TObject); begin RecordsNumber := StrToInt(TCBNOR.Text); CurrentPage := 1; InitGrid(SGetHintFilters(Pnl_F1, 1, 2)); end; procedure TfrmKCList_Sel.JYTypeChange(Sender: TObject); begin CurrentPage := 1; InitPage(); end; procedure TfrmKCList_Sel.MenuItem1Click(Sender: TObject); begin SelOKNo(CDS_3, true); end; procedure TfrmKCList_Sel.MenuItem2Click(Sender: TObject); begin SelOKNo(CDS_3, false); end; procedure TfrmKCList_Sel.MenuItem3Click(Sender: TObject); begin SelOKNo(CDS_2, True); end; procedure TfrmKCList_Sel.N1Click(Sender: TObject); begin SelOKNo(CDS_1, false); end; procedure TfrmKCList_Sel.N2Click(Sender: TObject); begin SelOKNo(CDS_2, False); end; procedure TfrmKCList_Sel.ToolButton1Click(Sender: TObject); begin if CDS_1.IsEmpty then Exit; try frmLabelPrint := TfrmLabelPrint.Create(Application); with frmLabelPrint do begin FLMType := 'TatClothIn1'; FFiltration1 := Trim(self.CDS_1.fieldbyname('IONO').AsString); if ShowModal = 1 then begin end; end; finally frmLabelPrint.Free; end; end; procedure TfrmKCList_Sel.ToolButton2Click(Sender: TObject); var WSql: string; begin if CDS_1.IsEmpty then Exit; if not CDS_1.Locate('SSel', True, []) then begin Application.MessageBox('没有选择数据!', '提示', 0); Exit; end; WSql := ''; CDS_1.DisableControls; with CDS_1 do begin First; while not Eof do begin if CDS_1.fieldbyname('SSel').AsBoolean then begin if WSql <> '' then begin WSql := WSql + ',' + QuotedStr(Trim(CDS_1.fieldbyname('CIID').AsString)); end else begin WSql := QuotedStr(Trim(CDS_1.fieldbyname('CIID').AsString)); end; end; Next; end; end; CDS_1.Locate('SSel', True, []); CDS_1.EnableControls; try frmLabelPrint := TfrmLabelPrint.Create(Application); with frmLabelPrint do begin FLMType := 'TatClothIn2'; FFiltration1 := WSql; if ShowModal = 1 then begin end; end; finally frmLabelPrint.Free; end; end; procedure TfrmKCList_Sel.ToolButton3Click(Sender: TObject); begin FFBYIOID := ''; FFBanID := ''; FFMXID := ''; FFStkID := ''; if frmKCList_Sel.cxPageControl1.ActivePageIndex = 0 then begin with CDS_2 do begin First; while not Eof do begin if CDS_2.fieldbyname('SSel').AsBoolean then begin FFBYIOID := FFBYIOID + (Trim(CDS_2.fieldbyname('BYIOID').AsString)) + ','; end; Next; end; end; FFBYIOID := leftBstr(trim(FFBYIOID), length(FFBYIOID) - 1); with ADOQueryCmd do begin Close; Sql.Clear; Sql.Add(' select count(*) AS GS,StkID =Max(A.BYIOID) from BS_Yarn_IO A'); sql.Add(' where EXISTS(select X.RTValue from [dbo].[F_Tool_SplitString](' + quotedstr(FFBYIOID) + ','','') X where A.BYIOID=X.RTValue ) '); Open; end; if ADOQueryCmd.fieldbyname('GS').AsInteger > 1 then begin Application.MessageBox('只能同时选择一种纱线出库', '提示', 0); Exit; end else begin FFStkID := trim(ADOQueryCmd.fieldbyname('StkID').asstring); end; with ADOQueryCmd do begin Close; Sql.Clear; Sql.Add(' select Sum(BaoQty) AS BS from BS_Yarn_IO_MX A'); sql.Add(' where IOFlag= ''已入库'' and EXISTS(select X.RTValue from [dbo].[F_Tool_SplitString](' + quotedstr(FFBYIOID) + ','','') X where A.BYIOID=X.RTValue ) '); Open; end; FFQty := ADOQueryCmd.fieldbyname('BS').AsInteger; end; if frmKCList_Sel.cxPageControl1.ActivePageIndex = 1 then begin with CDS_1 do begin First; while not Eof do begin if CDS_1.fieldbyname('SSel').AsBoolean then begin FFBanID := FFBanID + (Trim(CDS_1.fieldbyname('BanID').AsString)) + ','; FFBYIOID := FFBYIOID + (Trim(CDS_1.fieldbyname('BYIOID').AsString)) + ','; end; Next; end; end; FFBanID := leftBstr(trim(FFBanID), length(FFBanID) - 1); FFBYIOID := leftBstr(trim(FFBYIOID), length(FFBYIOID) - 1); with ADOQueryCmd do begin Close; Sql.Clear; Sql.Add(' select count(*) AS GS,StkID =Max(A.BYIOID) from BS_Yarn_IO A'); sql.Add(' where EXISTS(select X.RTValue from [dbo].[F_Tool_SplitString](' + quotedstr(FFBYIOID) + ','','') X where A.BYIOID=X.RTValue ) '); Open; end; if ADOQueryCmd.fieldbyname('GS').AsInteger > 1 then begin Application.MessageBox('只能同时选择一种纱线出库', '提示', 0); Exit; end else begin FFStkID := trim(ADOQueryCmd.fieldbyname('StkID').asstring); end; with ADOQueryCmd do begin Close; Sql.Clear; Sql.Add(' select Sum(BaoQty) AS BS from BS_Yarn_IO_MX A'); sql.Add(' where IOFlag= ''已入库'' and EXISTS(select X.RTValue from [dbo].[F_Tool_SplitString](' + quotedstr(FFBanID) + ','','') X where A.BanID=X.RTValue ) '); Open; end; FFQty := ADOQueryCmd.fieldbyname('BS').AsInteger; end; if frmKCList_Sel.cxPageControl1.ActivePageIndex = 2 then begin with CDS_3 do begin First; while not Eof do begin if CDS_3.fieldbyname('SSel').AsBoolean then begin FFMXID := FFMXID + (Trim(CDS_3.fieldbyname('MXID').AsString)) + ','; FFBYIOID := FFBYIOID + (Trim(CDS_3.fieldbyname('BYIOID').AsString)) + ','; end; Next; end; end; FFMXID := leftBstr(trim(FFMXID), length(FFMXID) - 1); FFBYIOID := leftBstr(trim(FFBYIOID), length(FFBYIOID) - 1); with ADOQueryCmd do begin Close; Sql.Clear; Sql.Add(' select count(*) AS GS,StkID =Max(A.BYIOID) from BS_Yarn_IO A'); sql.Add(' where EXISTS(select X.RTValue from [dbo].[F_Tool_SplitString](' + quotedstr(FFBYIOID) + ','','') X where A.BYIOID=X.RTValue ) '); Open; end; if ADOQueryCmd.fieldbyname('GS').AsInteger > 1 then begin Application.MessageBox('只能同时选择一种纱线出库', '提示', 0); Exit; end else begin FFStkID := trim(ADOQueryCmd.fieldbyname('StkID').asstring); end; with ADOQueryCmd do begin Close; Sql.Clear; Sql.Add(' select Sum(BaoQty) AS BS from BS_Yarn_IO_MX A'); sql.Add(' where IOFlag= ''已入库'' and EXISTS(select X.RTValue from [dbo].[F_Tool_SplitString](' + quotedstr(FFMXID) + ','','') X where A.MXID=X.RTValue ) '); Open; end; FFQty := ADOQueryCmd.fieldbyname('BS').AsInteger; end; ModalResult := 1; end; procedure TfrmKCList_Sel.ToolButton4Click(Sender: TObject); begin WriteCxGrid(trim(self.Caption) + 'Tv1', Tv1, '梭织坯布仓库'); WriteCxGrid(trim(self.Caption) + 'Tv2', Tv2, '梭织坯布仓库'); end; end.