unit U_CPBRKList; 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, cxContainer, cxImage, cxDBEdit, cxPC, Math, cxLookAndFeels, cxLookAndFeelPainters, cxNavigator, dxBarBuiltInMenu; type TfrmCPBRKList = class(TForm) ToolBar1: TToolBar; TBRafresh: TToolButton; TBFind: TToolButton; TBExport: TToolButton; TBClose: TToolButton; Panel1: TPanel; ADOQueryCmd: TADOQuery; ADOQueryMain: TADOQuery; ADOQueryTemp: TADOQuery; DataSource1: TDataSource; cxGridPopupMenu1: TcxGridPopupMenu; Label1: TLabel; Label2: TLabel; BegDate: TDateTimePicker; EndDate: TDateTimePicker; CDS_Main: TClientDataSet; RM1: TRMGridReport; RMDBMain: TRMDBDataSet; RMXLSExport1: TRMXLSExport; RMDBHZ: TRMDBDataSet; CDS_HZ: TClientDataSet; CDS_PRT: TClientDataSet; TBDel: TToolButton; PopupMenu1: TPopupMenu; N1: TMenuItem; N2: TMenuItem; TBAdd: TToolButton; TBEdit: TToolButton; Label7: TLabel; OrderNo: TEdit; cxGrid2: TcxGrid; Tv1: TcxGridDBTableView; v1Column6: TcxGridDBColumn; v1Column2: TcxGridDBColumn; v1Column4: TcxGridDBColumn; v1Column13: TcxGridDBColumn; v1Column15: TcxGridDBColumn; v1Column14: TcxGridDBColumn; v2Column1: TcxGridDBColumn; v1Column8: TcxGridDBColumn; v1Column7: TcxGridDBColumn; v1Column1: TcxGridDBColumn; v1Column10: TcxGridDBColumn; v1Column11: TcxGridDBColumn; v1Column9: TcxGridDBColumn; v2Column6: TcxGridDBColumn; v1Column3: TcxGridDBColumn; v1Column16: TcxGridDBColumn; v1Column12: TcxGridDBColumn; cxGrid2Level1: TcxGridLevel; Label9: TLabel; spcode: TEdit; Panel2: TPanel; Picture4: TcxDBImage; ADOQueryImage: TADOQuery; DSImage: TDataSource; v1Column21: TcxGridDBColumn; btnEditForFac: TToolButton; CDS_MX: TClientDataSet; DS_MX: TDataSource; cxGridPopupMenu2: TcxGridPopupMenu; btnJYCX: TToolButton; btnJY: TToolButton; cxTabControl1: TcxTabControl; ToolButton4: TToolButton; Panel3: TPanel; Label25: TLabel; btnChk: TButton; Button3: TButton; MMJYNote: TMemo; edtSPID: TEdit; ToolButton1: TToolButton; v1Column20: TcxGridDBColumn; ToolButton2: TToolButton; ToolButton3: TToolButton; ADOQueryPrint: TADOQuery; ComboBox1: TComboBox; v1Column22: TcxGridDBColumn; Label4: TLabel; CustomerNoName: TComboBox; Panel4: TPanel; cxGrid1: TcxGrid; TvMX: TcxGridDBTableView; vMXColumn1: TcxGridDBColumn; cxGridDBColumn8: TcxGridDBColumn; vMXColumn2: TcxGridDBColumn; vMXColumn3: TcxGridDBColumn; cxGridLevel2: TcxGridLevel; ToolBar2: TToolBar; ToolButton5: TToolButton; ToolButton6: TToolButton; Label3: TLabel; SPColor: TEdit; TvMXColumn1: TcxGridDBColumn; Tv1Column1: TcxGridDBColumn; Tv1Column2: TcxGridDBColumn; Tv1Column3: TcxGridDBColumn; Tv1Column4: TcxGridDBColumn; 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 SPIDChange(Sender: TObject); procedure SPSpecChange(Sender: TObject); procedure FactoryNameChange(Sender: TObject); procedure Tv1CellClick(Sender: TcxCustomGridTableView; ACellViewInfo: TcxGridTableDataCellViewInfo; AButton: TMouseButton; AShift: TShiftState; var AHandled: Boolean); procedure FormResize(Sender: TObject); procedure btnEditForFacClick(Sender: TObject); procedure TvMXCustomDrawIndicatorCell(Sender: TcxGridTableView; ACanvas: TcxCanvas; AViewInfo: TcxCustomGridIndicatorItemViewInfo; var ADone: Boolean); procedure Tv1FocusedRecordChanged(Sender: TcxCustomGridTableView; APrevFocusedRecord, AFocusedRecord: TcxCustomGridRecord; ANewItemRecordFocusingChanged: Boolean); procedure btnJYCXClick(Sender: TObject); procedure Button3Click(Sender: TObject); procedure ToolButton4Click(Sender: TObject); procedure btnChkClick(Sender: TObject); procedure btnJYClick(Sender: TObject); procedure cxTabControl1Change(Sender: TObject); procedure ToolButton1Click(Sender: TObject); procedure ToolButton3Click(Sender: TObject); procedure ToolButton2Click(Sender: TObject); private canshu2: string; procedure InitGrid(); procedure InitImage(fsubID: string); procedure InitMXGrid(MCRNO: string); procedure SetStatus(); { Private declarations } public { Public declarations } canshu1: string; end; var frmCPBRKList: TfrmCPBRKList; implementation uses U_DataLink, U_RTFun, U_CPBCKInPut, U_ZdyAttachGYS, U_FjList_RZ, U_CPCKMXLR, U_Fun; {$R *.dfm} procedure TfrmCPBRKList.SetStatus(); begin // TBEdit.Visible := False; btnEditForFac.Visible := False; btnJY.Visible := False; btnJYCX.Visible := False; // TBDel.Visible := False; case cxTabControl1.TabIndex of 0: begin TBEdit.Visible := True; btnEditForFac.Visible := True; btnJY.Visible := True; // TBDel.Visible := True; end; 1: begin btnEditForFac.Visible := True; btnJYCX.Visible := True; end; 2: begin end; end; end; procedure TfrmCPBRKList.InitMXGrid(MCRNO: string); begin with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from CK_SXPB_CRMX where CRNO=' + quotedstr(Trim(MCRNO))); sql.Add(' order by MXID'); Open; end; // with ADOQueryTemp do // begin // Close; // sql.Clear; // sql.Add('DELETE CK_SXPB_CRMX where crno=' + quotedstr(Trim(cds_main.FieldByName('spid').AsString))); // sql.Add(' AND (MXQTY=0 and mxqty2=0)'); //// ShowMessage(sql.Text); // EXECSQL; // end; SCreateCDS20(ADOQueryTemp, CDS_MX); SInitCDSData20(ADOQueryTemp, CDS_MX); end; procedure TfrmCPBRKList.InitImage(fsubID: string); begin ADOQueryImage.close; // IF fwbid='' then exit; with ADOQueryImage do begin close; sql.Clear; sql.Add('select * from TP_File A'); sql.Add('inner join JYOrder_Sub B on B.HXFile=A.WBID'); sql.Add('where B.SubID=' + quotedstr(trim(fsubID))); open; end; end; procedure TfrmCPBRKList.FormDestroy(Sender: TObject); begin frmCPBRKList := nil; end; procedure TfrmCPBRKList.FormClose(Sender: TObject; var Action: TCloseAction); begin Action := caFree; end; procedure TfrmCPBRKList.FormCreate(Sender: TObject); begin //cxGrid1.Align:=alClient; canshu1 := Trim(DParameters1); canshu2 := Trim(DParameters2); EndDate.DateTime := SGetServerDate10(ADOQueryTemp); BegDate.DateTime := EndDate.DateTime; end; procedure TfrmCPBRKList.InitGrid(); begin try ADOQueryMain.DisableControls; with ADOQueryMain do begin Filtered := False; Close; sql.Clear; sql.Add(' select A.* '); SQL.Add(',FQTY=(CASE WHEN qtyunit=''KG'' THEN (SELECT SUM(MXQTY2) FROM CK_SXPB_CRMX D WHERE D.CRNO=A.SPID)'); SQL.Add('WHEN qtyunit=''M'' OR qtyunit=''Y'' THEN (SELECT SUM(MXQTY) FROM CK_SXPB_CRMX D WHERE D.CRNO=A.SPID) END )'); SQL.Add(',FUNIT=(CASE WHEN qtyunit=''KG'' THEN (SELECT TOP 1 MXUnit FROM CK_SXPB_CRMX D WHERE D.CRNO=A.SPID)'); SQL.Add('WHEN qtyunit=''M'' OR qtyunit=''Y'' THEN ''KG'' END )'); sql.Add(',ISSC=cast((case when isnull((select count(WBID) from TP_File X where X.WBID=A.spid and X.TFType=''成品入库''),0)>0 then 1 else 0 end) as bit)'); sql.Add(' from CK_SXPB_CR A'); sql.add(' where A.CRTime>=''' + Trim(FormatDateTime('yyyy-MM-dd', BegDate.DateTime)) + ''''); sql.Add(' and A.CRTime<=''' + Trim(FormatDateTime('yyyy-MM-dd', enddate.DateTime + 1)) + ''''); sql.Add(' and isnull(CKName,'''')=''成品布'''); SQL.Add(' and CRFlag=''入库'' '); case cxTabControl1.TabIndex of 0: begin SQL.Add(' and isnull(chkstatus,0)=''0'' '); end; 1: begin SQL.Add(' and isnull(chkstatus,0)=''1'' '); end; end; if canshu1 <> '管理' then begin SQL.Add('AND (FILLER =' + QuotedStr(Trim(dname))); sql.Add('or (select lidan from JYOrder_Main c where c.orderno=a.qcorderno)=' + QuotedStr(Trim(dname))); sql.Add('or (select ywy from JYOrder_Main c where c.orderno=a.qcorderno)=' + QuotedStr(Trim(dname))); sql.Add(')'); end; // ShowMessage(SQL.Text); Open; end; SCreateCDS20(ADOQueryMain, CDS_Main); SInitCDSData20(ADOQueryMain, CDS_Main); finally ADOQueryMain.EnableControls; end; end; procedure TfrmCPBRKList.TBRafreshClick(Sender: TObject); begin BegDate.SetFocus; InitGrid(); end; procedure TfrmCPBRKList.ConNoMChange(Sender: TObject); begin if ADOQueryMain.Active then begin SDofilter(ADOQueryMain, SGetFilters(Panel1, 1, 2)); end; end; procedure TfrmCPBRKList.TBCloseClick(Sender: TObject); begin WriteCxGrid(Trim(Self.Caption) + 'Tv1', Tv1, '待检布仓库0327'); WriteCxGrid(Trim(Self.Caption) + 'Tv2', TvMX, '待检布仓库0327'); Close; end; procedure TfrmCPBRKList.FormShow(Sender: TObject); var fsj: string; begin SetStatus(); ReadCxGrid(Trim(Self.Caption) + 'Tv1', Tv1, '待检布仓库0327'); ReadCxGrid(Trim(Self.Caption) + 'Tv2', TvMX, '待检布仓库0327'); fsj := 'select distinct(CustomerNoName) Name from CK_SXPB_CR order by CustomerNoName '; SInitComBoxBySql(ADOQueryCmd, CustomerNoName, False, fsj); //InitGrid(); end; procedure TfrmCPBRKList.TBExportClick(Sender: TObject); begin if ADOQueryMain.IsEmpty then exit; TcxGridToExcel('待检布入库列表', cxGrid2); end; procedure TfrmCPBRKList.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 TfrmCPBRKList.N1Click(Sender: TObject); begin SelOKNo(CDS_Main, True); end; procedure TfrmCPBRKList.N2Click(Sender: TObject); begin SelOKNo(CDS_Main, False); end; procedure TfrmCPBRKList.TBDelClick(Sender: TObject); begin if CDS_Main.IsEmpty then Exit; 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) + ''''); sql.Add(' delete CK_SXPB_CRMX where CRNO=''' + Trim(CDS_Main.fieldbyname('SPID').AsString) + ''''); ExecSQL; // if UpdateSXPB(ADOQueryCmd, Trim(CDS_Main.fieldbyname('ORDMainIdRK').AsString), Trim(CDS_Main.fieldbyname('ORDSubIdRK').AsString)) = False then // begin // ADOQueryCmd.Connection.RollbackTrans; // Application.MessageBox('更新进度失败!', '提示', 0); // Exit; // end; end; ADOQueryCmd.Connection.CommitTrans; CDS_Main.Delete; except ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('删除异常!', '提示', 0); end; end else begin CDS_Main.Delete; end; end; procedure TfrmCPBRKList.TBAddClick(Sender: TObject); begin try frmCPBCKInPut := TfrmCPBCKInPut.Create(Application); with frmCPBCKInPut do begin FBCId := ''; if ShowModal = 1 then begin Self.InitGrid(); end; end; finally frmCPBCKInPut.Free; end; end; procedure TfrmCPBRKList.TBEditClick(Sender: TObject); begin if CDS_Main.IsEmpty then Exit; if Trim(CDS_Main.fieldbyname('CRType').AsString) = '平移入库' then begin Application.MessageBox('平移入库的数据为自动生成,不能修改!', '提示', 0); Exit; end; try frmCPBCKInPut := TfrmCPBCKInPut.Create(Application); with frmCPBCKInPut do begin FBCId := Trim(CDS_Main.fieldbyname('SPID').AsString); TBDel.Visible := False; TBAdd.Visible := False; if ShowModal = 1 then begin Self.InitGrid(); end; end; finally frmCPBCKInPut.Free; end; end; procedure TfrmCPBRKList.SPIDKeyPress(Sender: TObject; var Key: Char); begin if Key = #13 then begin {if Length(Trim(SPID.Text))<4 then Exit; try ADOQueryMain.DisableControls; with ADOQueryMain do begin Filtered:=False; Close; sql.Clear; sql.Add(' select A.* '); sql.Add(',ConNo=(select ConNo from Contract_Main CM where CM.MainId=A.CGMainId)'); //sql.Add(' ,ConNo=(select ConNo from Contract_Main CM where CM.MainId=A.CGMainId )'); sql.Add(' from CK_SXPB_CR A'); sql.add(' where SPID like :SXID'); Parameters.ParamByName('SXID').Value:='%'+Trim(SXID.Text)+'%'; Open; //ShowMessage(SQL.Text); end; SCreateCDS20(ADOQueryMain,CDS_Main); SInitCDSData20(ADOQueryMain,CDS_Main); finally ADOQueryMain.EnableControls; end; } end; end; procedure TfrmCPBRKList.SPIDChange(Sender: TObject); begin TBFind.Click; end; procedure TfrmCPBRKList.SPSpecChange(Sender: TObject); begin TBFind.Click; end; procedure TfrmCPBRKList.FactoryNameChange(Sender: TObject); begin TBFind.Click; end; procedure TfrmCPBRKList.Tv1CellClick(Sender: TcxCustomGridTableView; ACellViewInfo: TcxGridTableDataCellViewInfo; AButton: TMouseButton; AShift: TShiftState; var AHandled: Boolean); begin // ADOQueryImage.Close; // IF CDS_Main.IsEmpty then exit; // InitImage(CDS_Main.fieldbyname('OrdSubIdRK').AsString); end; procedure TfrmCPBRKList.FormResize(Sender: TObject); begin Panel2.Left := self.Width - Panel2.Width - 30; Panel2.Top := self.Height - Panel2.Height - 80; Panel3.Left := Ceil((self.Width - Panel3.Width) / 2) - 30; Panel3.Top := Ceil((self.Height - Panel3.Height) / 2) - 80; end; procedure TfrmCPBRKList.btnEditForFacClick(Sender: TObject); begin try frmZdyAttachGYS := TfrmZdyAttachGYS.Create(Application); with frmZdyAttachGYS do begin if ShowModal = 1 then begin with ADOQueryCmd do begin close; sql.Clear; sql.Add('exec P_Update_SXPB_Factory ' + quotedstr(trim(Self.CDS_Main.FieldByName('SPID').AsString)) + ',' + quotedstr(Trim(frmZdyAttachGYS.CDS_HZ.fieldbyname('ZdyCode').AsString)) + ',' + quotedstr(Trim(frmZdyAttachGYS.CDS_HZ.fieldbyname('ZdyName').AsString))); // ShowMessage(SQL.Text); 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('修改加工厂'))); sql.Add(',' + quotedstr(trim('入库单号:' + trim(Self.CDS_Main.FieldByName('SPID').AsString) + ' 原加工厂:' + trim(Self.CDS_Main.FieldByName('FactoryName').AsString)))); sql.Add(',' + quotedstr(trim('成功'))); sql.Add(')'); execsql; end; end; end; finally frmZdyAttachGYS.Free; end; end; procedure TfrmCPBRKList.TvMXCustomDrawIndicatorCell(Sender: TcxGridTableView; ACanvas: TcxCanvas; AViewInfo: TcxCustomGridIndicatorItemViewInfo; var ADone: Boolean); var FValue: string; FBounds: TRect; begin FBounds := AViewInfo.Bounds; if (AViewInfo is TcxGridIndicatorRowItemViewInfo) then begin ACanvas.FillRect(FBounds); ACanvas.DrawComplexFrame(FBounds, clBtnHighlight, clBtnShadow, [bBottom, bLeft, bRight], 1); FValue := IntToStr(TcxGridIndicatorRowItemViewInfo(AViewInfo).GridRecord.Index + 1); InflateRect(FBounds, -1, -1); //Platform specific. May not work on Linux. ACanvas.Font.Color := clBlack; ACanvas.Brush.Style := bsClear; ACanvas.DrawText(FValue, FBounds, cxAlignCenter or cxAlignTop); ADone := True; end; end; procedure TfrmCPBRKList.Tv1FocusedRecordChanged(Sender: TcxCustomGridTableView; APrevFocusedRecord, AFocusedRecord: TcxCustomGridRecord; ANewItemRecordFocusingChanged: Boolean); begin InitMXGrid(Trim(CDS_Main.fieldbyname('SPID').AsString)); end; procedure TfrmCPBRKList.btnJYCXClick(Sender: TObject); begin try with ADOQueryCmd do begin close; sql.Clear; sql.Add('update CK_SXPB_CR SET chkstatus=''0'',Chktime=null ,Chker= null'); sql.Add('where SPID=' + quotedstr(trim(CDS_Main.fieldbyname('SPID').AsString))); 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('撤销入库审核'))); sql.Add(',' + quotedstr(trim('入库单号:' + trim(CDS_Main.FieldByName('SPID').AsString)))); sql.Add(',' + quotedstr(trim('成功'))); sql.Add(')'); execsql; end; application.MessageBox('撤销检验成功!', '提示信息'); CDS_Main.Delete; except application.MessageBox('撤销检验失败!', '提示信息', 0); end; end; procedure TfrmCPBRKList.Button3Click(Sender: TObject); begin Panel3.Visible := False; end; procedure TfrmCPBRKList.ToolButton4Click(Sender: TObject); begin if CDS_Main.IsEmpty then Exit; try frmFjList_RZ := TfrmFjList_RZ.Create(Application); with frmFjList_RZ do begin fkeyNO := Trim(Self.CDS_Main.fieldbyname('SPId').AsString); fType := '纱线入库'; if ShowModal = 1 then begin end; end; finally frmFjList_RZ.Free; end; end; procedure TfrmCPBRKList.btnChkClick(Sender: TObject); begin try with ADOQueryCmd do begin close; sql.Clear; sql.Add('update CK_SXPB_CR SET chkstatus=''1'',Chktime=getdate() '); sql.Add(',Chker=' + quotedstr(Trim(DName))); sql.Add(',JYNote=' + quotedstr(Trim(MMJYNote.Text))); sql.Add('where SPID=' + quotedstr(trim(edtSPID.Text))); 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('入库审核'))); sql.Add(',' + quotedstr(trim('入库单号:' + trim(edtSPID.Text)))); sql.Add(',' + quotedstr(trim('成功'))); sql.Add(')'); execsql; end; application.MessageBox('检验成功!', '提示信息'); CDS_Main.Delete; Panel3.Visible := False; except application.MessageBox('检验失败!', '提示信息', 0); end; end; procedure TfrmCPBRKList.btnJYClick(Sender: TObject); begin edtSPID.Text := Trim(Self.CDS_Main.fieldbyname('SPID').AsString); MMJYNote.Text := Trim(Self.CDS_Main.fieldbyname('JYNote').AsString); Panel3.Visible := true; end; procedure TfrmCPBRKList.cxTabControl1Change(Sender: TObject); begin SetStatus(); InitGrid(); end; procedure TfrmCPBRKList.ToolButton1Click(Sender: TObject); begin if CDS_Main.IsEmpty then Exit; try frmFjList_RZ := TfrmFjList_RZ.Create(Application); with frmFjList_RZ do begin fkeyNO := Trim(Self.CDS_Main.fieldbyname('SPID').AsString); fType := '成品入库'; if ShowModal = 1 then begin end; end; finally frmFjList_RZ.Free; end; end; procedure TfrmCPBRKList.ToolButton3Click(Sender: TObject); var fPrintFile: string; Txt, fImagePath: string; Moudle: THandle; Makebar: TMakebar; Mixtext: TMixtext; begin if CDS_Main.IsEmpty then Exit; //if Trim(CDS_Main.fieldbyname('CRType').AsString)<>'检验出库' then Exit; if CDS_Main.Locate('SSel', True, []) = False then begin Application.MessageBox('没有选择数据!', '提示', 0); Exit; end; ExportFtErpFile(Trim(combobox1.Text) + '.rmf', ADOQueryTemp); fPrintFile := ExtractFilePath(Application.ExeName) + 'Report\' + Trim(combobox1.Text) + '.rmf'; CDS_Main.DisableControls; with CDS_Main do begin First; while CDS_Main.Locate('SSel', True, []) do begin if Trim(combobox1.Text) = '外销码单' then begin with ADOQueryPrint do begin Close; sql.Clear; sql.Add('select D.MainId,D.SubId, '); sql.Add('B.MXQty ,B.MXQTY2,MXMJXH,C.*,D.*,B.MXNOTE'); sql.Add('from CK_SXPB_CR A'); sql.Add('INNER JOIN CK_SXPB_CRMX B ON A.SPID=B.CRNO'); sql.Add('INNER JOIN JYOrder_Main C ON C.MainId=A.ORDMainIdRK'); sql.Add('INNER JOIN JYOrder_Sub D ON A.ORDSubIdRK=D.SUBID '); sql.Add('WHERE A.SPID=' + quotedstr(CDS_Main.fieldbyname('SPID').asstring)); sql.Add('and B.crzt=''入库'''); sql.Add(' AND NOT EXISTS(SELECT MXID FROM CK_SXPB_CRMX E WHERE E.FZMXID=B.MXID) '); sql.Add('order by D.subid,GangNo,MXID'); Open; end; SCreateCDS20(ADOQueryPrint, CDS_HZ); SInitCDSData20(ADOQueryPrint, CDS_HZ); end; if Trim(combobox1.Text) = '内销码单' then begin with ADOQueryPrint do begin Close; sql.Clear; sql.add('exec P_Print_CKMDYDLS2 ' + quotedstr(CDS_Main.fieldbyname('SPID').asstring)); Open; end; SCreateCDS20(ADOQueryPrint, CDS_HZ); SInitCDSData20(ADOQueryPrint, CDS_HZ); end; with ADOQueryPrint do begin Close; sql.Clear; sql.add('exec P_Do_PrintMd_HZ '); sql.add('@SPID=' + quotedstr(CDS_Main.fieldbyname('SPID').asstring)); Open; end; SCreateCDS20(ADOQueryPrint, CDS_PRT); SInitCDSData20(ADOQueryPrint, CDS_PRT); // // try // Moudle := LoadLibrary('MakeQRBarcode.dll'); // @Makebar := GetProcAddress(Moudle, 'Make'); // @Mixtext := GetProcAddress(Moudle, 'MixText'); // Txt := Trim(CDS_PRT.fieldbyname('SPID').AsString); // fImagePath := ExtractFilePath(Application.ExeName) + 'image\temp.bmp'; // if not DirectoryExists(pchar(ExtractFilePath(Application.ExeName) + 'image')) then // CreateDirectory(pchar(ExtractFilePath(Application.ExeName) + 'image'), nil); // if FileExists(fImagePath) then // DeleteFile(fImagePath); // Makebar(pchar(Txt), Length(Txt), 3, 3, 0, PChar(fImagePath), 3); // except // CDS_Main.EnableControls; // application.MessageBox('条形码生成失败!', '提示信息', MB_ICONERROR); // exit; // end; if FileExists(fPrintFile) then begin // RMVariables['QRBARCODE'] := fImagePath; RM1.LoadFromFile(fPrintFile); RM1.ShowReport; // RM1.PrintReport; end else begin CDS_Main.EnableControls; Application.MessageBox(PChar('没有找' + ExtractFilePath(Application.ExeName) + 'Report\' + Trim(combobox1.Text) + '.rmf'), '提示', 0); Exit; end; Edit; FieldByName('SSel').Value := False; Post; end; end; CDS_Main.EnableControls; end; procedure TfrmCPBRKList.ToolButton2Click(Sender: TObject); begin if CDS_Main.IsEmpty = true then begin exit; end; if CDS_Main.fieldbyname('ssel').value <> true then begin Application.MessageBox('没有选择数据或勾选数据不准确!', '提示', 0); Exit; end; frmCPCKMXLR := TfrmCPCKMXLR.create(self); with frmCPCKMXLR do begin fkeyNo := self.CDS_Main.fieldbyname('spid').AsString; FMXGangHao := self.CDS_Main.fieldbyname('Gangno').AsString; Edit3.Text := self.CDS_Main.fieldbyname('qtyunit').AsString; Edit2.Text := self.CDS_Main.fieldbyname('FZSPID').AsString; FCRTYPE := '入库'; fType := 0; if showmodal = 1 then begin // self.InitGrid(); // self.CDS_Main.Locate('spid', fkeyNo, []) end; free; end; end; end.