unit U_SXCKInPut; 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, cxLookAndFeels, cxLookAndFeelPainters, cxNavigator; type TfrmSXCKInPut = 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; v1Column7: TcxGridDBColumn; v1Column8: TcxGridDBColumn; v1Column10: TcxGridDBColumn; v1Column1: TcxGridDBColumn; v1Column3: TcxGridDBColumn; v1Column5: TcxGridDBColumn; v1Column11: TcxGridDBColumn; v1Column13: TcxGridDBColumn; v1Column15: TcxGridDBColumn; v1Column16: TcxGridDBColumn; v1Column17: TcxGridDBColumn; v1Column18: TcxGridDBColumn; v1Column19: TcxGridDBColumn; v1Column20: TcxGridDBColumn; v1Column22: TcxGridDBColumn; v1Column21: TcxGridDBColumn; v1Column23: TcxGridDBColumn; v1Column24: TcxGridDBColumn; v1Column25: TcxGridDBColumn; ADOQueryTMP: TADOQuery; v1Column26: TcxGridDBColumn; v1Column27: TcxGridDBColumn; v1Column28: TcxGridDBColumn; v1Column29: TcxGridDBColumn; cxStyleRepository1: TcxStyleRepository; cxStyle1: TcxStyle; cxStyle2: TcxStyle; cxStyle3: TcxStyle; Tv1Column1: 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 Tv1MouseDown(Sender: TObject; Button: TMouseButton; Shift: TShiftState; X, Y: Integer); procedure v1Column17PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); procedure v1Column8PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); procedure v1Column7PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); procedure v1Column1PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); procedure v1Column10PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); procedure v1Column25PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); private { Private declarations } function SaveCKData(): Boolean; public { Public declarations } FBCId, canshu3: string; end; var frmSXCKInPut: TfrmSXCKInPut; implementation uses U_DataLink, U_RTFun, U_ClothContractListHZCX, U_ZDYHelp, U_ZdyAttachGYS, U_ProductOrderListSel, U_ZdyAttachCP, U_ProductOrderListSelPBRK; {$R *.dfm} procedure TfrmSXCKInPut.FormClose(Sender: TObject; var Action: TCloseAction); begin Action := caFree; end; procedure TfrmSXCKInPut.TBAddClick(Sender: TObject); begin if CDS_Sub.IsEmpty = False then begin CopyAddRowCDS(CDS_Sub); with CDS_Sub do begin Edit; FieldByName('SPID').Value := null; FieldByName('PBPrice').Value := '0'; FieldByName('yunprice').value := '0'; FieldByName('otherprice').value := '0'; post; end; end else begin with CDS_Sub do begin Append; FieldByName('CRTime').Value := Trim(FormatDateTime('yyyy-MM-dd', Now)); FieldByName('PBPrice').Value := '0'; FieldByName('yunprice').value := '0'; FieldByName('otherprice').value := '0'; Post; end; end; end; function TfrmSXCKInPut.SaveCKData(): Boolean; var FCRID, Maxno, FFSPID, OTMaxno, FFFSPID, YFID, fkeyNo, SJMaxno: string; fid: string; FBP, FDP: Integer; 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); if Trim(FFSPID) = '' then begin if GetLSNo(ADOQueryCmd, Maxno, 'PR', 'CK_SXPB_CR', 3, 1) = False then begin Result := False; ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('取坯布入库编号失败!', '提示', 0); Exit; end; 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('ORDSubIdRK').Value := Trim(CDS_Sub.fieldbyname('ORDSubIdRK').AsString); FieldByName('CPID').Value := Trim(CDS_Sub.fieldbyname('CPID').AsString); FieldByName('jixing').Value := Trim(CDS_Sub.fieldbyname('jixing').AsString); FieldByName('CRFlag').Value := '入库'; FieldByName('CRQtyFlag').Value := 1; FieldByName('PBPrice').Value := (CDS_Sub.fieldbyname('PBPrice').AsString); FieldByName('quality').Value := Trim(CDS_Sub.Fieldbyname('quality').AsString); FieldByName('YGSL').Value := Trim(CDS_Sub.fieldbyname('YGSL').AsString); FieldByName('MPRTQtyNote').Value := Trim(CDS_Sub.fieldbyname('MPRTQtyNote').AsString); FieldByName('MPRTPBQtyNote').Value := Trim(CDS_Sub.fieldbyname('MPRTPBQtyNote').AsString); FieldByName('YUNtype').Value := Trim(CDS_Sub.fieldbyname('yuntype').AsString); FieldByName('PBcolor').Value := Trim(CDS_Sub.fieldbyname('PBcolor').AsString); if Trim(CDS_Sub.fieldbyname('yunprice').AsString) <> '' then begin FieldByName('yunprice').Value := Trim(CDS_Sub.fieldbyname('yunprice').AsString); end else begin FieldByName('yunprice').Value := '0'; end; if Trim(CDS_Sub.fieldbyname('otherprice').AsString) <> '' then begin FieldByName('otherprice').Value := Trim(CDS_Sub.fieldbyname('otherprice').AsString); end else begin FieldByName('otherprice').Value := '0'; end; if Trim(CDS_Sub.fieldbyname('SJPrice').AsString) <> '' then begin FieldByName('SJPrice').Value := Trim(CDS_Sub.fieldbyname('SJPrice').AsString); end else begin FieldByName('SJPrice').Value := '0'; end; //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(',MXKCKGQty=(select sum(isnull(kgQty,0)*CRQtyFlag) from CK_SXPB_CR A where A.FZSPID=CK_SXPB_CR.SPID)'); sql.Add(' where SPID=''' + Trim(Maxno) + ''''); ExecSQL; end; if CDS_Sub.FieldByName('otherprice').Value <> '0' then begin with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from YF_Money_CR where mainid=''' + Trim(FBCId) + ''' and YFName=''坯布其他费'' '); open; end; FFFSPID := Trim(ADOQueryTemp.fieldbyname('YFID').AsString); if Trim(FFFSPID) = '' then begin if GetLSNo(ADOQueryCmd, OTMaxno, 'OT', 'YF_Money_CR', 3, 1) = False then begin Result := False; ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('取坯布其他费编号失败!', '提示', 0); Exit; end; end else begin OTMaxno := Trim(FFFSPID); end; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('select * from YF_Money_CR where YFID=''' + Trim(OTMaxno) + ''''); Open; end; with ADOQueryCmd do begin if Trim(FFFSPID) = '' then begin Append; end else begin Edit; end; FieldByName('YFID').Value := Trim(OTMaxno); FieldByName('YFTypeId').Value := Trim(Maxno); FieldByName('Filler').Value := Trim(DName); FieldByName('CRType').Value := '应付款登记'; FieldByName('CRFlag').Value := '应付付'; FieldByName('QtyFlag').Value := 1; FieldByName('FactoryName').Value := Trim(CDS_Sub.fieldbyname('factoryName').AsString); FieldByName('CRTime').Value := CDS_Sub.fieldbyname('CRTime').AsDateTime; FieldByName('HuiLv').Value := 1; FieldByName('BZType').Value := 'RMB'; FieldByName('ComTaiTou').Value := ''; FieldByName('QtyUnit').Value := Trim(CDS_Sub.fieldbyname('QtyUnit').AsString); FieldByName('orderNo').Value := Trim(CDS_Sub.fieldbyname('OrderNo').AsString); FieldByName('P_CodeName').Value := Trim(CDS_Sub.fieldbyname('SPName').AsString); FieldByName('YFName').Value := '坯布其他费'; FieldByName('Money').Value := Trim(CDS_Sub.fieldbyname('otherPrice').AsString); fieldbyname('quality').Value := Trim(CDS_Sub.fieldbyname('quality').AsString); fieldbyname('P_Code').Value := Trim(CDS_Sub.fieldbyname('MPRTCode').AsString); FieldByName('MainId').Value := Trim(Maxno); FieldByName('status').Value := '0'; if Trim(FFFSPID) = '' then begin FieldByName('Filler').Value := Trim(DName); FieldByName('filltime').Value := SGetServerDate(ADOQueryTemp); end else begin FieldByName('Editer').Value := Trim(DName); FieldByName('EditTime').Value := SGetServerDate(ADOQueryTemp); end; Post; end; end else begin with ADOQueryCmd do begin Close; sql.Clear; sql.Add('select * from YF_Money_CR where YFTypeID=''' + Trim(Maxno) + ''' and YFName=''坯布其他费'' '); Open; end; if ADOQueryCmd.IsEmpty = False then begin with ADOQueryCmd do begin Close; sql.Clear; sql.Add('delete from YF_Money_CR where YFTypeID=''' + trim(Maxno) + ''' and YFName=''坯布其他费'' '); ExecSQL; end; end; end; if CDS_Sub.FieldByName('yunprice').Value <> '0' then begin if CDS_Sub.FieldByName('yuntype').Value = '' then begin Application.MessageBox('运费付款方式不能为空!', '提示'); Exit; end; if Trim(fkeyNo) = '' then begin if GetLSNo(ADOQueryTmp, fkeyNo, 'YL', 'YF_Money_LL', 3, 1) = False then begin ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('取流水号失败!', '提示'); Exit; end; end; // with ADOQueryCmd do // begin // Close; // sql.Clear; // SQL.Add('delete from YF_Money_LL where fromMainID='''+Trim(FFSPID)+''' '); // execsql; // end; with ADOQueryCmd do begin Close; sql.Clear; SQL.Add('select * from YF_Money_LL where fromMainID=''' + Trim(FFSPID) + ''' '); Open; if isempty then begin append; fieldbyname('filler').Value := trim(Dname); fieldbyname('filltime').Value := SGetServerDate10(ADOQueryTemp); fieldbyname('crtime').Value := SGetServerDate10(ADOQueryTemp); end else begin edit; fieldbyname('chker').Value := trim(Dname); fieldbyname('chkTime').Value := SGetServerDate10(ADOQueryTemp); end; FieldByName('LLNO').Value := Trim(fkeyNo); FieldByName('FactoryName').Value := Trim(CDS_Sub.fieldbyname('yuntype').AsString); fieldbyname('OutMoney').Value := Trim(CDS_Sub.fieldbyname('yunPrice').AsString); fieldbyname('frommainid').value := trim(Maxno); FieldByName('orderno').Value := Trim(CDS_Sub.fieldbyname('OrderNo').AsString); FieldByName('CRType').Value := '坯布运费'; FieldByName('HuiLv').Value := '1'; fieldbyname('status').Value := '0'; Post; end; end else begin with ADOQueryCmd do begin Close; sql.Clear; sql.Add('select * from YF_Money_LL where fromMainID=''' + Trim(Maxno) + ''' and CRType=''坯布运费'' '); Open; end; if ADOQueryCmd.IsEmpty = False then begin with ADOQueryCmd do begin Close; sql.Clear; sql.Add('delete from YF_Money_LL where fromMainID=''' + Trim(Maxno) + ''' and CRType=''坯布运费'' '); ExecSQL; end; end; end; if StrToFloatdef(CDS_Sub.FieldByName('SJPrice').asstring, 0) <> 0 then begin with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from YF_Money_CR where mainid=''' + Trim(FBCId) + ''' and YFName=''坯布上机费'' '); open; end; FFFSPID := Trim(ADOQueryTemp.fieldbyname('YFID').AsString); if Trim(FFFSPID) = '' then begin if GetLSNo(ADOQueryCmd, SJMaxno, 'SJ', 'YF_Money_CR', 3, 1) = False then begin Result := False; ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('取坯布上机费编号失败!', '提示', 0); Exit; end; end else begin SJMaxno := Trim(FFFSPID); end; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('select * from YF_Money_CR where YFID=''' + Trim(SJMaxno) + ''''); Open; end; with ADOQueryCmd do begin if Trim(FFFSPID) = '' then begin Append; end else begin Edit; end; FieldByName('YFID').Value := Trim(SJMaxno); FieldByName('YFTypeId').Value := Trim(Maxno); FieldByName('Filler').Value := Trim(DName); FieldByName('CRType').Value := '应付款登记'; FieldByName('CRFlag').Value := '应付付'; FieldByName('QtyFlag').Value := 1; FieldByName('FactoryName').Value := Trim(CDS_Sub.fieldbyname('factoryName').AsString); FieldByName('CRTime').Value := CDS_Sub.fieldbyname('CRTime').AsDateTime; FieldByName('HuiLv').Value := 1; FieldByName('BZType').Value := 'RMB'; FieldByName('ComTaiTou').Value := ''; FieldByName('QtyUnit').Value := Trim(CDS_Sub.fieldbyname('QtyUnit').AsString); FieldByName('orderNo').Value := Trim(CDS_Sub.fieldbyname('OrderNo').AsString); FieldByName('P_CodeName').Value := Trim(CDS_Sub.fieldbyname('SPName').AsString); FieldByName('YFName').Value := '坯布上机费'; FieldByName('Money').Value := Trim(CDS_Sub.fieldbyname('SJPrice').AsString); fieldbyname('quality').Value := Trim(CDS_Sub.fieldbyname('quality').AsString); fieldbyname('P_Code').Value := Trim(CDS_Sub.fieldbyname('MPRTCode').AsString); FieldByName('MainId').Value := Trim(Maxno); FieldByName('status').Value := '0'; if Trim(FFFSPID) = '' then begin FieldByName('Filler').Value := Trim(DName); FieldByName('filltime').Value := SGetServerDate(ADOQueryTemp); end else begin FieldByName('Editer').Value := Trim(DName); FieldByName('EditTime').Value := SGetServerDate(ADOQueryTemp); end; Post; end; end else begin with ADOQueryCmd do begin Close; sql.Clear; sql.Add('select * from YF_Money_CR where YFTypeID=''' + Trim(Maxno) + ''' and YFName=''坯布上机费'' '); Open; end; if ADOQueryCmd.IsEmpty = False then begin with ADOQueryCmd do begin Close; sql.Clear; sql.Add('delete from YF_Money_CR where YFTypeID=''' + trim(Maxno) + ''' and YFName=''坯布上机费'' '); ExecSQL; end; end; end; Edit; FieldByName('SPID').Value := Trim(Maxno); //FieldByName('CRID').Value:=Trim(FCRID); Post; FFSPID := ''; FFFSPID := ''; fkeyNo := ''; Next; end; end; CDS_Sub.EnableControls; ADOQueryCmd.Connection.CommitTrans; Result := True; except Result := False; ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('保存异常!', '提示', 0); end; end; procedure TfrmSXCKInPut.TBCloseClick(Sender: TObject); begin WriteCxGrid('坯布入库登记', Tv1, '坯布仓库'); Close; end; procedure TfrmSXCKInPut.FormShow(Sender: TObject); var fsj: string; begin ReadCxGrid('坯布入库登记', Tv1, '坯布仓库'); 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 TfrmSXCKInPut.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 TfrmSXCKInPut.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('SSType', null, []) = True then begin Application.MessageBox('所属类型不能为空!', '提示', 0); Exit; end; if CDS_Sub.Locate('SPType', 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('SPCF',null,[])=True then begin Application.MessageBox('成分不能为空!','提示',0); Exit; end; } if CDS_Sub.Locate('ToFactoryName', null, []) = True then begin Application.MessageBox('存放工厂不能为空!', '提示', 0); Exit; end; if CDS_Sub.Locate('FactoryName', null, []) = True then begin Application.MessageBox('供应商不能为空!', '提示', 0); Exit; 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('quality', null, []) = True then // begin // Application.MessageBox('品质情况不能为空!', '提示', 0); // Exit; // end; CDS_Sub.First; while not CDS_Sub.Eof do begin if CDS_Sub.FieldByName('yunprice').value <> '0' then begin if CDS_Sub.FieldByName('yuntype').value = null then begin Application.MessageBox('运费付款方式不能为空!', '提示'); Exit; end; end; if CDS_Sub.FieldByName('YGSL').value = '' then begin Application.MessageBox('预估缩率不能为空!', '提示'); Exit; end; CDS_Sub.Next; end; if CDS_Sub.Locate('CRType;FromFactoryName', VarArrayOf(['生产退回', Null]), [loPartialKey]) = True then begin Application.MessageBox('生产退回的数据,来自工厂不能为空!', '提示', 0); Exit; end; if CDS_Sub.Locate('CRType;OrderNo', VarArrayOf(['生产退回', Null]), [loPartialKey]) = True then begin Application.MessageBox('生产退回的数据,订单号不能为空!', '提示', 0); Exit; end; if SaveCKData() then begin Application.MessageBox('保存成功!', '提示', 0); //ModalResult:=1; Exit; end; end; procedure TfrmSXCKInPut.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 TfrmSXCKInPut.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('ZdyCode').AsString); FieldByName('FactoryName').Value := Trim(frmZdyAttachGYS.CDS_HZ.fieldbyname('ZdyName').AsString); //Post; end; end; end; finally frmZdyAttachGYS.Free; end; end; procedure TfrmSXCKInPut.v2Column1PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin if Trim(canshu3) = '' then begin try frmZDYHelp := TfrmZDYHelp.Create(Application); with frmZDYHelp do begin flag := 'PBName'; 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 else begin try frmZdyAttachCP := TfrmZdyAttachCP.Create(Application); with frmZdyAttachCP do begin if ShowModal = 1 then begin with Self.CDS_Sub do begin Edit; FieldByName('SPName').Value := Trim(frmZdyAttachCP.CDS_HZ.fieldbyname('ZdyName').AsString); FieldByName('SPSpec').Value := Trim(frmZdyAttachCP.CDS_HZ.fieldbyname('DEFstr1').AsString); FieldByName('SPCF').Value := Trim(frmZdyAttachCP.CDS_HZ.fieldbyname('DEFstr2').AsString); FieldByName('SPMF').Value := Trim(frmZdyAttachCP.CDS_HZ.fieldbyname('DEFstr7').AsString); FieldByName('SPKZ').Value := Trim(frmZdyAttachCP.CDS_HZ.fieldbyname('DEFstr8').AsString); FieldByName('SPKZ').Value := Trim(frmZdyAttachCP.CDS_HZ.fieldbyname('DEFstr8').AsString); FieldByName('SPCode').Value := Trim(frmZdyAttachCP.CDS_HZ.fieldbyname('ZdyCode').AsString); FieldByName('CPID').Value := Trim(frmZdyAttachCP.CDS_HZ.fieldbyname('ATID').AsString); end; end; end; finally frmZdyAttachCP.Free; end; end; end; procedure TfrmSXCKInPut.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 TfrmSXCKInPut.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('ZdyCode').AsString); FieldByName('ToFactoryName').Value := Trim(frmZdyAttachGYS.CDS_HZ.fieldbyname('ZdyName').AsString); //Post; end; end; end; finally frmZdyAttachGYS.Free; end; end; procedure TfrmSXCKInPut.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 TfrmSXCKInPut.v1Column13PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmProductOrderListSelPBRK := TfrmProductOrderListSelPBRK.Create(Application); with frmProductOrderListSelPBRK do begin if ShowModal = 1 then begin with Self.CDS_Sub do begin Edit; FieldByName('ORDMainIdRK').Value := Trim(frmProductOrderListSelPBRK.Order_Main.fieldbyname('MainId').AsString); // FieldByName('ORDSubIdRK').Value:=Trim(frmProductOrderListSelPBRK.Order_Main.fieldbyname('SubId').AsString); FieldByName('OrderNo').Value := Trim(frmProductOrderListSelPBRK.Order_Main.fieldbyname('OrderNo').AsString); FieldByName('SPSpec').Value := Trim(frmProductOrderListSelPBRK.Order_Main.fieldbyname('MPRTSpec').AsString); FieldByName('SPName').Value := Trim(frmProductOrderListSelPBRK.Order_Main.fieldbyname('MPRTCodeName').AsString); FieldByName('SPCode').Value := Trim(frmProductOrderListSelPBRK.Order_Main.fieldbyname('MPRTCode').AsString); FieldByName('SPKZ').Value := Trim(frmProductOrderListSelPBRK.Order_Main.fieldbyname('MPRTKZ').AsString); FieldByName('SPMF').Value := Trim(frmProductOrderListSelPBRK.Order_Main.fieldbyname('MPRTMF').AsString); FieldByName('QtyUnit').Value := Trim(frmProductOrderListSelPBRK.Order_Main.fieldbyname('OrderUnit').AsString); FieldByName('MPRTQtyNote').Value := Trim(frmProductOrderListSelPBRK.Order_Main.fieldbyname('MPRTQtyNote').AsString); end; end; end; finally frmProductOrderListSelPBRK.Free; end; end; procedure TfrmSXCKInPut.Tv1MouseDown(Sender: TObject; Button: TMouseButton; Shift: TShiftState; X, Y: Integer); begin if CDS_Sub.IsEmpty then Exit; if Trim(canshu3) = '' then exit; v1Column17.Options.Editing := False; v1Column8.Options.Editing := False; v1Column7.Options.Editing := False; (v2Column1.Properties as TcxButtonEditProperties).ReadOnly := True; end; procedure TfrmSXCKInPut.v1Column17PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmZDYHelp := TfrmZDYHelp.Create(Application); with frmZDYHelp do begin flag := 'PBCode'; flagname := '坯布编号'; if ShowModal = 1 then begin with Self.CDS_Sub do begin Edit; FieldByName('SPcode').Value := Trim(frmZDYHelp.ClientDataSet1.fieldbyname('ZdyName').AsString); end; end; end; finally frmZDYHelp.Free; end; end; procedure TfrmSXCKInPut.v1Column8PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmZDYHelp := TfrmZDYHelp.Create(Application); with frmZDYHelp do begin flag := 'PBspec'; flagname := '坯布规格'; if ShowModal = 1 then begin with Self.CDS_Sub do begin Edit; FieldByName('SPspec').Value := Trim(frmZDYHelp.ClientDataSet1.fieldbyname('ZdyName').AsString); end; end; end; finally frmZDYHelp.Free; end; end; procedure TfrmSXCKInPut.v1Column7PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmZDYHelp := TfrmZDYHelp.Create(Application); with frmZDYHelp do begin flag := 'PBKF'; flagname := '坯布称呼'; if ShowModal = 1 then begin with Self.CDS_Sub do begin Edit; FieldByName('SPCF').Value := Trim(frmZDYHelp.ClientDataSet1.fieldbyname('ZdyName').AsString); end; end; end; finally frmZDYHelp.Free; end; end; procedure TfrmSXCKInPut.v1Column1PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmZDYHelp := TfrmZDYHelp.Create(Application); with frmZDYHelp do begin flag := 'PBMF'; flagname := '坯布门幅'; if ShowModal = 1 then begin with Self.CDS_Sub do begin Edit; FieldByName('SPMF').Value := Trim(frmZDYHelp.ClientDataSet1.fieldbyname('ZdyName').AsString); end; end; end; finally frmZDYHelp.Free; end; end; procedure TfrmSXCKInPut.v1Column10PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmZDYHelp := TfrmZDYHelp.Create(Application); with frmZDYHelp do begin flag := 'PBKZ'; flagname := '坯布克重'; if ShowModal = 1 then begin with Self.CDS_Sub do begin Edit; FieldByName('SPKZ').Value := Trim(frmZDYHelp.ClientDataSet1.fieldbyname('ZdyName').AsString); end; end; end; finally frmZDYHelp.Free; end; end; procedure TfrmSXCKInPut.v1Column25PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmZDYHelp := TfrmZDYHelp.Create(self); with frmZDYHelp do begin flag := 'XJLLFLAG'; flagname := '账户类型定义'; if showmodal = 1 then begin with Self.CDS_Sub do begin Edit; FieldByName('yuntype').Value := Trim(frmZDYHelp.ClientDataSet1.fieldbyname('ZdyName').AsString); end; end; end; // initGrid(); finally frmZDYHelp.Free; end; end; end.