unit U_TradeFtyClothInEdit; 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, cxCheckBox, cxPC; type TfrmTradeFtyClothInEdit = class(TfrmBaseInput) cxGrid1: TcxGrid; Tv1: TcxGridDBTableView; v1Column2: TcxGridDBColumn; v1SPName: TcxGridDBColumn; v2Column6: TcxGridDBColumn; cxGrid1Level1: TcxGridLevel; ToolBar1: TToolBar; TBAdd: TToolButton; TBDel: TToolButton; TBSave: TToolButton; TBClose: TToolButton; v1Column4: TcxGridDBColumn; DS_1: TDataSource; CDS_Sub: TClientDataSet; ADOQueryCmd: TADOQuery; ADOQueryMain: TADOQuery; ADOQueryTemp: TADOQuery; GPM_1: 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; cxPageControl1: TcxPageControl; cxTabSheet1: TcxTabSheet; Pnl_F2: TPanel; Label3: TLabel; Label1: TLabel; MasterOrderNo: TEdit; C_Name: TEdit; cxGrid2: TcxGrid; TV2: TcxGridDBTableView; cxGridDBColumn1: TcxGridDBColumn; cxGridDBColumn2: TcxGridDBColumn; cxGridDBColumn4: TcxGridDBColumn; cxGridDBColumn5: TcxGridDBColumn; cxGridDBColumn6: TcxGridDBColumn; cxGridDBColumn7: TcxGridDBColumn; cxGridDBColumn8: TcxGridDBColumn; VC_SCSCode: TcxGridDBColumn; cxGridDBColumn9: TcxGridDBColumn; cxGridDBColumn10: TcxGridDBColumn; cxGridDBColumn11: TcxGridDBColumn; cxGridDBColumn12: TcxGridDBColumn; cxGridDBColumn13: TcxGridDBColumn; cxGridDBColumn14: TcxGridDBColumn; cxGridDBColumn15: TcxGridDBColumn; cxGridDBColumn16: TcxGridDBColumn; v1PRTOrderQty: TcxGridDBColumn; v1OrderUnit: TcxGridDBColumn; cxGridDBColumn17: TcxGridDBColumn; TV2Column1: TcxGridDBColumn; TV2Column2: TcxGridDBColumn; cxGridLevel1: TcxGridLevel; cxTabSheet2: TcxTabSheet; cxGrid3: TcxGrid; TV3: TcxGridDBTableView; cxGridDBColumn18: TcxGridDBColumn; cxGridDBColumn19: TcxGridDBColumn; v1OrderNo: TcxGridDBColumn; v1ConNo: TcxGridDBColumn; v1DeliveryDate: TcxGridDBColumn; cxGridDBColumn20: TcxGridDBColumn; cxGridDBColumn21: TcxGridDBColumn; cxGridDBColumn22: TcxGridDBColumn; v1OrdDefStr1: TcxGridDBColumn; v1MPRTCodeName: TcxGridDBColumn; v1MPRTSpec: TcxGridDBColumn; cxGridDBColumn23: TcxGridDBColumn; v1MPRTMF: TcxGridDBColumn; v1MPRTKZ: TcxGridDBColumn; v1PRTColor: TcxGridDBColumn; cxGridDBColumn24: TcxGridDBColumn; cxGridDBColumn25: TcxGridDBColumn; cxGridDBColumn26: TcxGridDBColumn; cxGridDBColumn27: TcxGridDBColumn; cxGridDBColumn28: TcxGridDBColumn; v1Column3: TcxGridDBColumn; cxGridDBColumn29: TcxGridDBColumn; cxGridDBColumn30: TcxGridDBColumn; cxGridDBColumn31: TcxGridDBColumn; cxGridLevel2: TcxGridLevel; Pnl_F3: TPanel; Label2: TLabel; Label4: TLabel; Edit1: TEdit; Edit2: TEdit; ADO_2: TADOQuery; GPM_2: TcxGridPopupMenu; CDS_2: TClientDataSet; DS_2: TDataSource; DS_3: TDataSource; CDS_3: TClientDataSet; GPM_3: TcxGridPopupMenu; ADO_3: TADOQuery; 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 ButtonEdit(Sender: TObject; AButtonIndex: Integer); procedure TV2DblClick(Sender: TObject); procedure MasterOrderNoKeyPress(Sender: TObject; var Key: Char); procedure TV3DblClick(Sender: TObject); procedure ToolButton2Click(Sender: TObject); procedure cxPageControl1Change(Sender: TObject); private { Private declarations } function CheckData(): Boolean; function SaveData(MSaveType: string): Boolean; procedure InitReceipt(); public { Public declarations } FBCId, canshu3, FSTKName, FKHName: string; end; var frmTradeFtyClothInEdit: TfrmTradeFtyClothInEdit; implementation uses U_DataLink, U_RTFun, U_ZDYHelp, U_CompanySel, U_TradePlanSel, U_ClothInfoSel; {$R *.dfm} function TfrmTradeFtyClothInEdit.CheckData(): Boolean; var mvalue, FReal: double; begin try if CDS_Sub.IsEmpty then raise Exception.Create('明细不能为空!'); if CDS_Sub.Locate('IOTime', null, []) = True then raise Exception.Create('入库时间不能为空!'); if CDS_Sub.Locate('IOType', null, []) = True then raise Exception.Create('入库类型不能为空!'); if CDS_Sub.Locate('FromCoName', null, []) = True then raise Exception.Create('来自单位不能为空!'); if CDS_Sub.Locate('C_Name', null, []) = True then raise Exception.Create('品名不能为空!'); if CDS_Sub.Locate('Piece', null, []) = True then raise Exception.Create('匹数不能为空!'); if CDS_Sub.Locate('Qty', null, []) = True then raise Exception.Create('数量不能为空!'); if CDS_Sub.Locate('QtyUnit', null, []) = True then raise Exception.Create('数量单位不能为空!'); Result := True; except Result := false; application.MessageBox(PChar(Exception(ExceptObject).Message), '提示信息', 0); end; end; procedure TfrmTradeFtyClothInEdit.cxPageControl1Change(Sender: TObject); begin InitReceipt(); end; procedure TfrmTradeFtyClothInEdit.InitReceipt(); var FWSql: string; begin case cxPageControl1.ActivePageIndex of 0: begin FWSql := SGetHintFilters(Pnl_F2, 1, 2); if FWSql <> '' then FWSql := ' and ' + FWSql; with ADO_2 do begin Close; sql.Clear; sql.Add('select * '); sql.Add(' ,DHPS= (select SUM(X.Piece) from BS_Cloth_IO X where X.IOFlag=''入库'' and X.FromPurSId=B.PurSId ) '); sql.Add(' ,DHQty=(select SUM(X.Qty) from BS_Cloth_IO X where X.IOFlag=''入库'' and X.FromPurSId=B.PurSId ) '); sql.add('from Pur_ClothPlan_Main A inner join Pur_ClothPlan_Sub B on A.PurMid=B.PurMid where isnull(A.status,''0'')=''9'' '); if Trim(FWSql) <> '' then sql.Add(FWSql); Open; end; SCreateCDS(ADO_2, CDS_2); SInitCDSData(ADO_2, CDS_2); end; 1: begin FWSql := SGetHintFilters(Pnl_F3, 1, 2); if FWSql <> '' then FWSql := ' and ' + FWSql; with ADO_3 do begin Close; sql.Clear; sql.Add('select A.* '); sql.Add(',SumPiece=(select Sum(X.Piece) from BS_Cloth_IO X where X.IOFlag=''入库'' and X.fromSubID=A.SubID and isnull(X.STKNAME,'''')=' + Quotedstr(Trim(FSTKNAME)) + ')'); sql.Add(',SumQty=(select Sum(X.Qty) from BS_Cloth_IO X where X.IOFlag=''入库'' and X.fromSubID=A.SubID and isnull(X.STKNAME,'''')=' + Quotedstr(Trim(FSTKNAME)) + ')'); sql.Add('from V_Trade_Plan_Fty A '); sql.add('where Status=''9'' '); if Trim(FWSql) <> '' then sql.Add(FWSql); Open; end; SCreateCDS(ADO_3, CDS_3); SInitCDSData(ADO_3, CDS_3); end; end; end; procedure TfrmTradeFtyClothInEdit.MasterOrderNoKeyPress(Sender: TObject; var Key: Char); begin if Key = #13 then begin InitReceipt(); end; end; procedure TfrmTradeFtyClothInEdit.FormClose(Sender: TObject; var Action: TCloseAction); begin inherited; Action := caFree; end; procedure TfrmTradeFtyClothInEdit.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 TfrmTradeFtyClothInEdit.SaveData(MSaveType: string): 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, 'MR', 'BS_Cloth_IO', 4, 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('入库匹数小于出库匹数不能保存!'); 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; if (MSaveType = '检验出库') or (MSaveType = '直接发货') then begin with ADOQueryCmd do begin Close; Sql.Clear; Sql.Add('exec P_BS_Cloth_OutBYIn '); Sql.Add(' @BCIOID=' + quotedstr(Trim(Maxno))); Sql.Add(' ,@OutType=' + quotedstr(MSaveType)); Open; end; if ADOQueryCmd.FieldByName('intReturn').AsInteger = -1 then raise Exception.Create(pchar(trim(ADOQueryCmd.FieldByName('ShowMsg').AsString))); 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 TfrmTradeFtyClothInEdit.TBCloseClick(Sender: TObject); begin Close; end; procedure TfrmTradeFtyClothInEdit.FormShow(Sender: TObject); begin inherited; ReadCxGrid(FSTKName + '入库登记', Tv1, '贸易汇总仓库'); InitReceipt(); 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 TfrmTradeFtyClothInEdit.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 TfrmTradeFtyClothInEdit.TBSaveClick(Sender: TObject); begin if CheckData() = false then exit; if SaveData('保存') then begin Application.MessageBox('保存成功!', '提示', 0); //ModalResult:=1; Exit; end; end; procedure TfrmTradeFtyClothInEdit.ToolButton1Click(Sender: TObject); begin WriteCxGrid(FSTKName + '入库登记', Tv1, '贸易汇总仓库'); end; procedure TfrmTradeFtyClothInEdit.ToolButton2Click(Sender: TObject); begin if CheckData() = false then exit; if SaveData('直接发货') then begin Application.MessageBox('保存成功!', '提示', 0); //ModalResult:=1; Exit; end; end; procedure TfrmTradeFtyClothInEdit.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 TfrmTradeFtyClothInEdit.Tv1Column4PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmTradePlanSel := TfrmTradePlanSel.Create(Application); with frmTradePlanSel do begin FSTKName := Self.FSTKName; 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); end; end; end; finally frmTradePlanSel.Free; end; end; procedure TfrmTradeFtyClothInEdit.TV2DblClick(Sender: TObject); var MMaxno: string; CurRow: Integer; begin CurRow := Tv2.Controller.FocusedRowIndex; with CDS_2 do begin Edit; Fieldbyname('SSel').Value := 1; Post; end; with CDS_2 do begin DisableControls; First; while not eof do begin if CDS_2.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(CDS_2.fieldbyname('Sellno').AsString); FieldByName('FromCoName').Value := Trim(CDS_2.fieldbyname('Sellname').AsString); FieldByName('FromPurNo').Value := Trim(CDS_2.fieldbyname('PurNo').AsString); FieldByName('FromPurMId').Value := Trim(CDS_2.fieldbyname('PurMid').AsString); FieldByName('FromPurSId').Value := Trim(CDS_2.fieldbyname('PurSId').AsString); FieldByName('C_Code').Value := Trim(CDS_2.fieldbyname('C_Code').AsString); FieldByName('C_Name').Value := Trim(CDS_2.fieldbyname('C_Name').AsString); FieldByName('C_Spec').Value := Trim(CDS_2.fieldbyname('C_Spec').AsString); FieldByName('C_Composition').Value := Trim(CDS_2.fieldbyname('C_Composition').AsString); FieldByName('C_Width').Value := Trim(CDS_2.fieldbyname('C_Width').AsString); FieldByName('C_GramWeight').Value := Trim(CDS_2.fieldbyname('C_GramWeight').AsString); FieldByName('C_Color').Value := Trim(CDS_2.fieldbyname('C_Color').AsString); FieldByName('C_ColorNo').Value := Trim(CDS_2.fieldbyname('C_ColorNo').AsString); FieldByName('C_Pattern').Value := Trim(CDS_2.fieldbyname('C_Pattern').AsString); FieldByName('C_StyleNo').Value := Trim(CDS_2.fieldbyname('C_StyleNo').AsString); FieldByName('QtyUnit').Value := Trim(CDS_2.fieldbyname('ConUnit').AsString); end; end; with CDS_2 do begin Edit; Fieldbyname('SSel').Value := 0; Post; end; Next; end; EnableControls; end; Tv2.Controller.FocusedRowIndex := CurRow; end; procedure TfrmTradeFtyClothInEdit.TV3DblClick(Sender: TObject); var MMaxno: string; CurRow: Integer; begin CurRow := Tv3.Controller.FocusedRowIndex; with CDS_3 do begin Edit; Fieldbyname('SSel').Value := 1; Post; end; with CDS_3 do begin DisableControls; First; while not eof do begin if CDS_3.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(CDS_3.fieldbyname('FtyNo').AsString); FieldByName('FromCoName').Value := Trim(CDS_3.fieldbyname('FtyName').AsString); FieldByName('FromOrdNo').Value := Trim(CDS_3.fieldbyname('OrderNo').AsString); FieldByName('FromMainId').Value := Trim(CDS_3.fieldbyname('MainId').AsString); FieldByName('FromSubId').Value := Trim(CDS_3.fieldbyname('SubId').AsString); FieldByName('C_Code').Value := Trim(CDS_3.fieldbyname('C_Code').AsString); FieldByName('C_Name').Value := Trim(CDS_3.fieldbyname('C_Name').AsString); FieldByName('C_Spec').Value := Trim(CDS_3.fieldbyname('C_Spec').AsString); FieldByName('C_Composition').Value := Trim(CDS_3.fieldbyname('C_Composition').AsString); FieldByName('C_Width').Value := Trim(CDS_3.fieldbyname('C_Width').AsString); FieldByName('C_GramWeight').Value := Trim(CDS_3.fieldbyname('C_GramWeight').AsString); FieldByName('C_Color').Value := Trim(CDS_3.fieldbyname('C_Color').AsString); FieldByName('C_ColorNo').Value := Trim(CDS_3.fieldbyname('C_ColorNo').AsString); FieldByName('C_Pattern').Value := Trim(CDS_3.fieldbyname('C_Pattern').AsString); FieldByName('C_StyleNo').Value := Trim(CDS_3.fieldbyname('C_StyleNo').AsString); FieldByName('QtyUnit').Value := Trim(CDS_3.fieldbyname('OrdUnit').AsString); end; end; with CDS_3 do begin Edit; Fieldbyname('SSel').Value := 0; Post; end; Next; end; EnableControls; end; Tv3.Controller.FocusedRowIndex := CurRow; end; procedure TfrmTradeFtyClothInEdit.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; 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); end; end; end; finally frmClothInfoSel.Free; end; end; procedure TfrmTradeFtyClothInEdit.v1Column14PropertiesButtonClick(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('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); end; end; end; finally frmCompanySel.Free; end; end; procedure TfrmTradeFtyClothInEdit.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 TfrmTradeFtyClothInEdit.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 TfrmTradeFtyClothInEdit.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.