unit U_DJBCKInPut2; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, Dialogs, cxStyles, cxCustomData, cxGraphics, cxFilter, cxData, cxDataStorage, cxEdit, DB, cxDBData, cxCalendar, cxDropDownEdit, ComCtrls, ToolWin, cxGridLevel, cxGridCustomTableView, cxGridTableView, cxGridDBTableView, cxClasses, cxControls, cxGridCustomView, cxGrid, cxGridCustomPopupMenu, cxGridPopupMenu, ADODB, DBClient, cxButtonEdit, cxTextEdit, StdCtrls, ExtCtrls, cxLookAndFeels, cxLookAndFeelPainters, cxNavigator, dxSkinsCore, dxSkinsDefaultPainters, dxSkinscxPCPainter; type TfrmDJBCKInPut2 = class(TForm) cxGrid2: TcxGrid; Tv1: TcxGridDBTableView; v1Column2: TcxGridDBColumn; v2Column1: TcxGridDBColumn; v1Column9: TcxGridDBColumn; v2Column6: TcxGridDBColumn; cxGrid2Level1: TcxGridLevel; ToolBar1: TToolBar; TBAdd: TToolButton; TBDel: TToolButton; TBSave: TToolButton; TBClose: TToolButton; v1Column4: TcxGridDBColumn; DataSource3: TDataSource; CDS_Sub: TClientDataSet; ADOQueryCmd: TADOQuery; ADOQueryMain: TADOQuery; ADOQueryTemp: TADOQuery; cxGridPopupMenu2: TcxGridPopupMenu; v1Column12: TcxGridDBColumn; v1Column14: TcxGridDBColumn; v1Column6: TcxGridDBColumn; v1Column3: TcxGridDBColumn; v1Column11: TcxGridDBColumn; v1Column13: TcxGridDBColumn; v1Column16: TcxGridDBColumn; v1Column15: TcxGridDBColumn; ToolButton1: TToolButton; ToolButton2: TToolButton; Panel4: TPanel; Label14: TLabel; Panel10: TPanel; Image2: TImage; Button1: TButton; GroupBox1: TGroupBox; CheckBox1: TCheckBox; CheckBox2: TCheckBox; CheckBox3: TCheckBox; CheckBox4: TCheckBox; CheckBox5: TCheckBox; CheckBox6: TCheckBox; CheckBox7: TCheckBox; CheckBox8: TCheckBox; CheckBox9: TCheckBox; Button2: TButton; Panel2: TPanel; cxGrid1: TcxGrid; TvMX: TcxGridDBTableView; cxGridDBColumn8: TcxGridDBColumn; cxGridLevel2: TcxGridLevel; ToolBar2: TToolBar; ToolButton3: TToolButton; ToolButton4: TToolButton; CDS_MX: TClientDataSet; DS_MX: TDataSource; ToolButton5: TToolButton; v1Column5: TcxGridDBColumn; chk1: TCheckBox; cv1Column1: TcxGridDBColumn; cv1Column2: TcxGridDBColumn; Tv1Column1: TcxGridDBColumn; Tv1Column2: TcxGridDBColumn; Tv1Column3: TcxGridDBColumn; procedure FormClose(Sender: TObject; var Action: TCloseAction); procedure TBAddClick(Sender: TObject); procedure TBCloseClick(Sender: TObject); procedure FormShow(Sender: TObject); procedure TBDelClick(Sender: TObject); procedure TBSaveClick(Sender: TObject); procedure v1Column3PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); procedure v1Column14PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); procedure v2Column1PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); procedure v1Column5PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); procedure v1Column11PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); procedure v1Column16PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); procedure v1Column13PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); procedure v1Column18PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); procedure ToolButton1Click(Sender: TObject); procedure Button2Click(Sender: TObject); procedure ToolButton2Click(Sender: TObject); procedure Image2Click(Sender: TObject); procedure Button1Click(Sender: TObject); procedure ToolButton3Click(Sender: TObject); procedure Tv1MouseDown(Sender: TObject; Button: TMouseButton; Shift: TShiftState; X, Y: Integer); procedure cxGridDBColumn8PropertiesEditValueChanged(Sender: TObject); procedure ToolButton4Click(Sender: TObject); procedure TvMXCustomDrawIndicatorCell(Sender: TcxGridTableView; ACanvas: TcxCanvas; AViewInfo: TcxCustomGridIndicatorItemViewInfo; var ADone: Boolean); procedure TvMXKeyDown(Sender: TObject; var Key: Word; Shift: TShiftState); procedure ToolButton5Click(Sender: TObject); procedure cv1Column20PropertiesEditValueChanged(Sender: TObject); procedure v2Column6PropertiesEditValueChanged(Sender: TObject); procedure v1Column2PropertiesChange(Sender: TObject); procedure Tv1Column2PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); private { Private declarations } function SaveCKData(): Boolean; procedure InitMXGrid(MCRNO: string); public { Public declarations } FBCId: string; end; var frmDJBCKInPut2: TfrmDJBCKInPut2; implementation uses U_DataLink, U_RTFun, U_ClothContractListHZCX, U_ZDYHelp, U_ZdyAttachGYS, U_ProductOrderListSel, U_OutListSel2, U_KHList; {$R *.dfm} procedure TfrmDJBCKInPut2.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; SCreateCDS20(ADOQueryTemp, CDS_MX); SInitCDSData20(ADOQueryTemp, CDS_MX); end; procedure TfrmDJBCKInPut2.FormClose(Sender: TObject; var Action: TCloseAction); begin Action := caFree; end; procedure TfrmDJBCKInPut2.TBAddClick(Sender: TObject); var MMaxno: string; begin if GetLSNo(ADOQueryCmd, MMaxno, 'DR', 'CK_SXPB_CR', 3, 1) = False then begin Application.MessageBox('取待检布入库编号失败!', '提示', 0); Exit; end; if CDS_Sub.IsEmpty = False then begin CopyAddRowCDS(CDS_Sub); with CDS_Sub do begin Edit; FieldByName('SPID').Value := Trim(MMaxno); post; end; end else begin with CDS_Sub do begin Append; FieldByName('SPID').Value := Trim(MMaxno); FieldByName('CRTime').Value := Trim(FormatDateTime('yyyy-MM-dd', Now)); FieldByName('PHTIME').Value := Trim(FormatDateTime('yyyy-MM-dd', Now)); FieldByName('CRType').Value := Trim('加工完成'); FieldByName('Qty').Value := 0; // FieldByName('Price').Value := 0; // FieldByName('Money').Value := 0; FieldByName('gxno').Value := 3; Post; end; end; end; function TfrmDJBCKInPut2.SaveCKData(): Boolean; var FCRID, Maxno, FFSPID: string; FGANHAO: string; begin try ADOQueryCmd.Connection.BeginTrans; CDS_Sub.DisableControls; with CDS_Sub do begin First; while not eof do begin with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from CK_SXPB_CR where SPID=''' + Trim(CDS_Sub.fieldbyname('SPID').AsString) + ''''); open; end; FFSPID := Trim(ADOQueryTemp.fieldbyname('SPID').AsString); FGANHAO := Trim(ADOQueryTemp.fieldbyname('GANGNO').AsString); if Trim(FFSPID) = '' then begin if GetLSNo(ADOQueryCmd, Maxno, 'DR', 'CK_SXPB_CR', 3, 1) = False then begin Result := False; ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('取待检布入库编号失败!', '提示', 0); Exit; end; Maxno := Trim(CDS_Sub.fieldbyname('SPID').AsString); end else begin Maxno := Trim(FFSPID); end; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('select * from CK_SXPB_CR where SPID=''' + Trim(Maxno) + ''''); Open; end; with ADOQueryCmd do begin if Trim(FFSPID) = '' then begin Append; end else begin Edit; end; FieldByName('SPID').Value := Trim(Maxno); FieldByName('FZSPID').Value := Trim(Maxno); FieldByName('CKName').Value := '待检布'; FieldByName('FactoryNo').Value := Trim(CDS_Sub.fieldbyname('FactoryNo').AsString); FieldByName('FromFactoryNo').Value := Trim(CDS_Sub.fieldbyname('FromFactoryNo').AsString); FieldByName('ToFactoryNo').Value := Trim(CDS_Sub.fieldbyname('ToFactoryNo').AsString); FieldByName('ORDMainIdRK').Value := Trim(CDS_Sub.fieldbyname('ORDMainIdRK').AsString); // FieldByName('price').Value := Trim(CDS_Sub.fieldbyname('price').AsString); // FieldByName('money').Value := Trim(CDS_Sub.fieldbyname('money').AsString); FieldByName('ORDSubIdRK').Value := Trim(CDS_Sub.fieldbyname('ORDSubIdRK').AsString); FieldByName('gxno').Value := Trim(CDS_Sub.fieldbyname('gxno').AsString); FieldByName('CRFlag').Value := '入库'; FieldByName('phtime').Value := Trim(CDS_Sub.fieldbyname('crtime').asstring); FieldByName('shtag').Value := Trim(CDS_Sub.fieldbyname('shtag').asstring); FieldByName('CRQtyFlag').Value := 1; FieldByName('FromSpid').Value := Trim(CDS_Sub.fieldbyname('FromSpid').AsString); //FieldByName('CRID').Value:=FCRID; RTSetSaveDataCDS(ADOQueryCmd, Tv1, CDS_Sub, 'CK_SXPB_CR', 2); if Trim(FFSPID) = '' then FieldByName('Filler').Value := Trim(DName) else begin FieldByName('Editer').Value := Trim(DName); FieldByName('EditTime').Value := SGetServerDate(ADOQueryTemp); end; if Trim(CDS_Sub.fieldbyname('OrderNo').AsString) <> '' then begin FieldByName('QCOrderNo').Value := Trim(CDS_Sub.fieldbyname('OrderNo').AsString); end; Post; end; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('Update CK_SXPB_CR Set MXKCQty=(select sum(isnull(Qty,0)*CRQtyFlag) from CK_SXPB_CR A where A.FZSPID=CK_SXPB_CR.SPID)'); sql.Add(',MXKCPiQty=(select sum(isnull(PiQty,0)*CRQtyFlag) from CK_SXPB_CR A where A.FZSPID=CK_SXPB_CR.SPID)'); sql.Add(' where SPID=''' + Trim(Maxno) + ''''); ExecSQL; end; with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from CK_SXPB_CR where SPID=''' + Trim(Maxno) + ''''); Open; end; if ADOQueryTemp.FieldByName('MXKCQty').Value < 0 then begin CDS_Sub.EnableControls; ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('入库数小于出库数不能保存!', '提示', 0); Exit; end; if CDS_Sub.FieldByName('gangno').AsString <> '' then begin with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select TT=count(*) from CK_SXPB_CR where gangno=''' + Trim(CDS_Sub.FieldByName('gangno').AsString) + ''''); Open; end; if ADOQueryTemp.FieldByName('TT').Value > 1 then begin CDS_Sub.EnableControls; ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox(PChar('缸号' + Trim(CDS_Sub.FieldByName('gangno').AsString) + '已存在不能保存!'), '提示', 0); Exit; end; end; // if FGANHAO <> CDS_Sub.FieldByName('gangno').AsString then // begin // with ADOQueryCmd do // begin // Close; // sql.Clear; // sql.Add('Update WFB_MJJY Set mjstr4=' + QuotedStr(CDS_Sub.FieldByName('gangno').AsString)); // // sql.Add(' where APID=''' + Trim(Maxno) + ''''); // // 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(Maxno) + ' 缸号:' + trim(CDS_Sub.FieldByName('gangno').AsString) + ' 原缸号:' + trim(FGANHAO)))); // sql.Add(',' + quotedstr(trim('成功'))); // sql.Add(')'); // ExecSQL; // end; // end; Edit; FieldByName('SPID').Value := Trim(Maxno); //FieldByName('CRID').Value:=Trim(FCRID); Post; // // if Trim(CDS_Sub.fieldbyname('CRType').AsString)='客户退货' then // begin // if not YSData(CDS_Sub) then // begin // ADOQueryCmd.Connection.RollbackTrans; // Application.MessageBox('保存异常!','提示',0); // exit; // end; // end; Next; end; end; CDS_Sub.EnableControls; ADOQueryCmd.Connection.CommitTrans; Result := True; except Result := False; ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('保存异常!', '提示', 0); end; end; procedure TfrmDJBCKInPut2.TBCloseClick(Sender: TObject); begin WriteCxGrid('成品入库登记', Tv1, '成品入库2'); Close; end; procedure TfrmDJBCKInPut2.FormShow(Sender: TObject); var fsj: string; begin ReadCxGrid('成品入库登记', Tv1, '成品入库2'); with ADOQueryTemp do begin Close; sql.Clear; sql.Add(' select A.* '); sql.Add(',OrderNO=(select OrderNO from JYOrder_Main JM where JM.MainId=A.ORDMainIdRK)'); sql.Add(' from CK_SXPB_CR A'); sql.Add(' where SPID=''' + Trim(FBCId) + ''''); Open; end; SCreateCDS20(ADOQueryTemp, CDS_Sub); SInitCDSData20(ADOQueryTemp, CDS_Sub); if CDS_Sub.IsEmpty then Exit; with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from CK_SXPB_CR where FZSPID=''' + Trim(CDS_Sub.fieldbyname('SPID').AsString) + ''''); sql.Add(' and CRQtyFlag=-1'); Open; end; if ADOQueryTemp.IsEmpty = False then begin v1Column4.Options.Focusing := False; // v1Column15.Options.Focusing:=False; v1Column13.Options.Focusing := False; v1Column14.Options.Focusing := False; v2Column1.Options.Focusing := False; // v1Column8.Options.Focusing := False; // v1Column7.Options.Focusing := False; // v1Column1.Options.Focusing := False; // v1Column10.Options.Focusing := False; v1Column11.Options.Focusing := False; Exit; end else begin v1Column4.Options.Focusing := True; //v1Column15.Options.Focusing:=True; v1Column13.Options.Focusing := True; v1Column14.Options.Focusing := True; v2Column1.Options.Focusing := True; // v1Column8.Options.Focusing := True; // v1Column7.Options.Focusing := True; // v1Column1.Options.Focusing := True; // v1Column10.Options.Focusing := True; v1Column11.Options.Focusing := True; end; end; procedure TfrmDJBCKInPut2.TBDelClick(Sender: TObject); begin if CDS_Sub.IsEmpty then Exit; if Trim(CDS_Sub.fieldbyname('SPID').AsString) <> '' then begin if Application.MessageBox('确定要删除数据吗?', '提示', 32 + 4) <> IDYES then Exit; with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from CK_SXPB_CR where FZSPID=''' + Trim(CDS_Sub.fieldbyname('SPID').AsString) + ''''); sql.Add(' and CRQtyFlag=-1'); Open; end; if ADOQueryTemp.IsEmpty = False then begin Application.MessageBox('已有出库记录,不能删除!', '提示', 0); Exit; end; try ADOQueryCmd.Connection.BeginTrans; with ADOQueryCmd do begin Close; sql.Clear; sql.Add(' delete CK_SXPB_CR where SPID=''' + Trim(CDS_Sub.fieldbyname('SPID').AsString) + ''''); ExecSQL; end; ADOQueryCmd.Connection.CommitTrans; CDS_Sub.Delete; except ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('删除异常!', '提示', 0); end; end else begin CDS_Sub.Delete; end; end; procedure TfrmDJBCKInPut2.TBSaveClick(Sender: TObject); begin if CDS_Sub.IsEmpty then Exit; if CDS_Sub.Locate('CRTime', null, []) = True then begin Application.MessageBox('入库时间不能为空!', '提示', 0); Exit; end; if CDS_Sub.Locate('CRType', null, []) = True then begin Application.MessageBox('入库类型不能为空!', '提示', 0); Exit; end; if CDS_Sub.Locate('SPName', null, []) = True then begin Application.MessageBox('品名不能为空!', '提示', 0); Exit; end; // if CDS_Sub.Locate('gxno', null, []) = True then // begin // Application.MessageBox('工序号不能为空!', '提示', 0); // Exit; // end; // if CDS_Sub.Locate('FactoryName', null, []) = True then // begin // Application.MessageBox('存放工厂不能为空!', '提示', 0); // Exit; // end; // if trim(CDS_Sub.fieldbyname('CRType').AsString) <> '客户退货' then // begin // if CDS_Sub.Locate('fromFactoryName', null, []) = True then // begin // Application.MessageBox('来自工厂不能为空!', '提示', 0); // Exit; // end; // end; if CDS_Sub.Locate('PiQty', null, []) = True then begin Application.MessageBox('匹数不能为空!', '提示', 0); Exit; end; if CDS_Sub.Locate('Qty', null, []) = True then begin Application.MessageBox('数量不能为空!', '提示', 0); Exit; end; if CDS_Sub.Locate('QtyUnit', null, []) = True then begin Application.MessageBox('数量单位不能为空!', '提示', 0); Exit; end; // if CDS_Sub.Locate('CRType;FromFactoryName', VarArrayOf(['生产退回', Null]), [loPartialKey]) = True then // begin // Application.MessageBox('生产退回的数据,来自工厂不能为空!', '提示', 0); // Exit; // end; if SaveCKData() then begin Application.MessageBox('保存成功!', '提示', 0); //ModalResult:=1; Exit; end; end; procedure TfrmDJBCKInPut2.v1Column3PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmZDYHelp := TfrmZDYHelp.Create(Application); with frmZDYHelp do begin flag := 'SXKuWei'; flagname := '库位'; if ShowModal = 1 then begin with Self.CDS_Sub do begin Edit; FieldByName('KuWei').Value := Trim(frmZDYHelp.ClientDataSet1.fieldbyname('ZdyName').AsString); end; end; end; finally frmZDYHelp.Free; end; end; procedure TfrmDJBCKInPut2.v1Column14PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmZdyAttachGYS := TfrmZdyAttachGYS.Create(Application); with frmZdyAttachGYS do begin if ShowModal = 1 then begin with Self.CDS_Sub do begin edit; // FieldByName('FactoryNo').Value := Trim(frmZdyAttachGYS.CDS_HZ.fieldbyname('coCode').AsString); // FieldByName('FactoryName').Value := Trim(frmZdyAttachGYS.CDS_HZ.fieldbyname('coName').AsString); // FieldByName('FromFactoryNo').Value := Trim(frmZdyAttachGYS.CDS_HZ.fieldbyname('coCode').AsString); FieldByName('FromFactoryName').Value := Trim(frmZdyAttachGYS.CDS_HZ.fieldbyname('coName').AsString); //Post; end; end; end; finally frmZdyAttachGYS.Free; end; end; procedure TfrmDJBCKInPut2.v2Column1PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmZDYHelp := TfrmZDYHelp.Create(Application); with frmZDYHelp do begin flag := 'WJGName'; flagname := '外加工名称'; if ShowModal = 1 then begin with Self.CDS_Sub do begin Edit; FieldByName('SPName').Value := Trim(frmZDYHelp.ClientDataSet1.fieldbyname('ZdyName').AsString); end; end; end; finally frmZDYHelp.Free; end; end; procedure TfrmDJBCKInPut2.v1Column5PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmZDYHelp := TfrmZDYHelp.Create(Application); with frmZDYHelp do begin flag := 'KuWei'; flagname := '库位'; if ShowModal = 1 then begin with Self.CDS_Sub do begin Edit; FieldByName('KuWei').Value := Trim(frmZDYHelp.ClientDataSet1.fieldbyname('ZdyName').AsString); end; end; end; finally frmZDYHelp.Free; end; end; procedure TfrmDJBCKInPut2.v1Column11PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmZdyAttachGYS := TfrmZdyAttachGYS.Create(Application); with frmZdyAttachGYS do begin if ShowModal = 1 then begin with Self.CDS_Sub do begin edit; FieldByName('ToFactoryNo').Value := Trim(frmZdyAttachGYS.CDS_HZ.fieldbyname('COCode').AsString); FieldByName('FactoryName').Value := Trim(frmZdyAttachGYS.CDS_HZ.fieldbyname('COName').AsString); //Post; end; end; end; finally frmZdyAttachGYS.Free; end; end; procedure TfrmDJBCKInPut2.v1Column16PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmZdyAttachGYS := TfrmZdyAttachGYS.Create(Application); with frmZdyAttachGYS do begin if ShowModal = 1 then begin with Self.CDS_Sub do begin edit; FieldByName('FromFactoryNo').Value := Trim(frmZdyAttachGYS.CDS_HZ.fieldbyname('ZdyCode').AsString); FieldByName('FromFactoryName').Value := Trim(frmZdyAttachGYS.CDS_HZ.fieldbyname('ZdyName').AsString); //Post; end; end; end; finally frmZdyAttachGYS.Free; end; end; procedure TfrmDJBCKInPut2.v1Column13PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmProductOrderListSel := TfrmProductOrderListSel.Create(Application); with frmProductOrderListSel do begin if ShowModal = 1 then begin with Self.CDS_Sub do begin Edit; FieldByName('ORDMainIdRK').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('MainId').AsString); FieldByName('ORDSubIdRK').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('SubId').AsString); FieldByName('OrderNo').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('OrderNo').AsString); FieldByName('CustomerNoName').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('CustomerNoName').AsString); FieldByName('SPColor').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('PRTColor').AsString); FieldByName('SPHX').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('PRTHX').AsString); FieldByName('SPCode').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('MPRTCode').AsString); FieldByName('SPName').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('MPRTCodeName').AsString); FieldByName('SPSpec').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('MPRTSpec').AsString); FieldByName('SPCF').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('MPRTCF').AsString); FieldByName('SPMF').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('MPRTMF').AsString); FieldByName('SPKZ').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('MPRTKZ').AsString); end; end; end; finally frmProductOrderListSel.Free; end; end; procedure TfrmDJBCKInPut2.v1Column18PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmZDYHelp := TfrmZDYHelp.Create(Application); with frmZDYHelp do begin flag := 'KuWei'; flagname := '库位'; if ShowModal = 1 then begin with Self.CDS_Sub do begin Edit; FieldByName('KuWei').Value := Trim(frmZDYHelp.ClientDataSet1.fieldbyname('ZdyName').AsString); end; end; end; finally frmZDYHelp.Free; end; end; procedure TfrmDJBCKInPut2.ToolButton1Click(Sender: TObject); var MMaxno: string; begin try frmProductOrderListSel := TfrmProductOrderListSel.Create(Application); with frmProductOrderListSel do begin if ShowModal = 1 then begin with frmProductOrderListSel.Order_Main do begin first; DisableControls; while not eof do begin if GetLSNo(ADOQueryCmd, MMaxno, 'DC', 'CK_SXPB_CR', 3, 1) = False then begin Application.MessageBox('取待检布入库编号失败!', '提示', 0); Exit; end; if fieldbyname('ssel').AsBoolean then begin if GetLSNo(ADOQueryCmd, MMaxno, 'DR', 'CK_SXPB_CR', 3, 1) = False then begin Application.MessageBox('取待检布入库编号失败!', '提示', 0); Exit; end; with Self.CDS_Sub do begin Append; FieldByName('CRTime').Value := Trim(FormatDateTime('yyyy-MM-dd', Now)); FieldByName('SPID').Value := Trim(MMaxno); FieldByName('CustomerNoName').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('CustomerNoName').AsString); FieldByName('SPCode').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('MPRTCode').AsString); FieldByName('ORDMainIdRK').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('MainId').AsString); FieldByName('ORDSubIdRK').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('SubId').AsString); FieldByName('OrderNo').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('OrderNo').AsString); FieldByName('SPColor').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('PRTColor').AsString); FieldByName('SPHX').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('PRTHX').AsString); FieldByName('SPName').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('MPRTCodeName').AsString); FieldByName('SPSpec').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('MPRTSpec').AsString); FieldByName('SPCF').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('MPRTCF').AsString); FieldByName('SPMF').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('MPRTMF').AsString); FieldByName('SPKZ').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('MPRTKZ').AsString); Post; end; end; next; end; first; EnableControls; end; end; end; finally frmProductOrderListSel.Free; end; end; procedure TfrmDJBCKInPut2.Button2Click(Sender: TObject); var CRType, FactoryName, fromFactoryName, gxno, batchno, QtyUnit, Note, spcolor: string; i, PiQty: Integer; qty: Double; begin try if CDS_Sub.IsEmpty then Exit; CDS_Sub.DisableControls; with CDS_Sub do begin CRType := Trim(CDS_Sub.fieldbyname('CRType').AsString); FactoryName := Trim(CDS_Sub.fieldbyname('FactoryName').AsString); // RCGangNo := Trim(CDS_Sub.fieldbyname('RCGangNo').AsString); // ToFactoryName := Trim(CDS_Sub.fieldbyname('ToFactoryName').AsString); spcolor := Trim(CDS_Sub.fieldbyname('spcolor').AsString); batchno := Trim(CDS_Sub.fieldbyname('batchno').AsString); PiQty := CDS_Sub.fieldbyname('PiQty').AsInteger; qty := CDS_Sub.fieldbyname('Qty').AsFloat; QtyUnit := Trim(CDS_Sub.fieldbyname('QtyUnit').AsString); Note := Trim(CDS_Sub.fieldbyname('Note').AsString); fromFactoryName := Trim(CDS_Sub.fieldbyname('fromFactoryName').AsString); end; with CDS_Sub do begin First; while not eof do begin Edit; if CheckBox1.Checked then FieldByName('CRType').Value := CRType; if CheckBox2.Checked then FieldByName('fromFactoryName').Value := fromFactoryName; if CheckBox3.Checked then FieldByName('spcolor').Value := spcolor; if CheckBox4.Checked then FieldByName('FactoryName').Value := FactoryName; if CheckBox5.Checked then FieldByName('batchno').Value := batchno; if CheckBox6.Checked then FieldByName('PiQty').Value := PiQty; if CheckBox7.Checked then FieldByName('Qty').Value := qty; if CheckBox8.Checked then FieldByName('QtyUnit').Value := QtyUnit; if CheckBox9.Checked then FieldByName('Note').Value := Note; if chk1.Checked then FieldByName('gxno').Value := gxno; Post; Next; end; end; CDS_Sub.EnableControls; except Application.MessageBox('替换异常!', '提示', 0); end; end; procedure TfrmDJBCKInPut2.ToolButton2Click(Sender: TObject); begin Panel4.Visible := True; end; procedure TfrmDJBCKInPut2.Image2Click(Sender: TObject); begin Panel4.Visible := False; end; procedure TfrmDJBCKInPut2.Button1Click(Sender: TObject); var i: Integer; begin for i := 0 to GroupBox1.ControlCount - 1 do begin if GroupBox1.Controls[i] is TCheckBox then begin TCheckBox(GroupBox1.Controls[i]).Checked := true; end; end; end; procedure TfrmDJBCKInPut2.ToolButton3Click(Sender: TObject); var i: Integer; MaxNo, MMXID, MCRNO: string; begin MCRNO := Trim(CDS_Sub.fieldbyname('SPID').AsString); if GetLSNo(ADOQueryTemp, MaxNo, 'MCM', 'CK_SXPB_CRMX', 3, 1) = False then begin Application.MessageBox('取最大号失败!', '提示', 0); Exit; end; try ADOQueryCmd.Connection.BeginTrans; for i := 1 to 10 do begin MMXID := Trim(MaxNo) + Trim(inttostr(i)); with ADOQueryCmd do begin Close; SQL.Clear; sql.Add('insert into CK_SXPB_CRMX (MXID,CRNO,MXQty)'); sql.Add('values(' + quotedstr(MMXID)); sql.Add(',' + quotedstr(Trim(MCRNO))); sql.Add(',0'); sql.Add(')'); ExecSQL; end; end; ADOQueryCmd.Connection.CommitTrans; InitMXGrid(MCRNO); except ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('添加失败!', '提示', 0); end; end; procedure TfrmDJBCKInPut2.Tv1MouseDown(Sender: TObject; Button: TMouseButton; Shift: TShiftState; X, Y: Integer); begin InitMXGrid(Trim(CDS_Sub.fieldbyname('SPID').AsString)); end; procedure TfrmDJBCKInPut2.cxGridDBColumn8PropertiesEditValueChanged(Sender: TObject); var mvalue, FFieldName: string; begin mvalue := TcxTextEdit(Sender).EditingText; FFieldName := Trim(TvMX.Controller.FocusedColumn.DataBinding.FilterFieldName); with CDS_MX do begin Edit; FieldByName(FFieldName).Value := mvalue; Post; end; with ADOQueryCmd do begin Close; SQL.Clear; sql.Add('update CK_SXPB_CRMX set ' + FFieldName + ' = ' + mvalue); sql.Add(' where MXID=' + quotedstr(Trim(CDS_MX.FieldByName('MXID').AsString))); ExecSQL; end; TvMX.Controller.EditingController.ShowEdit(); end; procedure TfrmDJBCKInPut2.ToolButton4Click(Sender: TObject); begin with ADOQueryCmd do begin Close; SQL.Clear; sql.Add('delete CK_SXPB_CRMX where MXID=' + quotedstr(Trim(CDS_MX.FieldByName('MXID').AsString))); ExecSQL; end; CDS_MX.Delete; end; procedure TfrmDJBCKInPut2.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 TfrmDJBCKInPut2.TvMXKeyDown(Sender: TObject; var Key: Word; Shift: TShiftState); begin TvMX.OptionsData.Editing := False; if Key = 13 then Key := 40; TvMX.OptionsData.Editing := True; end; procedure TfrmDJBCKInPut2.ToolButton5Click(Sender: TObject); var MMaxno: string; begin try frmOutListSel2 := TfrmOutListSel2.Create(Application); with frmOutListSel2 do begin if ShowModal = 1 then begin with frmOutListSel2.CDS_Main do begin while Locate('SSel', True, []) do begin if GetLSNo(ADOQueryCmd, MMaxno, 'DR', 'CK_SXPB_CR', 3, 1) = False then begin Application.MessageBox('取待检布入库编号失败!', '提示', 0); Exit; end; with Self.CDS_Sub do begin Append; FieldByName('CRTime').Value := Trim(FormatDateTime('yyyy-MM-dd', Now)); if frmOutListSel2.CDS_Main.fieldbyname('CRType').AsString = '加工出库' then FieldByName('CRType').Value := '加工完成'; if frmOutListSel2.CDS_Main.fieldbyname('CRType').AsString = '销售出库' then FieldByName('CRType').Value := '销售退回'; if frmOutListSel2.CDS_Main.fieldbyname('CRType').AsString = '检验出库' then FieldByName('CRType').Value := '检验完成'; if frmOutListSel2.CDS_Main.fieldbyname('CRType').AsString = '回修出库' then FieldByName('CRType').Value := '回修完成'; FieldByName('fromFactoryName').Value := frmOutListSel2.CDS_Main.fieldbyname('ToFactoryName').Value; FieldByName('fromFactoryNo').Value := frmOutListSel2.CDS_Main.fieldbyname('ToFactoryNo').Value; FieldByName('BatchNO').Value := frmOutListSel2.CDS_Main.fieldbyname('BatchNO').Value; FieldByName('SPCode').Value := frmOutListSel2.CDS_Main.fieldbyname('SPCode').Value; FieldByName('SPName').Value := frmOutListSel2.CDS_Main.fieldbyname('SPName').Value; FieldByName('SPSpec').Value := frmOutListSel2.CDS_Main.fieldbyname('SPSpec').Value; FieldByName('SPCF').Value := frmOutListSel2.CDS_Main.fieldbyname('SPCF').Value; FieldByName('SPMF').Value := frmOutListSel2.CDS_Main.fieldbyname('SPMF').Value; FieldByName('SPKZ').Value := frmOutListSel2.CDS_Main.fieldbyname('SPKZ').Value; FieldByName('SPHX').Value := frmOutListSel2.CDS_Main.fieldbyname('SPHX').Value; FieldByName('SPColor').Value := frmOutListSel2.CDS_Main.fieldbyname('SPColor').Value; FieldByName('QtyUnit').Value := frmOutListSel2.CDS_Main.fieldbyname('QtyUnit').Value; FieldByName('PiQty').Value := frmOutListSel2.CDS_Main.fieldbyname('PiQty').Value; FieldByName('Qty').Value := frmOutListSel2.CDS_Main.fieldbyname('Qty').Value; FieldByName('FromSPID').Value := frmOutListSel2.CDS_Main.fieldbyname('SPID').Value; FieldByName('GXNO').Value := frmOutListSel2.CDS_Main.fieldbyname('GXNO').Value; FieldByName('SHTAG').Value := '损耗'; FieldByName('SPID').Value := MMaxno; FieldByName('Price').Value := 0; FieldByName('Money').Value := 0; end; frmOutListSel2.CDS_Main.Delete; end; end; end; end; finally frmOutListSel2.Free; end; end; procedure TfrmDJBCKInPut2.cv1Column20PropertiesEditValueChanged(Sender: TObject); var mvalue, FFieldName: string; FQty, FPrice, FMxMoney: double; begin mvalue := TcxTextEdit(Sender).EditingText; FFieldName := Trim(Tv1.Controller.FocusedColumn.DataBinding.FilterFieldName); if Trim(mvalue) = '' then begin mvalue := '0'; end; with CDS_Sub do begin Edit; FieldByName(FFieldName).Value := Trim(mvalue); Post; end; with CDS_Sub do begin Edit; FQty := FieldByName('Qty').AsFloat; FPrice := FieldByName('Price').AsFloat; Post; end; with CDS_Sub do begin Edit; FieldByName('Money').Value := strtofloat(format('%.2f', [FieldByName('Qty').AsFloat * FieldByName('Price').AsFloat])); // FieldByName(FFieldName).Value := Trim(mvalue); // FieldbyName('MxMoney').Value := FMxMoney; Post; end; tv1.Controller.EditingController.ShowEdit(); // HJJE(); end; //procedure TfrmYFKInput.HJJE(); //var // FMoney, FHuiLv, FBBMoney: double; //begin // if TV1.DataController.Summary.FooterSummaryValues[1] <> NULL then // FMoney := TV1.DataController.Summary.FooterSummaryValues[1] // else // FMoney := 0; // // FHuiLv := strtofloat(HuiLv.Text); // if FHuiLv = 0 then // FHuiLv := 1; // FBBMoney := FHuiLv * FMoney; // Money.Text := floattostr(FMoney); // HuiLv.Text := floattostr(FHuiLv); // BBMoney.Text := floattostr(FBBMoney); //end; procedure TfrmDJBCKInPut2.v2Column6PropertiesEditValueChanged(Sender: TObject); var mvalue, FFieldName: string; FQty, FPrice, FMxMoney: double; begin mvalue := TcxTextEdit(Sender).EditingText; FFieldName := Trim(Tv1.Controller.FocusedColumn.DataBinding.FilterFieldName); if Trim(mvalue) = '' then begin mvalue := '0'; end; with CDS_Sub do begin Edit; FieldByName(FFieldName).Value := Trim(mvalue); Post; end; with CDS_Sub do begin Edit; FQty := FieldByName('Qty').AsFloat; FPrice := FieldByName('Price').AsFloat; Post; end; with CDS_Sub do begin Edit; FieldByName('Money').Value := strtofloat(format('%.2f', [FieldByName('Qty').AsFloat * FieldByName('Price').AsFloat])); // FieldByName(FFieldName).Value := Trim(mvalue); // FieldbyName('MxMoney').Value := FMxMoney; Post; end; tv1.Controller.EditingController.ShowEdit(); // HJJE(); end; procedure TfrmDJBCKInPut2.v1Column2PropertiesChange(Sender: TObject); var ftime: TDateTime; mvalue, FFieldName, funit: string; begin mvalue := TcxTextEdit(Sender).EditingText; FFieldName := Trim(Tv1.Controller.FocusedColumn.DataBinding.FilterFieldName); with CDS_Sub do begin Edit; FieldByName(FFieldName).Value := Trim(mvalue); Post; end; with CDS_Sub do begin Edit; ftime := CDS_Sub.FieldByName('crtime').AsDateTime; Post; end; with CDS_Sub do begin Edit; FieldbyName('phtime').Value := ftime; Post; end; // CDS_Sub.FieldByName('phtime').Value := ftime; end; procedure TfrmDJBCKInPut2.Tv1Column2PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmKHList := TfrmKHList.Create(Application); with frmKHList do begin if ShowModal = 1 then begin with Self.CDS_Sub do begin Edit; FieldByName('CustomerNoName').Value := Trim(Order_Main.fieldbyname('CoNAME').AsString); end; end; end; finally frmKHList.Free; end; end; end.