unit U_LLKCList; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, Dialogs, StdCtrls, ExtCtrls, ComCtrls, ToolWin, cxStyles, cxCustomData, cxGraphics, cxFilter, cxData, cxDataStorage, cxEdit, DB, cxDBData, ADODB, cxGridCustomPopupMenu, cxGridPopupMenu, cxGridLevel, cxClasses, cxControls, cxGridCustomView, cxGridCustomTableView, cxGridTableView, cxGridDBTableView, cxGrid, DBClient, cxCheckBox, cxCalendar, cxSplitter, RM_Dataset, RM_System, RM_Common, RM_Class, RM_GridReport, RM_e_Xls, Menus, cxButtonEdit, cxDropDownEdit, cxPC, Buttons, cxTextEdit, cxLookAndFeels, cxLookAndFeelPainters, cxNavigator, dxSkinsCore, dxSkinDarkRoom, dxSkinOffice2013White, dxSkinSharpPlus, dxSkinSpringTime, dxSkinsDefaultPainters, dxSkinscxPCPainter, BtnEdit, dxBarBuiltInMenu, dxSkinBlack, dxSkinBlue, dxSkinBlueprint, dxSkinCaramel, dxSkinCoffee, dxSkinDarkSide, dxSkinDevExpressDarkStyle, dxSkinDevExpressStyle, dxSkinFoggy, dxSkinGlassOceans, dxSkinHighContrast, dxSkiniMaginary, dxSkinLilian, dxSkinLiquidSky, dxSkinLondonLiquidSky, dxSkinMcSkin, dxSkinMetropolis, dxSkinMetropolisDark, dxSkinMoneyTwins, dxSkinOffice2007Black, dxSkinOffice2007Blue, dxSkinOffice2007Green, dxSkinOffice2007Pink, dxSkinOffice2007Silver, dxSkinOffice2010Black, dxSkinOffice2010Blue, dxSkinOffice2010Silver, dxSkinOffice2013DarkGray, dxSkinOffice2013LightGray, dxSkinPumpkin, dxSkinSeven, dxSkinSevenClassic, dxSkinSharp, dxSkinSilver, dxSkinStardust, dxSkinSummer2008, dxSkinTheAsphaltWorld, dxSkinValentine, dxSkinVS2010, dxSkinWhiteprint, dxSkinXmas2008Blue; type TfrmLLKCList = class(TForm) ToolBar1: TToolBar; TBRafresh: TToolButton; TBFind: TToolButton; TBAdd: TToolButton; TBClose: TToolButton; Tv1: TcxGridDBTableView; cxGrid1Level1: TcxGridLevel; cxGrid1: TcxGrid; cxGridPopupMenu1: TcxGridPopupMenu; ADOQueryCmd: TADOQuery; ADOQueryMain: TADOQuery; ADOQueryTemp: TADOQuery; DS_Main: TDataSource; TBExport: TToolButton; Order_Main: TClientDataSet; ToolButton1: TToolButton; Panel1: TPanel; Label34: TLabel; v1Column7: TcxGridDBColumn; v1Column9: TcxGridDBColumn; KHNameHZ: TEdit; BegDate: TDateTimePicker; EndDate: TDateTimePicker; RM1: TRMGridReport; RMDBMain: TRMDBDataSet; RMXLSExport2: TRMXLSExport; CDS_PRT: TClientDataSet; v1Column5: TcxGridDBColumn; Label2: TLabel; MYName: TEdit; v1Column2: TcxGridDBColumn; Label1: TLabel; Note: TEdit; labMYType: TLabel; Panel2: TPanel; SpeedButton1: TSpeedButton; PopupMenu1: TPopupMenu; N1: TMenuItem; N2: TMenuItem; CheckBox1: TCheckBox; v1JCDanWeiJC: TcxGridDBColumn; Label3: TLabel; JCDanWeiJC: TEdit; v1filler: TcxGridDBColumn; Label4: TLabel; filler: TEdit; ToolButton2: TToolButton; CDS_2: TClientDataSet; SpeedButton2: TSpeedButton; SpeedButton3: TSpeedButton; SpeedButton4: TSpeedButton; SpeedButton5: TSpeedButton; SpeedButton6: TSpeedButton; SpeedButton7: TSpeedButton; SpeedButton8: TSpeedButton; SpeedButton9: TSpeedButton; SpeedButton10: TSpeedButton; SpeedButton11: TSpeedButton; SpeedButton12: TSpeedButton; SpeedButton13: TSpeedButton; SpeedButton14: TSpeedButton; SpeedButton15: TSpeedButton; Image2: TImage; v1Column4: TcxGridDBColumn; v1Column10: TcxGridDBColumn; Label5: TLabel; MYTypeFlag: TComboBox; v1Column11: TcxGridDBColumn; v1Column12: TcxGridDBColumn; Label6: TLabel; MLOrderNo: TEdit; Label7: TLabel; v1Column13: TcxGridDBColumn; Tv1Column1: TcxGridDBColumn; Label8: TLabel; PBBatchNo: TEdit; Tv1Column3: TcxGridDBColumn; Tv1Column4: TcxGridDBColumn; Tv1Column5: TcxGridDBColumn; Label9: TLabel; MYColor: TEdit; Tv1Column6: TcxGridDBColumn; Tv1Column7: TcxGridDBColumn; Tv1Column8: TcxGridDBColumn; ToolButton3: TToolButton; Panel3: TPanel; Label10: TLabel; ComboBox1: TComboBox; Label11: TLabel; CDZSD: TBtnEditC; Button1: TButton; Button2: TButton; Tv1Column9: TcxGridDBColumn; ToolButton4: TToolButton; ADOQueryPrint: TADOQuery; RM2: TRMGridReport; RMDB_Main: TRMDBDataSet; Panel4: TPanel; Label12: TLabel; Label13: TLabel; Button3: TButton; Button4: TButton; GJ: TEdit; MS: TEdit; ToolButton6: TToolButton; ToolButton5: TToolButton; ZKZT: TBtnEditC; Label14: TLabel; Tv1Column2: TcxGridDBColumn; cxTabControl1: TcxTabControl; ToolButton7: TToolButton; PopupMenu2: TPopupMenu; MenuItem1: TMenuItem; MenuItem2: TMenuItem; Tv1Column10: TcxGridDBColumn; ToolButton8: TToolButton; Panel5: TPanel; Label15: TLabel; Button5: TButton; Button6: TButton; KW: TEdit; PageControl1: TPageControl; TabSheet1: TTabSheet; cxGrid2: TcxGrid; TV2: TcxGridDBTableView; TV2Ssel: TcxGridDBColumn; TV2KHName: TcxGridDBColumn; TV2KHNo: TcxGridDBColumn; TV2MYType: TcxGridDBColumn; TV2PS: TcxGridDBColumn; Tv2Qty: TcxGridDBColumn; TV2KgQty: TcxGridDBColumn; TV2Note: TcxGridDBColumn; cxGridLevel1: TcxGridLevel; TabSheet2: TTabSheet; cxGrid3: TcxGrid; TV3: TcxGridDBTableView; TV3Ssel: TcxGridDBColumn; TV3MLOrderNo: TcxGridDBColumn; TV3KHCode: TcxGridDBColumn; TV3KHName: TcxGridDBColumn; TV3CRTime: TcxGridDBColumn; TV3PBBatchNo: TcxGridDBColumn; TV3GYSNo: TcxGridDBColumn; TV3KHNameJC: TcxGridDBColumn; TV3KHNameJCDH: TcxGridDBColumn; TV3MYType: TcxGridDBColumn; TV3MYName: TcxGridDBColumn; TV3MYColor: TcxGridDBColumn; TV3MYColorNo: TcxGridDBColumn; TV3filler: TcxGridDBColumn; TV3RCGangNo: TcxGridDBColumn; TV3JH: TcxGridDBColumn; TV3JKGQTY: TcxGridDBColumn; TV3JMQTY: TcxGridDBColumn; TV3MYMF: TcxGridDBColumn; TV3MYKZ: TcxGridDBColumn; TV3SJKZ: TcxGridDBColumn; TV3Note: TcxGridDBColumn; TV3RCColor: TcxGridDBColumn; TV3ZKZT: TcxGridDBColumn; TV3CDZSD: TcxGridDBColumn; TV3KW: TcxGridDBColumn; cxGridLevel2: TcxGridLevel; TabSheet3: TTabSheet; cxGrid4: TcxGrid; TV4: TcxGridDBTableView; TV4RCGangNo: TcxGridDBColumn; TV4JH: TcxGridDBColumn; TV4KgQty: TcxGridDBColumn; TV4MQty: TcxGridDBColumn; cxGridLevel4: TcxGridLevel; ADOQuery3: TADOQuery; ADOQuery2: TADOQuery; CDS_3: TClientDataSet; CDS_Sub: TClientDataSet; DS_2: TDataSource; DS_3: TDataSource; DS_Sub: TDataSource; KHName: TComboBox; procedure FormDestroy(Sender: TObject); procedure FormClose(Sender: TObject; var Action: TCloseAction); procedure FormCreate(Sender: TObject); procedure TBCloseClick(Sender: TObject); procedure TBFindClick(Sender: TObject); procedure TBExportClick(Sender: TObject); procedure TBRafreshClick(Sender: TObject); procedure TBAddClick(Sender: TObject); procedure FormShow(Sender: TObject); procedure CheckBox1Click(Sender: TObject); procedure CheckBox2Click(Sender: TObject); procedure ToolButton1Click(Sender: TObject); procedure CustomerNoNameChange(Sender: TObject); procedure N2Click(Sender: TObject); procedure N1Click(Sender: TObject); procedure cxTabControl1Change(Sender: TObject); procedure ZJStatusChange(Sender: TObject); procedure Tv1DblClick(Sender: TObject); procedure Image2Click(Sender: TObject); procedure SpeedButton1Click(Sender: TObject); procedure ToolButton2Click(Sender: TObject); procedure v1Column1CustomDrawCell(Sender: TcxCustomGridTableView; ACanvas: TcxCanvas; AViewInfo: TcxGridTableDataCellViewInfo; var ADone: Boolean); procedure v1Column17CustomDrawCell(Sender: TcxCustomGridTableView; ACanvas: TcxCanvas; AViewInfo: TcxGridTableDataCellViewInfo; var ADone: Boolean); procedure v1Column3CustomDrawCell(Sender: TcxCustomGridTableView; ACanvas: TcxCanvas; AViewInfo: TcxGridTableDataCellViewInfo; var ADone: Boolean); procedure ToolButton3Click(Sender: TObject); procedure Button2Click(Sender: TObject); procedure CDZSDBtnDnClick(Sender: TObject); procedure CDZSDBtnUpClick(Sender: TObject); procedure Button1Click(Sender: TObject); procedure ToolButton4Click(Sender: TObject); // procedure ToolButton5Click(Sender: TObject); procedure ToolButton6Click(Sender: TObject); procedure Button4Click(Sender: TObject); procedure Button3Click(Sender: TObject); procedure ToolButton5Click(Sender: TObject); procedure ZKZTBtnDnClick(Sender: TObject); procedure ZKZTBtnUpClick(Sender: TObject); procedure ToolButton7Click(Sender: TObject); procedure MenuItem1Click(Sender: TObject); procedure MenuItem2Click(Sender: TObject); procedure ToolButton8Click(Sender: TObject); procedure Button6Click(Sender: TObject); procedure Button5Click(Sender: TObject); procedure Tv1FocusedRecordChanged(Sender: TcxCustomGridTableView; APrevFocusedRecord, AFocusedRecord: TcxCustomGridRecord; ANewItemRecordFocusingChanged: Boolean); private FGXName: string; DQdate: TDateTime; procedure InitGrid(); procedure InitForm(); function DelData(): Boolean; procedure initGX(); procedure SetStatus(); procedure InitSubGrid(); { Private declarations } public FFInt, FCloth: Integer; canshu1: string; { Public declarations } end; var frmLLKCList: TfrmLLKCList; implementation uses U_DataLink, U_RTFun, U_ZDYHelp, U_LLRKInPutMH_RCCG, U_ZSDXZ; {$R *.dfm} procedure TfrmLLKCList.SetStatus(); begin ToolButton3.Visible := false; ToolButton7.Visible := false; ToolButton5.Visible := false; ToolButton6.Visible := false; case cxTabControl1.TabIndex of 0: begin ToolButton3.Visible := true; ToolButton5.Visible := true; ToolButton6.Visible := true; end; 1: begin ToolButton7.Visible := true; end; end; end; procedure TfrmLLKCList.FormDestroy(Sender: TObject); begin frmLLKCList := nil; end; procedure TfrmLLKCList.FormClose(Sender: TObject; var Action: TCloseAction); begin Action := caFree; end; procedure TfrmLLKCList.FormCreate(Sender: TObject); begin cxgrid1.Align := alClient; canshu1 := Trim(DParameters1); end; procedure TfrmLLKCList.TBCloseClick(Sender: TObject); begin WriteCxGrid('来料库存汇总主表', Tv1, '库存贸易生产管理'); WriteCxGrid('来料库存汇总子表', TV4, '库存贸易生产管理'); Close; end; procedure TfrmLLKCList.InitGrid(); begin try ADOQueryMain.DisableControls; with ADOQueryMain do begin Filtered := False; Close; sql.Clear; sql.Add('select AA.* '); sql.Add(',KHNameHZ=dbo.getpinyin(isnull(AA.KHNameJC,''''))+AA.GYSNo+isnull(AA.KHNameJC,'''')'); sql.Add('from('); sql.Add(' select A.*,D.KGQTY as mxkgqty ,D.MQTY as mxmqty ,D.MXID,D.CDZSD,D.Fsubid,D.CMXID,D.ZKZT,D.JH,D.KW'); sql.Add(',KHNameJC=(select Top 1 B.KHNameJC from KH_Main B '); sql.Add(' where isnull(B.KHFlag,'''')=''GYS'' and isnull(B.Valid,'''')=''Y'' and B.KHNO=A.GYSNo)'); sql.Add(',KHNameJCDH=(select Top 1 B.KHNameJC from KH_Main B '); sql.Add(' where isnull(B.KHFlag,'''')=''GYS'' and isnull(B.Valid,'''')=''Y'' and B.KHNO=A.ToGYSNo)'); sql.Add(',KHNameHZZ=dbo.getpinyin(isnull(KM.KHNameJC,''''))+B.KHNO+isnull(KM.KHNameJC,'''')'); sql.Add(',KHNameJCZ=KM.KHNameJC,B.MLOrderNo,KHNOKH=B.KHNO'); sql.Add(' from CK_MYSC_CR A '); sql.Add(' left join CK_MYSC_CR_MX D on D.MYID=A.MYID'); sql.Add(' left join ML_OrderMainNew B on A.MainId=B.NewMLID'); sql.Add(' left join KH_Main KM on KM.KHNO=B.KHNO '); sql.Add(' where 1=1 '); if CheckBox1.Checked = False then begin sql.Add(' and A.CRTime>=''' + Trim(FormatDateTime('yyyy-MM', now) + '-01') + ''''); sql.Add(' and A.CRTime<''' + Trim(FormatDateTime('yyyy-MM-dd', now + 1)) + ''''); BegDate.Visible := false; EndDate.Visible := false; end else begin sql.Add(' and A.CRTime>=''' + Trim(FormatDateTime('yyyy-MM-dd', BegDate.Date)) + ''''); sql.Add(' and A.CRTime<''' + Trim(FormatDateTime('yyyy-MM-dd', EndDate.Date + 1)) + ''''); BegDate.Visible := true; EndDate.Visible := true; end; sql.Add(' and isnull(CRType,'''')=''来料入库'' '); if cxTabControl1.TabIndex = 0 then begin sql.Add(' and isnull(D.ZKZT,'''')=''在库'' '); end else begin sql.Add(' and (isnull(D.ZKZT,'''')<> ''在库'' and isnull(D.ZKZT,'''')<> '''' ) '); end; // if canshu1<>'高权限' then // begin // sql.add(' and A.filler='''+trim(DName)+''''); // end; sql.Add(')AA'); // ShowMessage(SQL.text); Open; end; SCreateCDS20(ADOQueryMain, Order_Main); SInitCDSData20(ADOQueryMain, Order_Main); InitSubGrid(); finally ADOQueryMain.EnableControls; end; end; procedure TfrmLLKCList.InitSubGrid(); var MYID: string; begin if Order_Main.IsEmpty then exit; try ADOQueryTemp.DisableControls; MYID := Order_Main.FieldByName('MYID').AsString; with ADOQueryTemp do begin Filtered := False; Close; sql.Clear; sql.Add('SELECT * FROM CK_MYSC_CR_MX WHERE MYID = ''' + MYID + ''''); Open; end; SCreateCDS20(ADOQueryTemp, CDS_Sub); SInitCDSData20(ADOQueryTemp, CDS_Sub); finally ADOQueryTemp.EnableControls; end; end; procedure TfrmLLKCList.InitForm(); var sql: string; begin BegDate.Date := StrToDate(formatdatetime('yyyy-MM', SGetServerDate(ADOQueryTemp)) + '-01'); EndDate.Date := SGetServerDate(ADOQueryTemp); ReadCxGrid('来料库存汇总主表', Tv1, '库存贸易生产管理'); ReadCxGrid('来料库存汇总子表', TV4, '库存贸易生产管理'); sql := 'select DISTINCT A.KHName AS Name from CK_MYSC_CR A where 1=1'; if CheckBox1.Checked = False then begin sql := sql + ' and A.CRTime>=''' + Trim(FormatDateTime('yyyy-MM-dd', now)) + ''''; sql := sql + ' and A.CRTime<''' + Trim(FormatDateTime('yyyy-MM-dd', now + 1)) + ''''; BegDate.Visible := false; EndDate.Visible := false; end else begin sql := sql + ' and A.CRTime>=''' + Trim(FormatDateTime('yyyy-MM-dd', BegDate.Date)) + ''''; sql := sql + ' and A.CRTime<''' + Trim(FormatDateTime('yyyy-MM-dd', EndDate.Date + 1)) + ''''; BegDate.Visible := true; EndDate.Visible := true; end; sql := sql + ' and isnull(CRType,'''')=''来料入库'' '; SInitComBoxBySql(ADOQueryTemp, KHName, False, sql); SetStatus(); InitGrid(); end; procedure TfrmLLKCList.TBFindClick(Sender: TObject); begin if ADOQueryMain.Active = False then Exit; SDofilter(ADOQueryMain, SGetFilters(Panel1, 1, 2)); SCreateCDS20(ADOQueryMain, Order_Main); SInitCDSData20(ADOQueryMain, Order_Main); end; function TfrmLLKCList.DelData(): Boolean; begin try Result := false; ADOQueryCmd.Connection.BeginTrans; Order_Main.DisableControls; with Order_Main do begin //First; // while Order_Main.Locate('SSel',True,[]) do begin with ADOQueryCmd do begin Close; sql.Clear; sql.Add(' delete YS_Money_CR where YFTypeId=''' + Trim(Order_Main.fieldbyname('MYID').AsString) + ''''); sql.Add(' insert into CK_MYSC_CR_Log '); sql.Add(' select * from CK_MYSC_CR where MYID=''' + Trim(Order_Main.fieldbyname('MYID').AsString) + ''''); sql.Add(' UPdate CK_MYSC_CR_Log Set DelTime=getdate(),DelerCode=''' + Trim(DCode) + ''',Deler=''' + Trim(DName) + ''''); sql.Add(' where MYID=''' + Trim(Order_Main.fieldbyname('MYID').AsString) + ''''); sql.Add(' Delete CK_MYSC_CR where MYId=''' + Trim(Order_Main.fieldbyname('MYId').AsString) + ''''); sql.Add(' delete from TP_File where WBID=''' + trim(Order_Main.fieldbyname('MYId').AsString) + ''' '); sql.Add(' and TFType=''来料入库'''); ExecSQL; end; Order_Main.Delete; end; end; Order_Main.EnableControls; ADOQueryCmd.Connection.CommitTrans; Result := True; except ADOQueryCmd.Connection.RollbackTrans; Result := False; Application.MessageBox('数据删除异常!', '提示', 0); end; end; procedure TfrmLLKCList.TBExportClick(Sender: TObject); begin if ADOQueryMain.IsEmpty then Exit; TcxGridToExcel(Self.Caption, cxGrid1); end; procedure TfrmLLKCList.TBRafreshClick(Sender: TObject); begin InitGrid(); TBFind.Click; end; procedure TfrmLLKCList.TBAddClick(Sender: TObject); begin Panel2.Visible := True; initGX(); end; procedure TfrmLLKCList.initGX(); var BB: array[0..100] of string; i, j: Integer; begin with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select ZDYName from KH_Zdy where Type=''JGGongXu'' '); //order by ZDYName Open; end; if ADOQueryTemp.IsEmpty then begin Application.MessageBox('没有定义数据!', '提示', 0); Exit; end; with ADOQueryTemp do begin First; i := 0; while not Eof do begin BB[i] := Trim(fieldbyname('ZDYName').AsString); i := i + 1; Next; end; end; i := i - 1; if i > 14 then begin i := 14; end; for j := 0 to i do begin with Panel2 do begin TSpeedButton(Controls[j]).Visible := True; TSpeedButton(Controls[j]).Caption := BB[j]; end; end; end; procedure TfrmLLKCList.FormShow(Sender: TObject); begin InitForm(); end; procedure TfrmLLKCList.CheckBox1Click(Sender: TObject); begin InitGrid(); end; procedure TfrmLLKCList.CheckBox2Click(Sender: TObject); begin TBRafresh.Click; end; procedure TfrmLLKCList.ToolButton1Click(Sender: TObject); var FFMYType: string; begin FFMYType := Trim(Order_Main.fieldbyname('MYType').AsString); try frmLLRKInPutMH_RCCG := TfrmLLRKInPutMH_RCCG.Create(Application); with frmLLRKInPutMH_RCCG do begin PState := 1; FMainId := Trim(Self.Order_Main.fieldbyname('MYId').AsString); FMYType := Trim(Self.Order_Main.fieldbyname('MYType').AsString); FMYTypeFlag := Trim(Self.Order_Main.fieldbyname('MYTypeFlag').AsString); labMYType.Caption := Trim(Self.Order_Main.fieldbyname('MYTypeFlag').AsString); if ShowModal = 1 then begin end; end; finally frmLLRKInPutMH_RCCG.Free; end; end; procedure TfrmLLKCList.CustomerNoNameChange(Sender: TObject); begin if ADOQueryMain.Active = False then Exit; SDofilter(ADOQueryMain, SGetFilters(Panel1, 1, 2)); SCreateCDS20(ADOQueryMain, Order_Main); SInitCDSData20(ADOQueryMain, Order_Main); end; procedure TfrmLLKCList.N2Click(Sender: TObject); begin if Order_Main.IsEmpty then Exit; if Trim(canshu1) <> '高权限' then begin // if Order_Main.FieldByName('filltime').AsDateTime+1'''' '); sql.Add(' or isnull(ChkerQ,'''')<>'''') '); Open; end; if ADOQueryTemp.IsEmpty = false then begin Application.MessageBox('应付款已审核,不能删除', '提示'); exit; end; if Application.MessageBox('确定要删除数据吗?', '提示', 32 + 4) <> IDYES then Exit; if DelData() then begin end; end; procedure TfrmLLKCList.N1Click(Sender: TObject); var FFMYType: string; begin if Order_Main.IsEmpty then Exit; if Trim(canshu1) <> '高权限' then begin // if Order_Main.FieldByName('filltime').AsDateTime+1 (AViewInfo.GridRecord.Values[Id10]) then begin ACanvas.Brush.Color := clRed; end; end; procedure TfrmLLKCList.v1Column17CustomDrawCell(Sender: TcxCustomGridTableView; ACanvas: TcxCanvas; AViewInfo: TcxGridTableDataCellViewInfo; var ADone: Boolean); var Id, Id10: Integer; begin Id := TV1.GetColumnByFieldName('KgQty').Index; Id10 := TV1.GetColumnByFieldName('MXHZKgQty').Index; if (AViewInfo.GridRecord.Values[Id]) <> (AViewInfo.GridRecord.Values[Id10]) then begin ACanvas.Brush.Color := clRed; end; end; procedure TfrmLLKCList.v1Column3CustomDrawCell(Sender: TcxCustomGridTableView; ACanvas: TcxCanvas; AViewInfo: TcxGridTableDataCellViewInfo; var ADone: Boolean); var Id, Id10: Integer; begin Id := TV1.GetColumnByFieldName('Qty').Index; Id10 := TV1.GetColumnByFieldName('MXHZQty').Index; if (AViewInfo.GridRecord.Values[Id]) <> (AViewInfo.GridRecord.Values[Id10]) then begin ACanvas.Brush.Color := clRed; end; end; procedure TfrmLLKCList.ToolButton3Click(Sender: TObject); begin if Order_Main.IsEmpty then Exit; Panel3.Left := (self.Width - Panel3.Width) div 2; Panel3.Visible := true; end; procedure TfrmLLKCList.Button2Click(Sender: TObject); begin Panel3.Visible := False; end; procedure TfrmLLKCList.CDZSDBtnDnClick(Sender: TObject); begin TBtnEditC(Sender).Text := ''; TBtnEditC(Sender).TxtCode := ''; end; procedure TfrmLLKCList.CDZSDBtnUpClick(Sender: TObject); begin try frmzsdxz := Tfrmzsdxz.Create(Application); with frmzsdxz do begin if ShowModal = 1 then begin Self.CDZSD.Text := Trim(frmzsdxz.Order_Main.fieldbyname('MLOrderNo').AsString); Self.CDZSD.TxtCode := Trim(frmzsdxz.Order_Main.fieldbyname('NewSubid').AsString); end; end; finally frmzsdxz.Free; end; end; procedure TfrmLLKCList.Button1Click(Sender: TObject); begin if Order_Main.IsEmpty then Exit; if Order_Main.Locate('SSel', True, []) = False then begin Application.MessageBox('没有选择数据!', '提示', 0); Exit; end; // if Trim(ComboBox1.text) = '' then // begin // Application.MessageBox('布匹类型不能为空!', '提示', 0); // Exit; // end; try Order_Main.DisableControls; ADOQueryCmd.Connection.BeginTrans; with Order_Main do begin First; while not Eof do begin if Order_Main.FieldByName('SSel').AsBoolean = True then begin with ADOQueryCmd do begin Close; sql.Clear; // sql.Add('Update CK_MYSC_CR_MX Set BPLX=''' + trim(ComboBox1.Text) + ''' '); sql.Add('Update CK_MYSC_CR_MX Set '); sql.Add('CDZSD=''' + trim(CDZSD.Text) + ''' '); sql.Add(', CDmainid=''' + trim(CDZSD.TxtCode) + ''' '); sql.Add(', ZKZT=''' + trim(ZKZT.Text) + ''' '); sql.Add('where MXID=''' + Trim(Order_Main.fieldbyname('MXID').AsString) + ''''); ExecSQL; end; end; Next; end; end; ADOQueryCmd.Connection.CommitTrans; Order_Main.EnableControls; application.MessageBox('数据保存成功!', '提示信息'); Panel3.Visible := false; TBRafresh.Click; except ADOQueryCmd.Connection.RollbackTrans; Order_Main.EnableControls; application.MessageBox('数据保存失败!', '提示信息', 0); end; end; procedure TfrmLLKCList.ToolButton4Click(Sender: TObject); var fPrintFile: string; Txt, fImagePath: string; Moudle: THandle; Makebar: TMakebar; Mixtext: TMixtext; CurRow: Integer; begin if Order_Main.IsEmpty then Exit; if Order_Main.Locate('SSel', True, []) = False then begin Application.MessageBox('没有选择数据!', '提示', 0); Exit; end; Order_Main.DisableControls; with Order_Main do begin First; while not Eof do begin if Order_Main.FieldByName('SSel').AsBoolean = True then begin CurRow := Tv1.Controller.FocusedRowIndex; with ADOQueryPrint do begin Close; sql.Clear; sql.Add('select AA.* '); sql.Add(',KHNameHZ=dbo.getpinyin(isnull(AA.KHNameJC,''''))+AA.GYSNo+isnull(AA.KHNameJC,'''')'); sql.Add('from('); sql.Add(' select A.*,D.KGQTY as mxkgqty ,D.MQTY as mxmqty ,D.MXID,D.KCCDZSD,D.ZKZT,D.JH'); sql.Add(',KHNameJC=(select Top 1 B.KHNameJC from KH_Main B '); sql.Add(' where isnull(B.KHFlag,'''')=''GYS'' and isnull(B.Valid,'''')=''Y'' and B.KHNO=A.GYSNo)'); sql.Add(',KHNameJCDH=(select Top 1 B.KHNameJC from KH_Main B '); sql.Add(' where isnull(B.KHFlag,'''')=''GYS'' and isnull(B.Valid,'''')=''Y'' and B.KHNO=A.ToGYSNo)'); sql.Add(',KHNameHZZ=dbo.getpinyin(isnull(KM.KHNameJC,''''))+B.KHNO+isnull(KM.KHNameJC,'''')'); sql.Add(',KHNameJCZ=KM.KHNameJC,B.MLOrderNo,KHNOKH=B.KHNO'); sql.Add(' from CK_MYSC_CR A '); sql.Add(' left join CK_MYSC_CR_MX D on D.MYID=A.MYID'); sql.Add(' left join ML_OrderMainNew B on A.MainId=B.NewMLID'); sql.Add(' left join KH_Main KM on KM.KHNO=B.KHNO '); sql.Add(' where 1=1 and isnull(D.ZKZT,'''')<>'''' '); if CheckBox1.Checked = False then begin sql.Add(' and A.CRTime>=''' + Trim(FormatDateTime('yyyy-MM', now) + '-01') + ''''); sql.Add(' and A.CRTime<''' + Trim(FormatDateTime('yyyy-MM-dd', now + 1)) + ''''); BegDate.Visible := false; EndDate.Visible := false; end else begin sql.Add(' and A.CRTime>=''' + Trim(FormatDateTime('yyyy-MM-dd', BegDate.Date)) + ''''); sql.Add(' and A.CRTime<''' + Trim(FormatDateTime('yyyy-MM-dd', EndDate.Date + 1)) + ''''); BegDate.Visible := true; EndDate.Visible := true; end; sql.Add(' and isnull(CRType,'''')=''来料入库'' '); sql.Add('and D.MXID=''' + Trim(Order_Main.fieldbyname('MXID').AsString) + ''''); sql.Add(')AA'); Open; end; try Moudle := LoadLibrary('MakeQRBarcode.dll'); @Makebar := GetProcAddress(Moudle, 'Make'); @Mixtext := GetProcAddress(Moudle, 'MixText'); Txt := Trim(ADOQueryPrint.fieldbyname('MXID').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 application.MessageBox('条形码生成失败!', '提示信息', MB_ICONERROR); Order_Main.EnableControls; exit; end; // if Trim(ADOQueryPrint.fieldbyname('SLbName').AsString) <> '' then // begin // ExportFtErpFile(Trim(ADOQueryPrint.fieldbyname('SLbName').AsString), ADOQueryCmd); // fPrintFile := ExtractFilePath(Application.ExeName) + 'Report\' + Trim(ADOQueryPrint.fieldbyname('SLbName').AsString); // end // else // begin ExportFtErpFile('通用标签.rmf', ADOQueryCmd); fPrintFile := ExtractFilePath(Application.ExeName) + 'Report\面料库存标签.rmf'; // end; if FileExists(fPrintFile) then begin RMVariables['QRBARCODE'] := fImagePath; RM2.LoadFromFile(fPrintFile); RM2.ShowReport; // RM2.PrintReport; end else begin Order_Main.EnableControls; Application.MessageBox(PChar('没有找' + ExtractFilePath(Application.ExeName) + 'Report\面料库存标签.rmf'), '提示', 0); Exit; end; end; Next; end; end; Order_Main.EnableControls; Tv1.Controller.FocusedRowIndex := CurRow; end; procedure TfrmLLKCList.ToolButton6Click(Sender: TObject); begin if Order_Main.IsEmpty then Exit; if Order_Main.Locate('SSel', True, []) = False then begin Application.MessageBox('没有选择数据!', '提示', 0); Exit; end; // if Order_Main.IsEmpty then // Exit; Panel4.Left := (self.Width - Panel4.Width) div 2; Panel4.Visible := true; end; procedure TfrmLLKCList.Button4Click(Sender: TObject); begin Panel4.Visible := False; end; procedure TfrmLLKCList.Button3Click(Sender: TObject); var maxno: string; CRID, JH: Integer; ZL, CD: string; MaxCkNo, MaxCkSubNo: string; begin try ADOQueryCmd.Connection.BeginTrans; Order_Main.DisableControls; with Order_Main do begin if Order_Main.FieldByName('SSel').AsBoolean = True then begin if GetLSNo(ADOQueryCmd, maxno, 'MX', 'CK_MYSC_CR_MX', 4, 1) = False then begin ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('取出库最大号失败!', '提示', 0); Exit; end; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('select * from CK_MYSC_CR_MX where 1<>1'); Open; end; with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select count(*) as js from CK_MYSC_CR_MX where MYID=''' + Trim(Order_Main.fieldbyname('MYID').AsString) + ''''); Open; end; JH := StrToInt(Trim(ADOQueryTemp.fieldbyname('js').AsString)) + 1; with ADOQueryCmd do begin Append; FieldByName('Filler').Value := Trim(DName); FieldByName('MYID').Value := Trim(Order_Main.fieldbyname('MYID').AsString); FieldByName('MXID').Value := Trim(maxno); FieldByName('CMXID').Value := Trim(Order_Main.fieldbyname('MXID').AsString); FieldByName('FSubId').Value := Trim(Order_Main.fieldbyname('FSubId').AsString); FieldByName('KCCDZSD').Value := Trim(Order_Main.fieldbyname('KCCDZSD').AsString); FieldByName('KgQty').Value := strtofloatdef(trim(GJ.Text), 0); FieldByName('MQty').Value := strtofloatdef(trim(MS.Text), 0); FieldByName('ZKZT').Value := '在库'; FieldByName('JH').Value := JH; Post; end; ZL := floattostr(strtofloatdef(trim(GJ.Text), 0)); CD := floattostr(strtofloatdef(trim(MS.Text), 0)); with ADOQueryCmd do begin Close; sql.Clear; sql.Add('Update CK_MYSC_CR_MX set KgQty=KgQty-''' + ZL + ''' ,MQty=MQty -''' + CD + ''' where MXID=''' + Trim(Order_Main.fieldbyname('MXID').AsString) + ''' '); // sql.Add(' UPdate CK_MYSC_CR Set MXHZQty=(select Sum(MQty) from CK_MYSC_CR_MX A where A.MYID=CK_MYSC_CR.MYID) '); // sql.Add(' ,MXHZKgQty=(select Sum(KgQty) from CK_MYSC_CR_MX A where A.MYID=CK_MYSC_CR.MYID) '); // sql.Add(' ,MXHZPS=(select Count(*) from CK_MYSC_CR_MX A where A.MYID=CK_MYSC_CR.MYID) '); // sql.Add(' where MYID=''' + Trim(Order_Main.fieldbyname('MYID').AsString) + ''''); // sql.Add(' Update CK_MYSC_CR Set QtyChaE=isnull(MXHZQty,0)-isnull(Qty,0),KgQtyChaE=isnull(MXHZKgQty,0)-isnull(KgQty,0),PSChaE=isnull(MXHZPS,0)-isnull(PS,0) '); // sql.Add(' where MYID=''' + Trim(Order_Main.fieldbyname('MYID').AsString) + ''''); // showmessage(sql.text); ExecSQL; end; application.ProcessMessages; end; end; Order_Main.EnableControls; ADOQueryCmd.Connection.CommitTrans; Application.MessageBox('拆匹成功!', '提示', 0); Panel4.Visible := False; TBRafresh.Click; Exit; except Order_Main.EnableControls; ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('拆匹异常!', '提示', 0); Panel4.Visible := False; end; end; procedure TfrmLLKCList.ToolButton5Click(Sender: TObject); var ZL, CD: string; begin if Order_Main.IsEmpty then Exit; if Order_Main.Locate('SSel', True, []) = False then begin Application.MessageBox('没有选择数据!', '提示', 0); Exit; end; with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from CK_MYSC_CR_MX where MXID=''' + Trim(Order_Main.fieldbyname('MXID').AsString) + ''''); Open; end; if Trim(Order_Main.fieldbyname('CMXID').AsString) = '' then begin Application.MessageBox('此匹不是拆匹布,不能撤销拆匹!', '提示'); exit; end; try // Result := false; ADOQueryCmd.Connection.BeginTrans; Order_Main.DisableControls; with Order_Main do begin ZL := floattostr(strtofloatdef(Trim(Order_Main.fieldbyname('mxKgQty').AsString), 0)); CD := floattostr(strtofloatdef(Trim(Order_Main.fieldbyname('mxMQty').AsString), 0)); with ADOQueryCmd do begin Close; sql.Clear; sql.Add('Update CK_MYSC_CR_MX set KgQty=KgQty+''' + ZL + ''' ,MQty=MQty +''' + CD + ''' where MXID=''' + Trim(Order_Main.fieldbyname('CMXID').AsString) + ''' '); sql.Add(' Delete CK_MYSC_CR_MX where MXID=''' + Trim(Order_Main.fieldbyname('MXID').AsString) + ''''); // sql.Add(' UPdate CK_MYSC_CR Set MXHZQty=(select Sum(MQty) from CK_MYSC_CR_MX A where A.MYID=CK_MYSC_CR.MYID) '); // sql.Add(' ,MXHZKgQty=(select Sum(KgQty) from CK_MYSC_CR_MX A where A.MYID=CK_MYSC_CR.MYID) '); // sql.Add(' ,MXHZPS=(select Count(*) from CK_MYSC_CR_MX A where A.MYID=CK_MYSC_CR.MYID) '); // sql.Add(' where MYID=''' + Trim(Order_Main.fieldbyname('MYID').AsString) + ''''); // sql.Add(' Update CK_MYSC_CR Set QtyChaE=isnull(MXHZQty,0)-isnull(Qty,0),KgQtyChaE=isnull(MXHZKgQty,0)-isnull(KgQty,0),PSChaE=isnull(MXHZPS,0)-isnull(PS,0) '); // sql.Add(' where MYID=''' + Trim(Order_Main.fieldbyname('MYID').AsString) + ''''); ExecSQL; end; Order_Main.Delete; end; Order_Main.EnableControls; ADOQueryCmd.Connection.CommitTrans; // Result := True; Application.MessageBox('撤销拆匹成功!', '提示', 0); TBRafresh.Click; except ADOQueryCmd.Connection.RollbackTrans; // Result := False; Application.MessageBox('撤销拆匹异常!', '提示', 0); end; end; procedure TfrmLLKCList.ZKZTBtnDnClick(Sender: TObject); begin TBtnEditC(Sender).Text := ''; TBtnEditC(Sender).TxtCode := ''; end; procedure TfrmLLKCList.ZKZTBtnUpClick(Sender: TObject); begin try frmZDYHelp := TfrmZDYHelp.Create(Application); with frmZDYHelp do begin flag := 'ZKZT'; flagname := '出库状态'; V1Name.Caption := '出库状态'; if ShowModal = 1 then begin Self.ZKZT.Text := Trim(ClientDataSet1.fieldbyname('ZDYName').AsString); end; end; finally frmZDYHelp.Free; end; end; procedure TfrmLLKCList.ToolButton7Click(Sender: TObject); begin if Order_Main.IsEmpty then Exit; if Order_Main.Locate('SSel', True, []) = False then begin Application.MessageBox('没有选择数据!', '提示', 0); Exit; end; try Order_Main.DisableControls; ADOQueryCmd.Connection.BeginTrans; with Order_Main do begin First; while not Eof do begin if Order_Main.FieldByName('SSel').AsBoolean = True then begin with ADOQueryCmd do begin Close; sql.Clear; // sql.Add('Update CK_MYSC_CR_MX Set BPLX='''' '); sql.Add('Update CK_MYSC_CR_MX Set '); sql.Add(' CDZSD='''' '); sql.Add(', CDmainid='''' '); sql.Add(', ZKZT=''在库'' '); sql.Add('where MXID=''' + Trim(Order_Main.fieldbyname('MXID').AsString) + ''''); ExecSQL; end; end; Next; end; end; ADOQueryCmd.Connection.CommitTrans; Order_Main.EnableControls; application.MessageBox('数据保存成功!', '提示信息'); TBRafresh.Click; except ADOQueryCmd.Connection.RollbackTrans; Order_Main.EnableControls; application.MessageBox('数据保存失败!', '提示信息', 0); end; end; procedure TfrmLLKCList.MenuItem1Click(Sender: TObject); begin SelOKNoFilter(Tv1, True); end; procedure TfrmLLKCList.MenuItem2Click(Sender: TObject); begin SelOKNoFilter(Tv1, False); end; procedure TfrmLLKCList.ToolButton8Click(Sender: TObject); begin if Order_Main.IsEmpty then Exit; Panel5.Left := (self.Width - Panel5.Width) div 2; Panel5.Visible := true; end; procedure TfrmLLKCList.Button6Click(Sender: TObject); begin Panel5.Visible := false; end; procedure TfrmLLKCList.Button5Click(Sender: TObject); begin if Order_Main.IsEmpty then Exit; if Order_Main.Locate('SSel', True, []) = False then begin Application.MessageBox('没有选择数据!', '提示', 0); Exit; end; try Order_Main.DisableControls; ADOQueryCmd.Connection.BeginTrans; with Order_Main do begin First; while not Eof do begin if Order_Main.FieldByName('SSel').AsBoolean = True then begin with ADOQueryCmd do begin Close; sql.Clear; sql.Add('Update CK_MYSC_CR_MX Set '); sql.Add('KW=''' + trim(KW.Text) + ''' '); sql.Add('where MXID=''' + Trim(Order_Main.fieldbyname('MXID').AsString) + ''''); ExecSQL; end; end; Next; end; end; ADOQueryCmd.Connection.CommitTrans; Order_Main.EnableControls; application.MessageBox('数据保存成功!', '提示信息'); Panel5.Visible := false; TBRafresh.Click; except ADOQueryCmd.Connection.RollbackTrans; Order_Main.EnableControls; application.MessageBox('数据保存失败!', '提示信息', 0); end; end; procedure TfrmLLKCList.Tv1FocusedRecordChanged(Sender: TcxCustomGridTableView; APrevFocusedRecord, AFocusedRecord: TcxCustomGridRecord; ANewItemRecordFocusingChanged: Boolean); begin InitSubGrid(); end; end.