unit U_TradeClothStkList_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, dxSkinsCore, dxSkinsDefaultPainters, dxDateRanges, dxBarBuiltInMenu, U_BaseList, cxPC, System.StrUtils, dxSkinBasic, dxSkinBlack, dxSkinBlue, dxSkinBlueprint, dxSkinCaramel, dxSkinCoffee, dxSkinDarkroom, dxSkinDarkSide, dxSkinDevExpressDarkStyle, dxSkinDevExpressStyle, dxSkinFoggy, dxSkinGlassOceans, dxSkinHighContrast, dxSkiniMaginary, dxSkinLilian, dxSkinLiquidSky, dxSkinLondonLiquidSky, dxSkinMcSkin, dxSkinMetropolis, dxSkinMetropolisDark, dxSkinMoneyTwins, dxSkinOffice2007Black, dxSkinOffice2007Blue, dxSkinOffice2007Green, dxSkinOffice2007Pink, dxSkinOffice2007Silver, dxSkinOffice2010Black, dxSkinOffice2010Blue, dxSkinOffice2010Silver, dxSkinOffice2013DarkGray, dxSkinOffice2013LightGray, dxSkinOffice2013White, dxSkinOffice2016Colorful, dxSkinOffice2016Dark, dxSkinOffice2019Black, dxSkinOffice2019Colorful, dxSkinOffice2019DarkGray, dxSkinOffice2019White, dxSkinPumpkin, dxSkinSeven, dxSkinSevenClassic, dxSkinSharp, dxSkinSharpPlus, dxSkinSilver, dxSkinSpringtime, dxSkinStardust, dxSkinSummer2008, dxSkinTheAsphaltWorld, dxSkinTheBezier, dxSkinValentine, dxSkinVisualStudio2013Blue, dxSkinVisualStudio2013Dark, dxSkinVisualStudio2013Light, dxSkinVS2010, dxSkinWhiteprint, dxSkinWXI, dxSkinXmas2008Blue, dxScrollbarAnnotations, U_BaseHelp, System.ImageList, Vcl.ImgList; type TfrmTradeClothStkList_Sel = class(TfrmBaseHelp) ToolBar1: TToolBar; TBRafresh: TToolButton; TBExport: TToolButton; TBClose: TToolButton; Panel1: TPanel; ADOQueryCmd: TADOQuery; ADOQueryMain: TADOQuery; ADOQueryTemp: TADOQuery; DS_1: TDataSource; GPM_1: TcxGridPopupMenu; Label2: TLabel; BegDate: TDateTimePicker; EndDate: TDateTimePicker; CDS_1: TClientDataSet; begtime: TDateTimePicker; endTime: TDateTimePicker; IsJYTime: TCheckBox; ToolButton2: TToolButton; ToolButton4: TToolButton; Panel6: TPanel; Label31: TLabel; LBCPAP: TLabel; BTLP: TButton; BTNP: TButton; TCBNOR: TComboBox; cxGrid1: TcxGrid; Tv1: TcxGridDBTableView; v1Column22: TcxGridDBColumn; v1Column21: TcxGridDBColumn; v1Column32: TcxGridDBColumn; v1Column1: TcxGridDBColumn; Tv1Column4: TcxGridDBColumn; v1Column13: TcxGridDBColumn; v1Column4: TcxGridDBColumn; v1Column23: TcxGridDBColumn; v1Column8: TcxGridDBColumn; v1Column27: TcxGridDBColumn; v1Column28: TcxGridDBColumn; v1Column10: TcxGridDBColumn; Tv1Column10: TcxGridDBColumn; v1Column12: TcxGridDBColumn; v1Column42: TcxGridDBColumn; v1Column6: TcxGridDBColumn; v1Column3: TcxGridDBColumn; v1Column5: TcxGridDBColumn; v1Column34: TcxGridDBColumn; v1Column46: TcxGridDBColumn; cxGrid1Level1: TcxGridLevel; Label3: TLabel; Label10: TLabel; Label5: TLabel; lbl1: TLabel; Label23: TLabel; OrderNo: TEdit; khconno: TEdit; STKID: TEdit; C_Name: TEdit; PCId: TEdit; C_Code: TEdit; Tv1Column11: TcxGridDBColumn; PM_1: TPopupMenu; PM11: TMenuItem; N1: TMenuItem; Tv1Column6: TcxGridDBColumn; Tv1Column1: TcxGridDBColumn; Tv1Column2: TcxGridDBColumn; ToolButton1: TToolButton; lbl2: TLabel; lbl3: TLabel; cxgrdbclmnTv1Column3: TcxGridDBColumn; lbl4: TLabel; C_Width: TEdit; lbl5: TLabel; C_GramWeight: TEdit; lbl6: TLabel; PieceNo: TEdit; cxGrid2: TcxGrid; TV2: TcxGridDBTableView; cxGridDBColumn6: TcxGridDBColumn; cxGridDBColumn7: TcxGridDBColumn; cxGridDBColumn8: TcxGridDBColumn; cxGridDBColumn15: TcxGridDBColumn; cxGridDBColumn16: TcxGridDBColumn; cxGridDBColumn17: TcxGridDBColumn; cxGridDBColumn18: TcxGridDBColumn; cxGridDBColumn19: TcxGridDBColumn; cxGridDBColumn20: TcxGridDBColumn; cxGridDBColumn21: TcxGridDBColumn; cxGridDBColumn25: TcxGridDBColumn; cxGridLevel1: TcxGridLevel; CD_2: TDataSource; CDS_2: TClientDataSet; 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 orderNoKeyPress(Sender: TObject; var Key: Char); 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 PM11Click(Sender: TObject); procedure N1Click(Sender: TObject); procedure FormDestroy(Sender: TObject); procedure ToolButton1Click(Sender: TObject); procedure v1Column22PropertiesChange(Sender: TObject); procedure TV2CellDblClick(Sender: TcxCustomGridTableView; ACellViewInfo: TcxGridTableDataCellViewInfo; AButton: TMouseButton; AShift: TShiftState; var AHandled: Boolean); private CurrentPage, RecordsNumber: Integer; lstCust: TStringList; sl: TStringList; procedure InitGrid(); procedure SetStatus(); { Private declarations } public canshu1: string; FilteredRecordCount: Integer; property MyStringList: TStringList read sl; { Public declarations } end; var frmTradeClothStkList_Sel: TfrmTradeClothStkList_Sel; implementation uses U_DataLink, U_RTFun, U_LabelPrint; {$R *.dfm} procedure TfrmTradeClothStkList_Sel.SetStatus(); begin end; procedure TfrmTradeClothStkList_Sel.FormClose(Sender: TObject; var Action: TCloseAction); begin inherited; FreeAndNil(lstCust); Action := caFree; end; procedure TfrmTradeClothStkList_Sel.FormCreate(Sender: TObject); begin inherited; lstCust := TStringList.Create; sl := TStringList.Create; EndDate.DateTime := SGetServerDateTime(ADOQueryTemp); BegDate.DateTime := EndDate.DateTime - 20; end; procedure TfrmTradeClothStkList_Sel.FormDestroy(Sender: TObject); begin inherited; frmTradeClothStkList_Sel := nil; end; procedure TfrmTradeClothStkList_Sel.InitGrid(); var WSql: string; begin WSql := SGetFilters(Panel1, 1, 2); if Trim(WSql) <> '' then WSql := ' and ' + WSql; if IsJYTime.Checked then begin WSql := WSql + ' and IOTime>=' + quotedstr(FormatDateTime('yyyy-MM-dd', BegDate.DateTime)); WSql := WSql + ' and IOTime<' + quotedstr(FormatDateTime('yyyy-MM-dd', enddate.DateTime + 1)); end; try ADOQueryMain.DisableControls; with ADOQueryMain do begin Filtered := False; Close; sql.Clear; sql.Add(' select top ' + inttostr(RecordsNumber) + ' * '); sql.Add(' from '); sql.Add('(select rownumber=cast((row_number() over(order by AA.IOTime desc)) as int)'); sql.Add(',COUNT(1) OVER() AS TotalCount'); sql.Add(',* from V_Trade_Cloth_Stk AA where 1=1 ' + WSql); sql.Add(') temp_row'); // sql.Add(' where rownumber> ' + inttostr(((CurrentPage - 1) * RecordsNumber))); sql.Add(' order by rownumber'); // showmessage(sql.text); Open; end; SCreateCDS(ADOQueryMain, CDS_1); SInitCDSData(ADOQueryMain, CDS_1); LBCPAP.Caption := inttostr(CurrentPage) + '/' + inttostr(ceil(CDS_1.FieldByName('TotalCount').AsInteger / RecordsNumber)); finally ADOQueryMain.EnableControls; TV1.DataController.Filter.Clear; end; end; procedure TfrmTradeClothStkList_Sel.TBRafreshClick(Sender: TObject); begin CurrentPage := 1; InitGrid(); end; procedure TfrmTradeClothStkList_Sel.CDS_1BeforeOpen(DataSet: TDataSet); begin lstCust.Clear; end; procedure TfrmTradeClothStkList_Sel.ConNoMChange(Sender: TObject); begin if ADOQueryMain.Active then begin SDofilter(ADOQueryMain, SGetFilters(Panel1, 1, 2)); end; end; procedure TfrmTradeClothStkList_Sel.cxPageControl1Change(Sender: TObject); begin CurrentPage := 1; SetStatus(); InitGrid(); end; procedure TfrmTradeClothStkList_Sel.TBCloseClick(Sender: TObject); begin Close; end; procedure TfrmTradeClothStkList_Sel.FormShow(Sender: TObject); begin inherited; FilteredRecordCount := 0; ReadCxGrid(trim(self.Caption) + 'Tv123', Tv1, '成品仓库'); ReadCxGrid(trim(self.Caption) + 'Tv2', Tv2, '待出库'); CurrentPage := 1; RecordsNumber := 500; canshu1 := '管理'; SetStatus(); v1Column4.Visible := false; v1Column4.Hidden := true; end; procedure TfrmTradeClothStkList_Sel.TBExportClick(Sender: TObject); begin if ADOQueryMain.IsEmpty then exit; TcxGridToExcel(Self.Caption, cxGrid1); end; procedure TfrmTradeClothStkList_Sel.orderNoKeyPress(Sender: TObject; var Key: Char); begin if Key = #13 then begin CurrentPage := 1; InitGrid(); end; end; procedure TfrmTradeClothStkList_Sel.PM11Click(Sender: TObject); var i, index: Integer; WSql: string; begin SelOKNo(CDS_1, false); with CDS_1 do begin First; while not Eof do begin if CDS_1.fieldbyname('SSel').AsBoolean then begin if sl.IndexOf(CDS_1.fieldbyname('CIID').AsString) < 0 then sl.Add(CDS_1.fieldbyname('CIID').AsString); end else begin index := sl.IndexOf(CDS_1.fieldbyname('CIID').AsString); if index >= 0 then sl.Delete(index); end; Next; end; end; for i := 0 to sl.Count - 1 do begin if WSql <> '' then begin WSql := WSql + ',' + QuotedStr(sl[i]); end else begin WSql := QuotedStr(sl[i]); end; end; with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from V_Trade_Cloth_Stk AA where CIID in('); if WSql = '' then sql.Add(QuotedStr(WSql)) else sql.Add(WSql); sql.Add(')'); // showmessage(sql.Text); Open; end; SCreateCDS(ADOQueryTemp, CDS_2); SInitCDSData(ADOQueryTemp, CDS_2); lbl3.Caption := IntToStr(sl.Count); end; procedure TfrmTradeClothStkList_Sel.Tv1DataControllerFilterBeforeChange(Sender: TcxDBDataFilterCriteria; ADataSet: TDataSet; const AFilterText: string); begin lstCust.Clear; end; procedure TfrmTradeClothStkList_Sel.Tv1TcxGridDBDataControllerTcxDataSummaryFooterSummaryItems6GetText(Sender: TcxDataSummaryItem; const AValue: Variant; AIsFooter: Boolean; var AText: string); begin if lstCust <> nil then AText := IntToStr(lstCust.Count); end; procedure TfrmTradeClothStkList_Sel.TV2CellDblClick(Sender: TcxCustomGridTableView; ACellViewInfo: TcxGridTableDataCellViewInfo; AButton: TMouseButton; AShift: TShiftState; var AHandled: Boolean); var index, I: Integer; WSql: string; begin index := sl.IndexOf(CDS_2.fieldbyname('CIID').AsString); if index >= 0 then sl.Delete(index); lbl3.Caption := IntToStr(sl.Count); for I := 0 to sl.Count - 1 do begin if WSql <> '' then begin WSql := WSql + ',' + QuotedStr(sl[I]); end else begin WSql := QuotedStr(sl[I]); end; end; with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from V_Trade_Cloth_Stk AA where CIID in('); if WSql = '' then sql.Add(QuotedStr(WSql)) else sql.Add(WSql); sql.Add(')'); Open; end; SCreateCDS(ADOQueryTemp, CDS_2); SInitCDSData(ADOQueryTemp, CDS_2); end; procedure TfrmTradeClothStkList_Sel.v1Column22PropertiesChange(Sender: TObject); var index: Integer; I: Integer; WSql: string; begin if CDS_1.fieldbyname('SSel').AsBoolean then begin if sl.IndexOf(CDS_1.fieldbyname('CIID').AsString) < 0 then sl.Add(CDS_1.fieldbyname('CIID').AsString); end else begin index := sl.IndexOf(CDS_1.fieldbyname('CIID').AsString); if index >= 0 then sl.Delete(index); end; lbl3.Caption := IntToStr(sl.Count); for I := 0 to sl.Count - 1 do begin if WSql <> '' then begin WSql := WSql + ',' + QuotedStr(sl[I]); end else begin WSql := QuotedStr(sl[I]); end; end; with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from V_Trade_Cloth_Stk AA where CIID in('); if WSql = '' then sql.Add(QuotedStr(WSql)) else sql.Add(WSql); sql.Add(')'); // showmessage(sql.Text); Open; end; SCreateCDS(ADOQueryTemp, CDS_2); SInitCDSData(ADOQueryTemp, CDS_2); end; procedure TfrmTradeClothStkList_Sel.BTNPClick(Sender: TObject); begin if CurrentPage < CDS_1.FieldByName('TotalCount').AsInteger / RecordsNumber then CurrentPage := CurrentPage + 1; InitGrid(); end; procedure TfrmTradeClothStkList_Sel.BTLPClick(Sender: TObject); begin if CurrentPage > 1 then CurrentPage := CurrentPage - 1; InitGrid(); end; procedure TfrmTradeClothStkList_Sel.TCBNORChange(Sender: TObject); begin RecordsNumber := StrToInt(TCBNOR.Text); CurrentPage := 1; InitGrid(); end; procedure TfrmTradeClothStkList_Sel.JYTypeChange(Sender: TObject); begin CurrentPage := 1; InitGrid(); end; procedure TfrmTradeClothStkList_Sel.N1Click(Sender: TObject); var i, index: Integer; WSql: string; begin SelOKNo(CDS_1, true); with CDS_1 do begin First; while not Eof do begin if CDS_1.fieldbyname('SSel').AsBoolean then begin if sl.IndexOf(CDS_1.fieldbyname('CIID').AsString) < 0 then sl.Add(CDS_1.fieldbyname('CIID').AsString); end else begin index := sl.IndexOf(CDS_1.fieldbyname('CIID').AsString); if index >= 0 then sl.Delete(index); end; Next; end; end; for i := 0 to sl.Count - 1 do begin if WSql <> '' then begin WSql := WSql + ',' + QuotedStr(sl[i]); end else begin WSql := QuotedStr(sl[i]); end; end; with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from V_Trade_Cloth_Stk AA where CIID in('); if WSql = '' then sql.Add(QuotedStr(WSql)) else sql.Add(WSql); sql.Add(')'); // showmessage(sql.Text); Open; end; SCreateCDS(ADOQueryTemp, CDS_2); SInitCDSData(ADOQueryTemp, CDS_2); lbl3.Caption := IntToStr(sl.Count); end; procedure TfrmTradeClothStkList_Sel.ToolButton1Click(Sender: TObject); begin OrderNo.SetFocus; ModalResult := 1; end; procedure TfrmTradeClothStkList_Sel.ToolButton2Click(Sender: TObject); var WSql: string; i: Integer; 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 := 'TradeClothStk'; FFiltration1 := WSql; if ShowModal = 1 then begin end; end; finally frmLabelPrint.Free; end; end; procedure TfrmTradeClothStkList_Sel.ToolButton4Click(Sender: TObject); begin WriteCxGrid(trim(self.Caption) + 'Tv123', Tv1, '成品仓库'); WriteCxGrid(trim(self.Caption) + 'Tv2', Tv2, '待出库'); end; end.