unit U_YarnInList_RC; 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, cxPC, cxLookAndFeels, cxLookAndFeelPainters, cxNavigator, dxDateRanges, dxBarBuiltInMenu, U_BaseList, dxScrollbarAnnotations, cxContainer, dxCore, cxDateUtils, cxMaskEdit, FrameDateSel, U_InputBoxSingleNumber, dxSkinsCore, dxSkinsDefaultPainters, cxProgressBar; type TfrmYarnInList_RC = class(TfrmBaseList) ToolBar1: TToolBar; TBRafresh: TToolButton; TBFind: TToolButton; TBExport: TToolButton; TBClose: TToolButton; Panel1: TPanel; ADOQueryCmd: TADOQuery; ADOQueryMain: TADOQuery; ADOQueryTemp: TADOQuery; DS_1: TDataSource; GPM_1: TcxGridPopupMenu; CDS_Main: TClientDataSet; TBDel: TToolButton; PopupMenu1: TPopupMenu; N1: TMenuItem; N2: TMenuItem; TBAdd: TToolButton; TBEdit: TToolButton; Label3: TLabel; Label4: TLabel; Label8: TLabel; Label12: TLabel; Y_Name: TcxTextEdit; FromCoName: TcxTextEdit; Y_spec: TcxTextEdit; cxGrid1: TcxGrid; Tv1: TcxGridDBTableView; v1Column6: TcxGridDBColumn; v1Column2: TcxGridDBColumn; v1Column4: TcxGridDBColumn; v1Column14: TcxGridDBColumn; v2Column1: TcxGridDBColumn; v1Column8: TcxGridDBColumn; v2Column6: TcxGridDBColumn; v1Column3: TcxGridDBColumn; v1Column5: TcxGridDBColumn; v1Column12: TcxGridDBColumn; cxGrid1Level1: TcxGridLevel; v1Column10: TcxGridDBColumn; Label10: TLabel; BatchNo: TcxTextEdit; v1Column20: TcxGridDBColumn; ToolButton1: TToolButton; Label6: TLabel; BYIOID: TcxTextEdit; Tv1Column1: TcxGridDBColumn; Tv1Column2: TcxGridDBColumn; Tv1Column3: TcxGridDBColumn; Tv1Column4: TcxGridDBColumn; Tv1Column5: TcxGridDBColumn; Tv1Column6: TcxGridDBColumn; ToolButton2: TToolButton; Tv1Column7: TcxGridDBColumn; Tv1Column10: TcxGridDBColumn; Label5: TLabel; Supplier: TcxTextEdit; Frame11: TfrmFrameDateSel; IOType: TcxComboBox; Tv1Column11: TcxGridDBColumn; ToolButton3: TToolButton; ToolButton4: TToolButton; Tv1Column8: TcxGridDBColumn; Y_Code: TcxTextEdit; Label1: TLabel; Tv1Column12: TcxGridDBColumn; Tv1Column13: TcxGridDBColumn; ToolButton5: TToolButton; Tv1Column14: TcxGridDBColumn; Tv1Column15: TcxGridDBColumn; Tv1Column16: TcxGridDBColumn; Tv1Column17: TcxGridDBColumn; cxGrid2: TcxGrid; Tv2: TcxGridDBTableView; cxGridDBColumn2: TcxGridDBColumn; cxGridDBColumn3: TcxGridDBColumn; cxGridDBColumn4: TcxGridDBColumn; v1Column15: TcxGridDBColumn; v1Column1: TcxGridDBColumn; cxGridDBColumn5: TcxGridDBColumn; cxGridDBColumn6: TcxGridDBColumn; cxGridDBColumn7: TcxGridDBColumn; cxGridDBColumn8: TcxGridDBColumn; cxGridDBColumn9: TcxGridDBColumn; cxGridDBColumn10: TcxGridDBColumn; cxGridDBColumn11: TcxGridDBColumn; v1Column16: TcxGridDBColumn; v1Column17: TcxGridDBColumn; cxGridDBColumn12: TcxGridDBColumn; cxGridDBColumn13: TcxGridDBColumn; cxGridDBColumn14: TcxGridDBColumn; cxGridDBColumn15: TcxGridDBColumn; cxGridDBColumn16: TcxGridDBColumn; cxGridDBColumn17: TcxGridDBColumn; cxGridDBColumn18: TcxGridDBColumn; cxGridDBColumn19: TcxGridDBColumn; cxGridDBColumn20: TcxGridDBColumn; v1Column7: TcxGridDBColumn; cxGridDBColumn21: TcxGridDBColumn; cxGridDBColumn22: TcxGridDBColumn; cxGridDBColumn23: TcxGridDBColumn; cxGridDBColumn24: TcxGridDBColumn; cxGridDBColumn25: TcxGridDBColumn; cxGridLevel1: TcxGridLevel; DS_2: TDataSource; CDS_2: TClientDataSet; Tv2Column1: TcxGridDBColumn; ADOQuerySub: TADOQuery; Tv1Column9: TcxGridDBColumn; Tv2Column2: TcxGridDBColumn; Tv2Column3: TcxGridDBColumn; 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 BYIOIDChange(Sender: TObject); procedure Y_specChange(Sender: TObject); procedure FromCoNameChange(Sender: TObject); procedure cxTabControl1Change(Sender: TObject); procedure ToolButton1Click(Sender: TObject); procedure ToolButton2Click(Sender: TObject); procedure ToolButton3Click(Sender: TObject); procedure ToolButton4Click(Sender: TObject); procedure BYIOIDPropertiesChange(Sender: TObject); procedure ToolButton5Click(Sender: TObject); procedure Tv1FocusedRecordChanged(Sender: TcxCustomGridTableView; APrevFocusedRecord, AFocusedRecord: TcxCustomGridRecord; ANewItemRecordFocusingChanged: Boolean); private canshu1, FStkName, canshu3: string; procedure InitGrid(); procedure InitCKGrid(); procedure setStatus(); { Private declarations } public { Public declarations } end; implementation uses U_DataLink, U_RTFun, U_YarnInEdit, U_LabelPrint, U_YarnOutReturnList, U_YarnOutReturnList1; {$R *.dfm} procedure TfrmYarnInList_RC.setStatus(); begin end; procedure TfrmYarnInList_RC.FormClose(Sender: TObject; var Action: TCloseAction); begin inherited; Action := caFree; end; procedure TfrmYarnInList_RC.FormCreate(Sender: TObject); begin inherited; Frame11.EndDate.Date := SGetServerDate(ADOQueryTemp); Frame11.BegDate.Date := Frame11.EndDate.Date - 30; canshu1 := Trim(self.fParameters1); FStkName := Trim(self.fParameters2); canshu3 := Trim(self.fParameters3); end; procedure TfrmYarnInList_RC.InitGrid(); begin try ADOQueryMain.DisableControls; with ADOQueryMain do begin Filtered := False; Close; sql.Clear; sql.Add(' select A.* '); sql.Add(' from BS_Yarn_IO A'); sql.add(' where A.IOTime>=''' + Trim(FormatDateTime('yyyy-MM-dd', Frame11.BegDate.Date)) + ''''); sql.Add(' and A.IOTime<''' + Trim(FormatDateTime('yyyy-MM-dd', Frame11.enddate.Date + 1)) + ''''); sql.Add(' and isnull(StkName,'''')=''' + Trim(FStkName) + ''''); SQL.Add(' and IOFlag=''入库'' '); SQL.Add(' order by IOTime desc'); Open; end; SDofilter(ADOQueryMain, SGetFilters(Panel1, 1, 2)); SCreateCDS(ADOQueryMain, CDS_Main); SInitCDSData(ADOQueryMain, CDS_Main); finally ADOQueryMain.EnableControls; end; end; procedure TfrmYarnInList_RC.InitCKGrid(); begin try ADOQuerySub.DisableControls; with ADOQuerySub do begin Filtered := False; Close; sql.Clear; sql.Add(' select A.* '); sql.Add(' ,JZCRTime =(select top 1 X.IOTime from Tat_WB_IO X where X.STKName =''经轴'' and X.IOFlag =''入库'' and X.WBCID =A.WBCID order by IOTime) '); sql.Add(' ,ZC =(select top 1 X.Qty from Tat_WB_IO X where X.STKName =''经轴'' and X.IOFlag =''入库'' and X.WBCID =A.WBCID order by IOTime) '); sql.Add(' from BS_Yarn_IO A'); sql.add(' where A.IOTime>=''' + Trim(FormatDateTime('yyyy-MM-dd', Frame11.BegDate.Date)) + ''''); sql.Add(' and A.IOTime<''' + Trim(FormatDateTime('yyyy-MM-dd', Frame11.enddate.Date + 1)) + ''''); sql.Add(' and isnull(StkName,'''')=''' + Trim(FStkName) + ''''); SQL.Add(' and IOFlag=''出库'' '); SQL.Add(' and StkID=''' + Trim(CDS_Main.fieldbyname('BYIOID').AsString) + ''''); SQL.Add(' order by IOTime desc'); Open; end; // SDofilter(ADOQuerySub, SGetFilters(Panel1, 1, 2)); SCreateCDS(ADOQuerySub, CDS_2); SInitCDSData(ADOQuerySub, CDS_2); finally ADOQuerySub.EnableControls; end; end; procedure TfrmYarnInList_RC.TBRafreshClick(Sender: TObject); begin ToolBar1.SetFocus; InitGrid(); end; procedure TfrmYarnInList_RC.ToolButton1Click(Sender: TObject); begin WriteCxGrid(Self.Caption + '1', Tv1, '纱线仓库'); WriteCxGrid(Self.Caption + '2', Tv2, '纱线仓库'); end; procedure TfrmYarnInList_RC.ToolButton2Click(Sender: TObject); var MBYIOID: string; begin if CDS_Main.IsEmpty then Exit; if CDS_Main.Locate('SSel', True, []) = False then begin Application.MessageBox('没有选择数据!', '提示', 0); Exit; end; MBYIOID := ''; CDS_Main.DisableControls; with CDS_Main do begin First; while CDS_Main.Locate('SSel', True, []) do begin MBYIOID := MBYIOID + ',' + (Trim(CDS_Main.fieldbyname('BYIOID').AsString)); Edit; FieldByName('SSel').Value := False; Post; end; end; CDS_Main.EnableControls; try frmLabelPrint := TfrmLabelPrint.Create(Application); with frmLabelPrint do begin FLMType := 'BSYarnInPrt1'; FFiltration1 := MBYIOID; if ShowModal = 1 then begin // Self.InitGrid(); end; end; finally frmLabelPrint.Free; end; end; procedure TfrmYarnInList_RC.ToolButton3Click(Sender: TObject); var MBYIOIDs: string; begin MBYIOIDs := SelCDSKey(CDS_Main, ['BYIOID'])[0]; if MBYIOIDs = '' then Exit; try frmInputBoxSingleNumber := TfrmInputBoxSingleNumber.Create(Application); with frmInputBoxSingleNumber do begin if ShowModal = 1 then begin if StrToFloatDef(frmInputBoxSingleNumber.Price.Text, 0) = 0 then frmInputBoxSingleNumber.Price.Text := '0'; try ADOQueryCmd.Connection.BeginTrans; with ADOQueryCmd do begin Close; Sql.Clear; Sql.Add('update BS_Yarn_IO set TestDenier=' + frmInputBoxSingleNumber.Price.Text); sql.Add('where EXISTS(select X.RTValue from [dbo].[F_Tool_SplitString](' + quotedstr(MBYIOIDs) + ','','') X where BS_Yarn_IO.BYIOID=X.RTValue ) '); ExecSQL; end; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('insert into SY_SysLog(operor,opertime,Model,acction,opevent,result) values( '); sql.Add(' ' + quotedstr(trim(DName))); sql.Add(',getdate() '); sql.Add(',' + quotedstr(trim(self.Caption))); sql.Add(',' + quotedstr(trim('D数调整'))); sql.Add(',' + quotedstr(trim(MBYIOIDs) + ' D数:' + frmInputBoxSingleNumber.Price.Text)); sql.Add(',' + quotedstr(trim('成功'))); sql.Add(')'); ExecSQL; end; ADOQueryCmd.Connection.CommitTrans; except ADOQueryCmd.Connection.RollbackTrans; application.MessageBox(PChar(Exception(ExceptObject).Message), '提示信息', 0); end; end; end; finally frmInputBoxSingleNumber.Free; end; InitGrid(); end; procedure TfrmYarnInList_RC.ToolButton4Click(Sender: TObject); begin try frmYarnOutReturnList := TfrmYarnOutReturnList.Create(Application); with frmYarnOutReturnList do begin FStkName := Self.FStkName; if ShowModal = 1 then begin Self.InitGrid(); end; end; finally frmYarnOutReturnList.Free; end; end; procedure TfrmYarnInList_RC.ToolButton5Click(Sender: TObject); begin try frmYarnOutReturnList1 := TfrmYarnOutReturnList1.Create(Application); with frmYarnOutReturnList1 do begin FStkName := Self.FStkName; if ShowModal = 1 then begin Self.InitGrid(); end; end; finally frmYarnOutReturnList1.Free; end; end; procedure TfrmYarnInList_RC.Tv1FocusedRecordChanged(Sender: TcxCustomGridTableView; APrevFocusedRecord, AFocusedRecord: TcxCustomGridRecord; ANewItemRecordFocusingChanged: Boolean); begin InitCKGrid(); end; procedure TfrmYarnInList_RC.BYIOIDPropertiesChange(Sender: TObject); begin TBFind.Click; end; procedure TfrmYarnInList_RC.ConNoMChange(Sender: TObject); begin if ADOQueryMain.Active then begin SDofilter(ADOQueryMain, SGetFilters(Panel1, 1, 2)); end; end; procedure TfrmYarnInList_RC.TBCloseClick(Sender: TObject); begin Close; end; procedure TfrmYarnInList_RC.FormShow(Sender: TObject); var mSql: string; begin inherited; mSql := 'select distinct name=A.IOType from BS_Yarn_IO A where IOFlag=''入库'' and isnull(STKNAME,'''')=''' + Trim(FSTKNAME) + ''' '; SInitTcxComBoxBySql(ADOQueryTemp, IOType, false, mSql); ReadCxGrid(Self.Caption + '1', Tv1, '纱线仓库'); ReadCxGrid(Self.Caption + '2', Tv2, '纱线仓库'); setStatus(); InitGrid(); end; procedure TfrmYarnInList_RC.TBExportClick(Sender: TObject); begin if ADOQueryMain.IsEmpty then exit; TcxGridToExcel(FStkName + '入库列表', cxGrid1); end; procedure TfrmYarnInList_RC.TBFindClick(Sender: TObject); begin if ADOQueryMain.Active then begin SDofilter(ADOQueryMain, SGetFilters(Panel1, 1, 2)); SCreateCDS(ADOQueryMain, CDS_Main); SInitCDSData(ADOQueryMain, CDS_Main); end; end; procedure TfrmYarnInList_RC.N1Click(Sender: TObject); begin SelOKNo(CDS_Main, True); end; procedure TfrmYarnInList_RC.N2Click(Sender: TObject); begin SelOKNo(CDS_Main, False); end; procedure TfrmYarnInList_RC.TBDelClick(Sender: TObject); var MBYIOID: string; begin if CDS_Main.IsEmpty then Exit; if Application.MessageBox('确定要删除数据吗?', '提示', 32 + 4) <> IDYES then Exit; if CDS_Main.Locate('SSel', True, []) = False then begin Application.MessageBox('没有选择数据!', '提示', 0); Exit; end; MBYIOID := ''; CDS_Main.DisableControls; with CDS_Main do begin First; while CDS_Main.Locate('SSel', True, []) do begin MBYIOID := MBYIOID + ',' + Trim(CDS_Main.fieldbyname('BYIOID').AsString); CDS_Main.Delete; end; end; CDS_Main.EnableControls; with ADOQueryTemp do begin Close; sql.Clear; sql.Add('exec P_Fin_Flow_Judge '); Sql.Add(' @FFIDS=' + quotedstr(MBYIOID)); Sql.Add(',@DCode=' + quotedstr(Trim(DCode))); Sql.Add(',@DName=' + quotedstr(Trim(DName))); Open; end; if ADOQueryTemp.FieldByName('intReturn').AsInteger = -1 then begin Application.MessageBox(PChar(ADOQueryTemp.fieldbyname('ShowMsg').AsString), '提示', 0); exit; end; try ADOQueryCmd.Connection.BeginTrans; with ADOQueryCmd do begin Close; Sql.Clear; sql.Add('insert into Finance_Need_Up(UType,UDataId,UOperation,UOperator,UModule,UDetails) '); sql.Add('values(''纱线入库'' '); sql.Add(',' + quotedstr(MBYIOID)); sql.Add(',''删除'' '); sql.Add(',' + quotedstr(DName)); sql.Add(',' + quotedstr(trim(self.Caption))); sql.Add(',' + quotedstr(MBYIOID)); sql.Add(') '); Sql.Add('exec P_BS_Yarn_In_Del '); Sql.Add(' @BYIOIDS=' + quotedstr(MBYIOID)); Sql.Add(',@DCode=' + quotedstr(Trim(DCode))); Sql.Add(',@DName=' + quotedstr(Trim(DName))); Open; end; if ADOQueryCmd.FieldByName('intReturn').AsInteger = -1 then raise Exception.Create(pchar(trim(ADOQueryCmd.FieldByName('ShowMsg').AsString))); ADOQueryCmd.Connection.CommitTrans; InitGrid(); except ADOQueryCmd.Connection.RollbackTrans; application.MessageBox(PChar(Exception(ExceptObject).Message), '提示信息', 0); end; end; procedure TfrmYarnInList_RC.TBAddClick(Sender: TObject); begin try frmYarnInEdit := TfrmYarnInEdit.Create(Application); with frmYarnInEdit do begin FBCId := ''; frmYarnInEdit.canshu3 := Trim(Self.canshu3); FStkName := Self.FStkName; if ShowModal = 1 then begin Self.InitGrid(); end; end; finally frmYarnInEdit.Free; end; end; procedure TfrmYarnInList_RC.TBEditClick(Sender: TObject); begin if CDS_Main.IsEmpty then Exit; with ADOQueryTemp do begin Close; sql.Clear; sql.Add('exec P_Fin_Flow_Judge '); Sql.Add(' @FFIDS=' + quotedstr(Trim(CDS_Main.fieldbyname('BYIOID').AsString))); Sql.Add(',@DCode=' + quotedstr(Trim(DCode))); Sql.Add(',@DName=' + quotedstr(Trim(DName))); Open; end; if ADOQueryTemp.FieldByName('intReturn').AsInteger = -1 then begin Application.MessageBox(PChar(ADOQueryTemp.fieldbyname('ShowMsg').AsString), '提示', 0); exit; end; with ADOQueryTemp do begin Close; Sql.Clear; Sql.Add('exec P_BS_Yarn_In_Edit '); Sql.Add(' @BYIOIDS=' + quotedstr(Trim(CDS_Main.fieldbyname('BYIOID').AsString))); Sql.Add(',@DCode=' + quotedstr(Trim(DCode))); Sql.Add(',@DName=' + quotedstr(Trim(DName))); Open; end; if ADOQueryTemp.FieldByName('intReturn').AsInteger = -1 then begin Application.MessageBox(PChar(ADOQueryTemp.fieldbyname('ShowMsg').AsString), '提示', 0); exit; end; try frmYarnInEdit := TfrmYarnInEdit.Create(Application); with frmYarnInEdit do begin FBCId := Trim(CDS_Main.fieldbyname('BYIOID').AsString); TBDel.Visible := False; TBAdd.Visible := False; FStkName := Self.FStkName; if ShowModal = 1 then begin Self.InitGrid(); end; end; finally frmYarnInEdit.Free; end; end; procedure TfrmYarnInList_RC.BYIOIDChange(Sender: TObject); begin if Length(Trim(BYIOID.Text)) < 4 then begin if Trim(BYIOID.Text) <> '' then Exit; end; TBFind.Click; end; procedure TfrmYarnInList_RC.Y_specChange(Sender: TObject); begin TBFind.Click; end; procedure TfrmYarnInList_RC.FromCoNameChange(Sender: TObject); begin TBFind.Click; end; procedure TfrmYarnInList_RC.cxTabControl1Change(Sender: TObject); begin InitGrid(); end; end.