unit U_TradeFinishClothInEdit; 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, dxDateRanges, dxBarBuiltInMenu, U_BaseInput, System.ImageList, Vcl.ImgList, dxSkinWXI, dxScrollbarAnnotations; type TfrmTradeFinishClothInEdit = class(TfrmBaseInput) cxGrid2: TcxGrid; Tv1: TcxGridDBTableView; v1Column2: TcxGridDBColumn; v1SPName: 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; v1FactoryName: TcxGridDBColumn; v1Column6: TcxGridDBColumn; v1SPSpec: TcxGridDBColumn; v1QtyUnit: TcxGridDBColumn; v1Column5: TcxGridDBColumn; v1Column1: TcxGridDBColumn; v1SPMF: TcxGridDBColumn; v1Column8: TcxGridDBColumn; v1Column9: TcxGridDBColumn; v1Column7: TcxGridDBColumn; Tv1Column3: TcxGridDBColumn; Tv1Column5: TcxGridDBColumn; Tv1Column1: TcxGridDBColumn; Tv1Column2: TcxGridDBColumn; Tv1Column4: TcxGridDBColumn; ToolButton1: TToolButton; Tv1Column6: TcxGridDBColumn; ToolButton2: TToolButton; Tv1Column7: TcxGridDBColumn; Tv1Column8: TcxGridDBColumn; Tv1Column9: TcxGridDBColumn; Tv1Column10: TcxGridDBColumn; Tv1Column11: TcxGridDBColumn; ToolButton3: TToolButton; Tv1Column12: 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 v1Column14PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); procedure v2Column1PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); procedure v1Column5PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); procedure v1Column8PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); procedure Tv1Column1PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); procedure Tv1Column4PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); procedure ToolButton1Click(Sender: TObject); procedure ToolButton2Click(Sender: TObject); procedure ButtonEdit(Sender: TObject; AButtonIndex: Integer); procedure ToolButton3Click(Sender: TObject); private { Private declarations } function SaveCKData(): Boolean; function ValidateInData(ARow: Integer): Boolean; public { Public declarations } FBCId, canshu3, FSTKName, FKHName: string; end; var frmTradeFinishClothInEdit: TfrmTradeFinishClothInEdit; implementation uses U_DataLink, U_RTFun, U_ZDYHelp, U_CompanySel, U_TradePlanSel, U_ClothInfoSel; {$R *.dfm} function TfrmTradeFinishClothInEdit.ValidateInData(ARow: Integer): Boolean; var IOType, FromSubId, FromOrdNo, C_Code: string; HasPlan, HasProcess, HasOutRecord: Boolean; MaxGlideIdx: Integer; LastProcessName: string; begin Result := True; IOType := Trim(CDS_Sub.FieldByName('IOType').AsString); FromSubId := Trim(CDS_Sub.FieldByName('FromSubId').AsString); FromOrdNo := Trim(CDS_Sub.FieldByName('FromOrdNo').AsString); C_Code := Trim(CDS_Sub.FieldByName('C_Code').AsString); if IOType = '采购入库' then begin if FromSubId = '' then begin Application.MessageBox(PChar('第' + IntToStr(ARow) + '行:采购入库必须关联采购计划单!'), PChar('验证失败'), MB_ICONERROR); Result := False; Exit; end; with ADOQueryTemp do begin Close; SQL.Clear; SQL.Add('SELECT 1 FROM Pur_ClothPlan_sub WHERE SubId = :SubId'); Parameters.ParamByName('SubId').Value := FromSubId; Open; HasPlan := not IsEmpty; Close; end; if not HasPlan then begin Application.MessageBox(PChar('第' + IntToStr(ARow) + '行:关联的采购计划单不存在!'), PChar('验证失败'), MB_ICONERROR); Result := False; Exit; end; end else if IOType = '加工入库' then begin with ADOQueryTemp do begin Close; SQL.Clear; SQL.Add('SELECT TOP 1 GlideIdx, ProcessName'); SQL.Add('FROM BS_Cloth_Glide g'); SQL.Add('INNER JOIN Bs_Cloth_Info i ON g.BCIID = i.BCIID'); SQL.Add('WHERE i.C_Code = :C_Code'); SQL.Add('ORDER BY GlideIdx DESC'); Parameters.ParamByName('C_Code').Value := C_Code; Open; HasProcess := not IsEmpty; if HasProcess then begin MaxGlideIdx := FieldByName('GlideIdx').AsInteger; LastProcessName := Trim(FieldByName('ProcessName').AsString); end; Close; end; if not HasProcess then begin if FromOrdNo = '' then begin Application.MessageBox(PChar('第' + IntToStr(ARow) + '行:加工入库必须关联订单号!'), PChar('验证失败'), MB_ICONERROR); Result := False; Exit; end; with ADOQueryTemp do begin Close; SQL.Clear; SQL.Add('SELECT 1 FROM BS_Cloth_IO'); SQL.Add('WHERE FromOrdNO = :FromOrdNo'); SQL.Add('AND ioFlag = ''出库'''); SQL.Add('AND ISNULL(stkName, '''') = ''贸易成品'''); Parameters.ParamByName('FromOrdNo').Value := FromOrdNo; Open; HasOutRecord := not IsEmpty; Close; end; if not HasOutRecord then begin Application.MessageBox(PChar('第' + IntToStr(ARow) + '行:该产品无工艺工序,必须有对应的贸易成品出库记录才能入库!'), PChar('验证失败'), MB_ICONERROR); Result := False; Exit; end; end else begin if FromSubId = '' then begin Application.MessageBox(PChar('第' + IntToStr(ARow) + '行:加工入库必须关联采购计划单!'), PChar('验证失败'), MB_ICONERROR); Result := False; Exit; end; with ADOQueryTemp do begin Close; SQL.Clear; SQL.Add('SELECT 1 FROM Pur_ClothPlan_sub s'); SQL.Add('INNER JOIN Pur_ClothPlan_Main m ON s.PurMId = m.PurMId'); SQL.Add('INNER JOIN BS_Cloth_IO io ON io.FromOrdNO = m.PurNo'); SQL.Add('WHERE s.SubId = :SubId'); SQL.Add('AND m.GX = :GX'); SQL.Add('AND io.stkname = ''贸易外加工布'''); SQL.Add('AND io.ioFlag = ''出库'''); Parameters.ParamByName('SubId').Value := FromSubId; Parameters.ParamByName('GX').Value := LastProcessName; Open; HasOutRecord := not IsEmpty; Close; end; if not HasOutRecord then begin Application.MessageBox(PChar(Format('第%d行:该产品有%d道工序,必须有最后一道工序"%s"对应的贸易外加工布出库记录才能入库!', [ARow, MaxGlideIdx, LastProcessName])), PChar('验证失败'), MB_ICONERROR); Result := False; Exit; end; end; end; end; procedure TfrmTradeFinishClothInEdit.FormClose(Sender: TObject; var Action: TCloseAction); begin inherited; Action := caFree; end; procedure TfrmTradeFinishClothInEdit.TBAddClick(Sender: TObject); begin if CDS_Sub.IsEmpty = False then begin CopyAddRowCDS(CDS_Sub); with CDS_Sub do begin Edit; FieldByName('BCIOID').Value := null; FieldByName('StkCoNo').Value := '本厂仓库'; FieldByName('StkCoName').Value := '本厂仓库'; post; end; end else begin with CDS_Sub do begin Append; FieldByName('IOTime').Value := Trim(FormatDateTime('yyyy-MM-dd', Now)); FieldByName('StkCoNo').Value := '本厂仓库'; FieldByName('StkCoName').Value := '本厂仓库'; // FieldByName('QtyUnit').Value := 'KG'; Post; end; end; end; function TfrmTradeFinishClothInEdit.SaveCKData(): Boolean; var Maxno, MBCIOID: 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 BS_Cloth_IO where BCIOID=''' + Trim(CDS_Sub.fieldbyname('BCIOID').AsString) + ''''); open; end; MBCIOID := Trim(ADOQueryTemp.fieldbyname('BCIOID').AsString); if Trim(MBCIOID) = '' then begin if not GetLSNo(ADOQueryCmd, Maxno, 'PR', 'BS_Cloth_IO', 3, 1) then raise Exception.Create('取染色坯布入库编号失败!'); end else begin Maxno := Trim(MBCIOID); end; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('select * from BS_Cloth_IO where BCIOID=''' + Trim(Maxno) + ''''); Open; end; with ADOQueryCmd do begin if Trim(MBCIOID) = '' then begin Append; FieldByName('Fillid').Value := Trim(Dcode); FieldByName('Filler').Value := Trim(DName); end else begin Edit; FieldByName('Editid').Value := Trim(Dcode); FieldByName('Editer').Value := Trim(DName); FieldByName('EditTime').Value := SGetServerDate(ADOQueryTemp); end; RTSetSaveDataCDS(ADOQueryCmd, Tv1, CDS_Sub, 'BS_Cloth_IO', 0); FieldByName('FromCoNo').Value := CDS_Sub.fieldbyname('FromCoNo').Value; FieldByName('StkCoNo').Value := CDS_Sub.fieldbyname('StkCoNo').Value; FieldByName('FromMainId').Value := CDS_Sub.fieldbyname('FromMainId').Value; FieldByName('FromSubId').Value := CDS_Sub.fieldbyname('FromSubId').Value; FieldByName('BCIOID').Value := Trim(Maxno); FieldByName('STKID').Value := Trim(Maxno); FieldByName('STKName').Value := FSTKName; FieldByName('IOFlag').Value := '入库'; FieldByName('IOQtyFlag').Value := 1; Post; end; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('Update BS_Cloth_IO Set StkPiece=(select Sum(isnull(Piece,0)*IOQtyFlag) from BS_Cloth_IO A where A.STKID=BS_Cloth_IO.BCIOID )'); sql.Add(',StkQty=(select Sum(isnull(Qty,0)*IOQtyFlag) from BS_Cloth_IO A where A.STKID=BS_Cloth_IO.BCIOID )'); sql.Add(' where BCIOID=''' + Trim(Maxno) + ''''); ExecSQL; end; with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select stkQty,StkPiece from BS_Cloth_IO where BCIOID=''' + Trim(Maxno) + ''''); Open; end; if ADOQueryTemp.FieldByName('stkQty').Value < 0 then raise Exception.Create('入库数量小于出库数量不能保存!'); if ADOQueryTemp.FieldByName('StkPiece').Value < 0 then raise Exception.Create('入库匹数小于出库匹数不能保存!'); // if CDS_Sub.fieldbyname('IOType').Value = '采购入库' then // begin with ADOQueryCmd do begin Close; sql.Clear; sql.Add('insert into Finance_Need_Up(UType,UDataId,UOperation,UOperator,UModule,UDetails) '); sql.Add('values(''待检布入库'' '); sql.Add(',' + quotedstr(Maxno)); sql.Add(',''保存'' '); sql.Add(',' + quotedstr(DName)); sql.Add(',' + quotedstr(trim(self.Caption))); sql.Add(',' + quotedstr(Maxno)); sql.Add(') '); ExecSQL; end; // end; Edit; FieldByName('BCIOID').Value := Trim(Maxno); Post; Next; end; end; CDS_Sub.EnableControls; ADOQueryCmd.Connection.CommitTrans; Result := True; except Result := False; ADOQueryCmd.Connection.RollbackTrans; application.MessageBox(PChar(Exception(ExceptObject).Message), '提示信息', 0); end; end; procedure TfrmTradeFinishClothInEdit.TBCloseClick(Sender: TObject); begin Close; end; procedure TfrmTradeFinishClothInEdit.FormShow(Sender: TObject); begin inherited; ReadCxGrid(FSTKName + '入库登记', Tv1, '贸易汇总仓库'); with ADOQueryTemp do begin Close; sql.Clear; sql.Add(' select A.* '); sql.Add(' from BS_Cloth_IO A'); sql.Add(' where BCIOID=''' + Trim(FBCId) + ''''); Open; end; SCreateCDS(ADOQueryTemp, CDS_Sub); SInitCDSData(ADOQueryTemp, CDS_Sub); end; procedure TfrmTradeFinishClothInEdit.TBDelClick(Sender: TObject); begin if CDS_Sub.IsEmpty then Exit; if Trim(CDS_Sub.fieldbyname('BCIOID').AsString) <> '' then begin if Application.MessageBox('确定要删除数据吗?', '提示', 32 + 4) <> IDYES then Exit; with ADOQueryTemp do begin Close; sql.Clear; sql.Add('exec P_Fin_Flow_Judge '); Sql.Add(' @FFIDS=' + quotedstr(Trim(CDS_Sub.fieldbyname('BCIOID').AsString))); Sql.Add(',@DCode=' + quotedstr(Trim(DCode))); Sql.Add(',@DName=' + quotedstr(Trim(DName))); Open; end; if ADOQueryTemp.FieldByName('intReturn').AsInteger = -1 then begin Application.MessageBox(PChar(ADOQueryTemp.fieldbyname('ShowMsg').AsString), '提示', 0); exit; end; try ADOQueryCmd.Connection.BeginTrans; with ADOQueryCmd do begin Close; Sql.Clear; sql.Add('insert into Finance_Need_Up(UType,UDataId,UOperation,UOperator,UModule,UDetails) '); sql.Add('values(''待检布入库'' '); sql.Add(',' + quotedstr(Trim(CDS_Sub.fieldbyname('BCIOID').AsString))); sql.Add(',''删除'' '); sql.Add(',' + quotedstr(DName)); sql.Add(',' + quotedstr(trim(self.Caption))); sql.Add(',' + quotedstr(Trim(CDS_Sub.fieldbyname('BCIOID').AsString))); sql.Add(') '); Sql.Add('exec P_BS_Cloth_In_Del '); Sql.Add(' @BCIOIDS=' + quotedstr(Trim(CDS_Sub.fieldbyname('BCIOID').AsString))); Sql.Add(',@DCode=' + quotedstr(Trim(DCode))); Sql.Add(',@DName=' + quotedstr(Trim(DName))); Open; end; if ADOQueryCmd.FieldByName('intReturn').AsInteger = -1 then raise Exception.Create(pchar(trim(ADOQueryCmd.FieldByName('ShowMsg').AsString))); ADOQueryCmd.Connection.CommitTrans; CDS_Sub.Delete; except ADOQueryCmd.Connection.RollbackTrans; application.MessageBox(PChar(Exception(ExceptObject).Message), '提示信息', 0); end; end else begin CDS_Sub.Delete; end; end; procedure TfrmTradeFinishClothInEdit.TBSaveClick(Sender: TObject); var RowIndex: Integer; begin if CDS_Sub.IsEmpty then Exit; if CDS_Sub.Locate('QtyUnit', null, []) = True then begin Application.MessageBox('数量单位不能为空!', '提示', 0); Exit; end; if CDS_Sub.Locate('IOTime', null, []) = True then begin Application.MessageBox('入库时间不能为空!', '提示', 0); Exit; end; if CDS_Sub.Locate('IOType', null, []) = True then begin Application.MessageBox('入库类型不能为空!', '提示', 0); Exit; end; if CDS_Sub.Locate('C_Name', null, []) = True then begin Application.MessageBox('品名不能为空!', '提示', 0); Exit; end; if CDS_Sub.Locate('Piece', 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('FromCoName', null, []) = True then begin Application.MessageBox('来自单位不能为空!', '提示', 0); Exit; end; if CDS_Sub.Locate('FromCoName', '', []) = True then begin Application.MessageBox('来自单位不能为空!', '提示', 0); Exit; end; CDS_Sub.DisableControls; try CDS_Sub.First; RowIndex := 1; while not CDS_Sub.Eof do begin if not ValidateInData(RowIndex) then begin // 验证失败,定位到错误行并退出 Tv1.DataController.FocusedRowIndex := RowIndex - 1; Exit; end; CDS_Sub.Next; Inc(RowIndex); end; finally CDS_Sub.EnableControls; end; if SaveCKData() then begin Application.MessageBox('保存成功!', '提示', 0); //ModalResult:=1; Exit; end; end; procedure TfrmTradeFinishClothInEdit.ToolButton1Click(Sender: TObject); begin WriteCxGrid(FSTKName + '入库登记', Tv1, '贸易汇总仓库'); end; procedure TfrmTradeFinishClothInEdit.ToolButton2Click(Sender: TObject); begin try frmTradePlanSel := TfrmTradePlanSel.Create(Application); with frmTradePlanSel do begin if ShowModal = 1 then begin with frmTradePlanSel.CDS_1 do begin DisableControls; First; while not eof do begin if frmTradePlanSel.CDS_1.fieldbyname('SSel').AsBoolean then begin with Self.CDS_Sub do begin append; FieldByName('IOTime').Value := Trim(FormatDateTime('yyyy-MM-dd', Now)); FieldByName('BCIOID').Value := null; FieldByName('IOType').Value := '加工入库'; FieldByName('StkCoNo').Value := '本厂仓库'; FieldByName('StkCoName').Value := '本厂仓库'; FieldByName('FromCoNo').Value := Trim(frmTradePlanSel.CDS_1.fieldbyname('FtyNo').AsString); FieldByName('FromCoName').Value := Trim(frmTradePlanSel.CDS_1.fieldbyname('FtyName').AsString); FieldByName('FromOrdNo').Value := Trim(frmTradePlanSel.CDS_1.fieldbyname('OrderNo').AsString); FieldByName('FromMainId').Value := Trim(frmTradePlanSel.CDS_1.fieldbyname('MainId').AsString); FieldByName('FromSubId').Value := Trim(frmTradePlanSel.CDS_1.fieldbyname('SubId').AsString); FieldByName('C_Code').Value := Trim(frmTradePlanSel.CDS_1.fieldbyname('C_Code').AsString); FieldByName('C_Name').Value := Trim(frmTradePlanSel.CDS_1.fieldbyname('C_Name').AsString); FieldByName('C_Spec').Value := Trim(frmTradePlanSel.CDS_1.fieldbyname('C_Spec').AsString); FieldByName('C_Composition').Value := Trim(frmTradePlanSel.CDS_1.fieldbyname('C_Composition').AsString); FieldByName('C_Width').Value := Trim(frmTradePlanSel.CDS_1.fieldbyname('C_Width').AsString); FieldByName('C_GramWeight').Value := Trim(frmTradePlanSel.CDS_1.fieldbyname('C_GramWeight').AsString); FieldByName('C_Color').Value := Trim(frmTradePlanSel.CDS_1.fieldbyname('C_Color').AsString); FieldByName('C_ColorNo').Value := Trim(frmTradePlanSel.CDS_1.fieldbyname('C_ColorNo').AsString); FieldByName('C_Pattern').Value := Trim(frmTradePlanSel.CDS_1.fieldbyname('C_Pattern').AsString); FieldByName('C_StyleNo').Value := Trim(frmTradePlanSel.CDS_1.fieldbyname('C_StyleNo').AsString); // FieldByName('QtyUnit').Value := Trim(frmTradePlanSel.CDS_1.fieldbyname('OrdUnit').AsString); FieldByName('Saleser').Value := Trim(frmTradePlanSel.CDS_1.fieldbyname('Saleser').AsString); // FieldByName('SalesId').Value := Trim(frmTradePlanSel.CDS_1.fieldbyname('SalesId').AsString); end; end; Next; end; EnableControls; end; end; end; finally frmTradePlanSel.Free; end; end; procedure TfrmTradeFinishClothInEdit.ToolButton3Click(Sender: TObject); var PFromCoNo: string; begin if CDS_Sub.IsEmpty then Exit; PFromCoNo := CDS_Sub.FieldByName('FromCoNo').AsString; OneKeyPost(Tv1, CDS_Sub); if Tv1.Controller.FocusedColumn.DataBinding.FilterFieldName = 'FromCoName' then begin with CDS_Sub do begin DisableControls; first; while not Eof do begin edit; FieldByName('FromCoNo').AsString := PFromCoNo; post; Next; end; EnableControls; end; end; end; procedure TfrmTradeFinishClothInEdit.Tv1Column1PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmCompanySel := TfrmCompanySel.Create(Application); with frmCompanySel do begin FCoType := '供应商'; if ShowModal = 1 then begin with Self.CDS_Sub do begin Edit; FieldByName('StkCoNo').Value := Trim(CDS_1.fieldbyname('CoCode').AsString); FieldByName('StkCoName').Value := Trim(CDS_1.fieldbyname('CoAbbrName').AsString); end; end; end; finally frmCompanySel.Free; end; end; procedure TfrmTradeFinishClothInEdit.Tv1Column4PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmTradePlanSel := TfrmTradePlanSel.Create(Application); with frmTradePlanSel do begin if ShowModal = 1 then begin with Self.CDS_Sub do begin Edit; FieldByName('FromCoNo').Value := Trim(frmTradePlanSel.CDS_1.fieldbyname('FtyNo').AsString); FieldByName('FromCoName').Value := Trim(frmTradePlanSel.CDS_1.fieldbyname('FtyName').AsString); FieldByName('FromOrdNo').Value := Trim(frmTradePlanSel.CDS_1.fieldbyname('OrderNo').AsString); FieldByName('FromMainId').Value := Trim(frmTradePlanSel.CDS_1.fieldbyname('MainId').AsString); FieldByName('FromSubId').Value := Trim(frmTradePlanSel.CDS_1.fieldbyname('SubId').AsString); FieldByName('C_Code').Value := Trim(frmTradePlanSel.CDS_1.fieldbyname('C_Code').AsString); FieldByName('C_Name').Value := Trim(frmTradePlanSel.CDS_1.fieldbyname('C_Name').AsString); FieldByName('C_Spec').Value := Trim(frmTradePlanSel.CDS_1.fieldbyname('C_Spec').AsString); FieldByName('C_Composition').Value := Trim(frmTradePlanSel.CDS_1.fieldbyname('C_Composition').AsString); FieldByName('C_Width').Value := Trim(frmTradePlanSel.CDS_1.fieldbyname('C_Width').AsString); FieldByName('C_GramWeight').Value := Trim(frmTradePlanSel.CDS_1.fieldbyname('C_GramWeight').AsString); FieldByName('C_Color').Value := Trim(frmTradePlanSel.CDS_1.fieldbyname('C_Color').AsString); FieldByName('C_ColorNo').Value := Trim(frmTradePlanSel.CDS_1.fieldbyname('C_ColorNo').AsString); FieldByName('C_Pattern').Value := Trim(frmTradePlanSel.CDS_1.fieldbyname('C_Pattern').AsString); FieldByName('Saleser').Value := Trim(frmTradePlanSel.CDS_1.fieldbyname('Saleser').AsString); // FieldByName('SalesId').Value := Trim(frmTradePlanSel.CDS_1.fieldbyname('SalesId').AsString); end; end; end; finally frmTradePlanSel.Free; end; end; procedure TfrmTradeFinishClothInEdit.ButtonEdit(Sender: TObject; AButtonIndex: Integer); begin try frmClothInfoSel := TfrmClothInfoSel.Create(Application); with frmClothInfoSel do begin if ShowModal = 1 then begin with Self.CDS_Sub do begin // append; Edit; FieldByName('C_Code').Value := trim(frmClothInfoSel.CDS_1.Fieldbyname('C_Code').AsString); FieldByName('C_Name').Value := trim(frmClothInfoSel.CDS_1.Fieldbyname('C_Name').AsString); FieldByName('C_Spec').Value := trim(frmClothInfoSel.CDS_1.Fieldbyname('C_Spec').AsString); FieldByName('C_Composition').Value := trim(frmClothInfoSel.CDS_1.Fieldbyname('C_Composition').AsString); FieldByName('C_Width').Value := trim(frmClothInfoSel.CDS_1.Fieldbyname('C_Width').AsString); FieldByName('C_GramWeight').Value := trim(frmClothInfoSel.CDS_1.Fieldbyname('C_GramWeight').AsString); Fieldbyname('C_ColorNo').value := trim(frmClothInfoSel.CDS_1.Fieldbyname('C_ColorNo').AsString); Fieldbyname('C_Color').value := trim(frmClothInfoSel.CDS_1.Fieldbyname('C_Color').AsString); Fieldbyname('C_Pattern').value := trim(frmClothInfoSel.CDS_1.Fieldbyname('C_Pattern').AsString); Post; end; end; end; finally frmClothInfoSel.Free; end; end; procedure TfrmTradeFinishClothInEdit.v1Column14PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmCompanySel := TfrmCompanySel.Create(Application); with frmCompanySel do begin if CDS_Sub.FieldByName('IOType').value = '销售退回' then begin FCoType := '客户'; end else begin FCoType := '供应商'; end; if ShowModal = 1 then begin with Self.CDS_Sub do begin Edit; FieldByName('FromCoNo').Value := Trim(CDS_1.fieldbyname('CoCode').AsString); FieldByName('FromCoName').Value := Trim(CDS_1.fieldbyname('CoAbbrName').AsString); // FieldByName('SalesER').Value := Trim(CDS_1.fieldbyname('SalesER').AsString); post; end; end; end; finally frmCompanySel.Free; end; end; procedure TfrmTradeFinishClothInEdit.v2Column1PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmZDYHelp := TfrmZDYHelp.Create(Application); with frmZDYHelp do begin flag := 'JWLYCLName'; flagname := '品名'; MainType := FSTKName; if ShowModal = 1 then begin with Self.CDS_Sub do begin Edit; FieldByName('C_Name').Value := Trim(frmZDYHelp.ClientDataSet1.fieldbyname('ZdyName').AsString); end; end; end; finally frmZDYHelp.Free; end; end; procedure TfrmTradeFinishClothInEdit.v1Column5PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmZDYHelp := TfrmZDYHelp.Create(Application); with frmZDYHelp do begin flag := 'StkPosition'; flagname := '库位'; MainType := FSTKName; if ShowModal = 1 then begin with Self.CDS_Sub do begin Edit; FieldByName('StkPosition').Value := Trim(frmZDYHelp.ClientDataSet1.fieldbyname('ZdyName').AsString); end; end; end; finally frmZDYHelp.Free; end; end; procedure TfrmTradeFinishClothInEdit.v1Column8PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmZDYHelp := TfrmZDYHelp.Create(Application); with frmZDYHelp do begin flag := 'C_Spec'; flagname := '规格'; MainType := FSTKName; if ShowModal = 1 then begin with Self.CDS_Sub do begin Edit; FieldByName('C_Spec').Value := Trim(frmZDYHelp.ClientDataSet1.fieldbyname('ZdyName').AsString); end; end; end; finally frmZDYHelp.Free; end; end; end.