unit U_DJBCKOutPut; 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, cxSpinEdit, StdCtrls, ExtCtrls, cxLookAndFeels, cxLookAndFeelPainters, cxNavigator, dxSkinsCore, dxSkinsDefaultPainters, dxDateRanges, dxBarBuiltInMenu, Vcl.Menus, U_BaseInput, System.ImageList, Vcl.ImgList, U_BaseHelp; type TfrmDJBCKOutPut = class(TfrmBaseInput) ToolBar1: TToolBar; TBAdd: TToolButton; TBDel: TToolButton; TBSave: TToolButton; TBClose: TToolButton; DataSource3: TDataSource; CDS_Sub: TClientDataSet; ADOQueryCmd: TADOQuery; ADOQueryMain: TADOQuery; ADOQueryTemp: TADOQuery; cxGridPopupMenu2: TcxGridPopupMenu; cxGrid2: TcxGrid; Tv1: TcxGridDBTableView; v1Column6: TcxGridDBColumn; v1Column2: TcxGridDBColumn; v1CRType: TcxGridDBColumn; v1Column13: TcxGridDBColumn; v1Column14: TcxGridDBColumn; v2Column1: TcxGridDBColumn; v1Column8: TcxGridDBColumn; v1Column7: TcxGridDBColumn; v1Column1: TcxGridDBColumn; v1Column10: TcxGridDBColumn; v1Column11: TcxGridDBColumn; v1Column9: TcxGridDBColumn; v2Column6: TcxGridDBColumn; v1Column3: TcxGridDBColumn; v1Column16: TcxGridDBColumn; v1Column12: TcxGridDBColumn; cxGrid2Level1: TcxGridLevel; v1Column5: TcxGridDBColumn; v1Column17: TcxGridDBColumn; v1Column19: TcxGridDBColumn; v1Column4: TcxGridDBColumn; v1Column15: TcxGridDBColumn; v1Column20: TcxGridDBColumn; v1Column21: TcxGridDBColumn; v1Column22: TcxGridDBColumn; ToolButton1: TToolButton; Panel4: TPanel; Label14: TLabel; Panel10: TPanel; Image2: TImage; Button1: TButton; GroupBox1: TGroupBox; CheckBox1: TCheckBox; CheckBox2: TCheckBox; CheckBox3: TCheckBox; CheckBox4: TCheckBox; CheckBox5: TCheckBox; Button2: TButton; CheckBox6: TCheckBox; CheckBox7: TCheckBox; v1Column18: TcxGridDBColumn; v1Column23: TcxGridDBColumn; v1Column24: TcxGridDBColumn; ToolButton3: TToolButton; Tv1Column2: TcxGridDBColumn; ToolButton2: TToolButton; Tv1Column4: TcxGridDBColumn; Tv1Column5: TcxGridDBColumn; CDS_KC: TClientDataSet; PopupMenu1: TPopupMenu; N3: TMenuItem; Tv1Column6: TcxGridDBColumn; Tv1Column7: TcxGridDBColumn; Tv1Column8: TcxGridDBColumn; Tv1Column3: TcxGridDBColumn; Tv1Column9: TcxGridDBColumn; chkJYFS: TCheckBox; 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 v1Column1PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); procedure v1Column11PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); procedure v1Column5PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); procedure Tv1MouseDown(Sender: TObject; Button: TMouseButton; Shift: TShiftState; X, Y: Integer); procedure Image2Click(Sender: TObject); procedure ToolButton1Click(Sender: TObject); procedure Button1Click(Sender: TObject); procedure Button2Click(Sender: TObject); procedure ToolButton3Click(Sender: TObject); procedure Tv1CustomDrawIndicatorCell(Sender: TcxGridTableView; ACanvas: TcxCanvas; AViewInfo: TcxCustomGridIndicatorItemViewInfo; var ADone: Boolean); procedure ToolButton2Click(Sender: TObject); procedure v2Column6PropertiesEditValueChanged(Sender: TObject); procedure N3Click(Sender: TObject); procedure Tv1Column1PropertiesEditValueChanged(Sender: TObject); procedure v1Column19PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); procedure Tv1Column2PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); procedure v1Column17PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); private { Private declarations } function SaveCKData(): Boolean; procedure UpKYKC(); public { Public declarations } FBCId, canshu2: string; end; var frmDJBCKOutPut: TfrmDJBCKOutPut; implementation uses U_DataLink, U_RTFun, U_ClothContractListHZCX, U_ZDYHelp, U_DJBCKKCSelList, U_GYSSelList, U_ZdyAttachGYS, U_ProductOrderLBNameSel, U_DDDJBCKKCSelList, U_ProductOrderListSel; {$R *.dfm} procedure TfrmDJBCKOutPut.UpKYKC(); begin CDS_KC.EmptyDataSet; with CDS_Sub do begin DisableControls; First; while not Eof do begin if not CDS_KC.Locate('FZSPID', Trim(CDS_Sub.FieldByName('FZSPID').AsString), []) then begin with CDS_KC do begin Append; FieldByName('FZSPID').Value := CDS_Sub.FieldByName('FZSPID').AsString; FieldByName('MaxQty').Value := CDS_Sub.FieldByName('IKCQty').AsFloat; FieldByName('MinQty').Value := CDS_Sub.FieldByName('IKCQty').AsFloat - CDS_Sub.FieldByName('Qty').AsFloat; Post; end; end else begin with CDS_KC do begin Edit; FieldByName('MinQty').Value := FieldByName('MinQty').AsFloat - CDS_Sub.FieldByName('Qty').AsFloat; Post; end; end; Next; end; First; while not Eof do begin if CDS_KC.Locate('FZSPID', Trim(CDS_Sub.FieldByName('FZSPID').AsString), []) then begin with CDS_Sub do begin Edit; FieldByName('IKCSYQty').Value := CDS_KC.FieldByName('MinQty').AsFloat; Post; end; end; Next; end; EnableControls; end; end; procedure TfrmDJBCKOutPut.FormClose(Sender: TObject; var Action: TCloseAction); begin inherited; Action := caFree; end; procedure TfrmDJBCKOutPut.TBAddClick(Sender: TObject); begin try frmDJBCKKCSelList := TfrmDJBCKKCSelList.Create(Application); with frmDJBCKKCSelList do begin CANSHU2 := SELF.canshu2; ToolButton1.Visible := True; if ShowModal = 1 then begin frmDJBCKKCSelList.CDS_Main.DisableControls; with frmDJBCKKCSelList.CDS_Main do begin First; while Locate('SSel', True, []) do begin with Self.CDS_Sub do begin Append; FieldByName('CRTime').Value := Trim(FormatDateTime('yyyy-MM-dd', Now)); FieldByName('ORDMainIdRK').Value := Trim(frmDJBCKKCSelList.CDS_Main.fieldbyname('ORDMainIdRK').AsString); FieldByName('ORDSubIdRK').Value := Trim(frmDJBCKKCSelList.CDS_Main.fieldbyname('ORDSubIdRK').AsString); FieldByName('ORDMainIdCK').Value := Trim(frmDJBCKKCSelList.CDS_Main.fieldbyname('ORDMainIdRK').AsString); FieldByName('ORDSubIdCK').Value := Trim(frmDJBCKKCSelList.CDS_Main.fieldbyname('ORDSubIdRK').AsString); FieldByName('QCOrderNo').Value := frmDJBCKKCSelList.CDS_Main.fieldbyname('OrderNo').Value; FieldByName('CKOrderNo').Value := frmDJBCKKCSelList.CDS_Main.fieldbyname('OrderNo').Value; FieldByName('TPColorNo').Value := frmDJBCKKCSelList.CDS_Main.fieldbyname('TPColorNo').Value; FieldByName('TPID').Value := frmDJBCKKCSelList.CDS_Main.fieldbyname('TPID').Value; FieldByName('CKConNo').Value := frmDJBCKKCSelList.CDS_Main.fieldbyname('ConNo').AsString; FieldByName('CKConMainId').Value := frmDJBCKKCSelList.CDS_Main.fieldbyname('ConMainId').AsString; FieldByName('CKConSubId').Value := frmDJBCKKCSelList.CDS_Main.fieldbyname('ConSubId').AsString; FieldByName('ConNo').Value := frmDJBCKKCSelList.CDS_Main.fieldbyname('ConNo').AsString; FieldByName('ConMainId').Value := frmDJBCKKCSelList.CDS_Main.fieldbyname('ConMainId').AsString; FieldByName('ConSubId').Value := frmDJBCKKCSelList.CDS_Main.fieldbyname('ConSubId').AsString; FieldByName('CustomerNoName').Value := frmDJBCKKCSelList.CDS_Main.fieldbyname('CustomerNoName').AsString; FieldByName('spcode').Value := frmDJBCKKCSelList.CDS_Main.fieldbyname('spcode').AsString; FieldByName('SPColor').Value := frmDJBCKKCSelList.CDS_Main.fieldbyname('SPColor').AsString; FieldByName('SPColorno').Value := frmDJBCKKCSelList.CDS_Main.fieldbyname('SPColorno').AsString; FieldByName('SPHX').Value := frmDJBCKKCSelList.CDS_Main.fieldbyname('SPHX').AsString; FieldByName('FactoryName').Value := frmDJBCKKCSelList.CDS_Main.fieldbyname('FactoryName').Value; FieldByName('FactoryNo').Value := frmDJBCKKCSelList.CDS_Main.fieldbyname('FactoryNo').Value; FieldByName('SSType').Value := frmDJBCKKCSelList.CDS_Main.fieldbyname('SSType').Value; FieldByName('SPName').Value := frmDJBCKKCSelList.CDS_Main.fieldbyname('SPName').Value; FieldByName('SPSpec').Value := frmDJBCKKCSelList.CDS_Main.fieldbyname('SPSpec').Value; FieldByName('SPCF').Value := frmDJBCKKCSelList.CDS_Main.fieldbyname('SPCF').Value; FieldByName('SPMF').Value := frmDJBCKKCSelList.CDS_Main.fieldbyname('SPMF').Value; FieldByName('SPKZ').Value := frmDJBCKKCSelList.CDS_Main.fieldbyname('SPKZ').Value; FieldByName('RCGangNo').Value := frmDJBCKKCSelList.CDS_Main.fieldbyname('RCGangNo').Value; FieldByName('FromFactoryName').Value := frmDJBCKKCSelList.CDS_Main.fieldbyname('ToFactoryName').Value; FieldByName('FromFactoryNo').Value := frmDJBCKKCSelList.CDS_Main.fieldbyname('ToFactoryNo').Value; FieldByName('ToFactoryName').Value := frmDJBCKKCSelList.CDS_Main.fieldbyname('ToFactoryName').Value; FieldByName('ToFactoryNo').Value := frmDJBCKKCSelList.CDS_Main.fieldbyname('ToFactoryNo').Value; FieldByName('QtyUnit').Value := frmDJBCKKCSelList.CDS_Main.fieldbyname('QtyUnit').Value; FieldByName('PiQty').Value := frmDJBCKKCSelList.CDS_Main.fieldbyname('MXKCPiQty').Value; FieldByName('Qty').Value := 0; FieldByName('IKCQty').Value := frmDJBCKKCSelList.CDS_Main.fieldbyname('MXKCQty').Value; FieldByName('IKCSYQty').Value := frmDJBCKKCSelList.CDS_Main.fieldbyname('MXKCQty').Value; FieldByName('FZSPID').Value := frmDJBCKKCSelList.CDS_Main.fieldbyname('SPID').Value; FieldByName('Note').Value := frmDJBCKKCSelList.CDS_Main.fieldbyname('Note').Value; FieldByName('SCOrderNo').Value := frmDJBCKKCSelList.CDS_Main.fieldbyname('SCOrderNo').Value; FieldByName('WanChengDu').Value := frmDJBCKKCSelList.CDS_Main.fieldbyname('WanChengDu').Value; FieldByName('JiaWeiNo').Value := frmDJBCKKCSelList.CDS_Main.fieldbyname('JiaWeiNo').Value; FieldByName('QuYuNo').Value := frmDJBCKKCSelList.CDS_Main.fieldbyname('QuYuNo').Value; FieldByName('lotno').Value := frmDJBCKKCSelList.CDS_Main.fieldbyname('lotno').Value; if FieldByName('WanChengDu').Value = '成品' then FieldByName('JYFS').Value := '机检'; if FieldByName('WanChengDu').Value = '半成品' then FieldByName('JYFS').Value := '桌检'; post; end; frmDJBCKKCSelList.CDS_Main.Delete; end; end; frmDJBCKKCSelList.CDS_Main.EnableControls; end; end; finally frmDJBCKKCSelList.Free; end; end; function TfrmDJBCKOutPut.SaveCKData(): Boolean; var FCRID, Maxno, FSPID, MaxPYNo, FPYID: 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; FSPID := Trim(ADOQueryTemp.fieldbyname('SPID').AsString); if Trim(FSPID) = '' then begin if GetLSNo(ADOQueryCmd, Maxno, 'DC', 'CK_SXPB_CR', 3, 1) = False then begin Result := False; ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('取待检布出库编号失败!', '提示', 0); Exit; end; end else begin Maxno := Trim(FSPID); 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(FSPID) = '' then begin Append; end else begin Edit; end; FieldByName('SPID').Value := Trim(Maxno); FieldByName('CDANWEI').Value := Trim(CANSHU2); FieldByName('CKOrderNo').Value := Trim(CDS_Sub.fieldbyname('CKOrderNo').AsString); FieldByName('ORDMainIdRK').Value := Trim(CDS_Sub.fieldbyname('ORDMainIdRK').AsString); FieldByName('ORDSubIdRK').Value := Trim(CDS_Sub.fieldbyname('ORDSubIdRK').AsString); FieldByName('ORDMainIdCK').Value := Trim(CDS_Sub.fieldbyname('ORDMainIdCK').AsString); FieldByName('ORDSubIdCK').Value := Trim(CDS_Sub.fieldbyname('ORDSubIdCK').AsString); FieldByName('CKConMainId').Value := Trim(CDS_Sub.fieldbyname('CKConMainId').AsString); FieldByName('CKConSubId').Value := Trim(CDS_Sub.fieldbyname('CKConSubId').AsString); FieldByName('ConNo').Value := Trim(CDS_Sub.fieldbyname('ConNo').AsString); FieldByName('ConMainId').Value := Trim(CDS_Sub.fieldbyname('ConMainId').AsString); FieldByName('ConSubId').Value := Trim(CDS_Sub.fieldbyname('ConSubId').AsString); FieldByName('FZSPID').Value := Trim(CDS_Sub.fieldbyname('FZSPID').AsString); FieldByName('TPID').Value := Trim(CDS_Sub.fieldbyname('TPID').AsString); 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('CRFlag').Value := '出库'; FieldByName('CRQtyFlag').Value := -1; RTSetSaveDataCDS(ADOQueryCmd, Tv1, CDS_Sub, 'CK_SXPB_CR', 2); FieldByName('CKName').Value := '待检布'; FieldByName('ClothDegree').Value := '成品'; FieldByName('CKorderNo').Value := Trim(CDS_Sub.fieldbyname('CKorderNo').AsString); if Trim(CDS_Sub.fieldbyname('CRType').AsString) = '平移出库' then begin FieldByName('PYID').Value := Trim(Maxno); end; if Trim(FSPID) = '' then FieldByName('Filler').Value := Trim(DName) else begin FieldByName('Editer').Value := Trim(DName); FieldByName('EditTime').Value := SGetServerDate(ADOQueryTemp); end; FieldByName('Xs').Value := CDS_Sub.fieldbyname('Xs').AsFloat; FieldByName('PiQty').Value := CDS_Sub.fieldbyname('PiQty').AsFloat; FieldByName('Qty').Value := CDS_Sub.fieldbyname('Qty').AsFloat; 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(CDS_Sub.fieldbyname('FZSPID').AsString) + ''''); ExecSQL; end; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('Update CK_SXPB_CR Set GangNo=1+ISNULL((select max([dbo].[getNum](GangNo)) from CK_SXPB_CR A '); sql.Add('where A.CKName=''待检布'' and A.CKOrderNo=CK_SXPB_CR.CKOrderNo and A.SPName=CK_SXPB_CR.SPName and A.SPColor=CK_SXPB_CR.SPColor and A.SPHX=CK_SXPB_CR.SPHX and A.SPID<>' + QUOTEDSTR(Trim(Maxno)) + '),0)'); sql.Add(' where isnull(GangNo,'''')='''' and isnull(SPHX,'''')<>'''' and SPID=''' + Trim(Maxno) + ''''); // ShowMessage(SQL.Text); ExecSQL; end; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('Update CK_SXPB_CR Set GangNo=1+ISNULL((select max([dbo].[getNum](GangNo)) from CK_SXPB_CR A '); sql.Add('where A.CKName=''待检布'' and A.CKOrderNo=CK_SXPB_CR.CKOrderNo and A.SPName=CK_SXPB_CR.SPName and A.SPColor=CK_SXPB_CR.SPColor and isnull(A.SPHX,'''')='''' and A.SPID<>' + QUOTEDSTR(Trim(Maxno)) + '),0)'); sql.Add(' where isnull(GangNo,'''')='''' and isnull(SPHX,'''')='''' and SPID=''' + Trim(Maxno) + ''''); // ShowMessage(SQL.Text); ExecSQL; end; ///////////////////////// 3.待检布出库通尺,系统默认读取改订单该颜色最近的设置 //////////////////////// // and A.SPColor=CK_SXPB_CR.SPColor with ADOQueryCmd do begin Close; sql.Clear; sql.Add('Update CK_SXPB_CR Set '); sql.Add(' TongChi= (select top 1 TongChi from CK_SXPB_CR A where A.CKName=''待检布'' and A.ORDMainIdCK=CK_SXPB_CR.ORDMainIdCK and A.SPID<>' + QUOTEDSTR(Trim(Maxno)) + ' order by CRTime desc ) '); sql.Add(' where SPID=''' + Trim(Maxno) + ''''); // ShowMessage(SQL.Text); isnull(TongChi,0)<>0 and ExecSQL; end; ///////////////////////// 3.待检布出库通尺,系统默认读取改订单该颜色最近的设置 //////////////////////// ///////////////////////// 更新系数 //////////////////////// with ADOQueryCmd do begin Close; sql.Clear; sql.Add('Update CK_SXPB_CR Set '); sql.Add(' XS= isnull((select top 1 XS from CK_SXPB_CR A where isnull(A.XS,0)<>0 and A.CKName=''待检布'' and A.ORDMainIdCK=CK_SXPB_CR.ORDMainIdCK and A.SPID<>' + QUOTEDSTR(Trim(Maxno)) + ' order by CRTime desc ),0) '); sql.Add(' where isnull(XS,0)=0 and SPID=''' + Trim(Maxno) + ''''); // ShowMessage(SQL.Text); isnull(XS,0)<>0 and ExecSQL; end; ///////////////////////// 更新系数 //////////////////////// with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from CK_SXPB_CR where SPID=''' + Trim(CDS_Sub.fieldbyname('FZSPID').AsString) + ''''); Open; end; if ADOQueryTemp.FieldByName('MXKCQty').Value < 0 then begin CDS_Sub.DisableControls; ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('出库数大于库存数不能保存!', '提示', 0); Exit; end; if Trim(CDS_Sub.fieldbyname('CRType').AsString) = '加工出库' then begin with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from CK_SXPB_CR where PYID=''' + Trim(Maxno) + ''''); sql.Add(' and isnull(CRType,'''')=''平移入库'' '); Open; end; FPYID := Trim(ADOQueryTemp.fieldbyname('SPID').AsString); if Trim(FPYID) = '' then begin if GetLSNo(ADOQueryCmd, MaxPYNo, 'YR', 'CK_SXPB_CR', 3, 1) = False then begin Result := False; ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('取外加工平移入库编号失败!', '提示', 0); Exit; end; end else begin MaxPYNo := Trim(FPYID); end; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('select * from CK_SXPB_CR where SPID=''' + Trim(MaxPYNo) + ''''); Open; end; with ADOQueryCmd do begin if Trim(FPYID) = '' then begin Append; end else begin Edit; end; RTSetSaveDataCDS(ADOQueryCmd, Tv1, CDS_Sub, 'CK_SXPB_CR', 2); FieldByName('SPID').Value := Trim(MaxPYNo); FieldByName('ORDMainIdRK').Value := Trim(CDS_Sub.fieldbyname('ORDMainIdCK').AsString); FieldByName('ORDSubIdRK').Value := Trim(CDS_Sub.fieldbyname('ORDSubIdCK').AsString); {FieldByName('ORDMainIdCK').Value:=Trim(CDS_Sub.fieldbyname('ORDMainIdCK').AsString); FieldByName('ORDSubIdCK').Value:=Trim(CDS_Sub.fieldbyname('ORDSubIdCK').AsString);} FieldByName('FZSPID').Value := Trim(MaxPYNo); FieldByName('FactoryNo').Value := Trim(CDS_Sub.fieldbyname('ToFactoryNo').AsString); FieldByName('FromFactoryNo').Value := Trim(CDS_Sub.fieldbyname('FromFactoryNo').AsString); FieldByName('ToFactoryNo').Value := Trim(CDS_Sub.fieldbyname('ToFactoryNo').AsString); FieldByName('CRFlag').Value := '入库'; FieldByName('CRQtyFlag').Value := 1; FieldByName('xs').Value := 0; FieldByName('CKName').Value := '外加工'; FieldByName('CRType').Value := '平移入库'; FieldByName('PYID').Value := Trim(Maxno); if Trim(FPYID) = '' then FieldByName('Filler').Value := Trim(DName) else begin FieldByName('Editer').Value := Trim(DName); FieldByName('EditTime').Value := SGetServerDate(ADOQueryTemp); 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(MaxPYNo) + ''''); ExecSQL; end; with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from CK_SXPB_CR where SPID=''' + Trim(MaxPYNo) + ''''); Open; end; if ADOQueryTemp.FieldByName('MXKCQty').Value < 0 then begin CDS_Sub.DisableControls; ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('出库数大于库存数不能保存!', '提示', 0); Exit; end; end; Edit; FieldByName('SPID').Value := Trim(Maxno); Post; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('exec P_CW_SXPB ''' + Trim(Maxno) + ''''); ExecSQL; end; Next; end; end; CDS_Sub.EnableControls; ADOQueryCmd.Connection.CommitTrans; Result := True; except Result := False; ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('保存异常!', '提示', 0); end; end; procedure TfrmDJBCKOutPut.TBCloseClick(Sender: TObject); begin WriteCxGrid('待检布出库登记PMD', Tv1, '待检布仓库'); Close; end; procedure TfrmDJBCKOutPut.FormShow(Sender: TObject); begin inherited; ReadCxGrid('待检布出库登记PMD', Tv1, '待检布仓库'); CDS_KC.FieldDefs.Clear; CDS_KC.FieldDefs.Add('FZSPID', ftString, 60); CDS_KC.FieldDefs.Add('MaxQty', ftFloat, 0); CDS_KC.FieldDefs.Add('MinQty', ftFloat, 0); CDS_KC.close; CDS_KC.CreateDataSet; 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(' ,OrderNoCK=(select OrderNo from JYOrder_Main JM where JM.MainId=A.OrdMainIdCK )'); sql.Add(' from CK_SXPB_CR A'); sql.Add(' where SPID=''' + Trim(FBCId) + ''''); Open; end; SCreateCDS(ADOQueryTemp, CDS_Sub); CDS_Sub.FieldDefs.Add('IKCQty', ftFloat, 0); CDS_Sub.FieldDefs.Add('IKCSYQty', ftFloat, 0); CDS_Sub.close; CDS_Sub.CreateDataSet; SInitCDSData(ADOQueryTemp, CDS_Sub); end; procedure TfrmDJBCKOutPut.TBDelClick(Sender: TObject); begin if CDS_Sub.IsEmpty then Exit; if Trim(CDS_Sub.fieldbyname('SPID').AsString) <> '' then begin with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from CK_SXPB_CR where FZSPID='); sql.Add('(select SPID from CK_SXPB_CR where PYID=''' + Trim(CDS_Sub.fieldbyname('SPID').AsString) + ''''); sql.Add(' and isnull(CRType,'''')=''平移入库'')'); sql.Add(' and CRQtyFlag=-1'); Open; end; if ADOQueryTemp.IsEmpty = False then begin Application.MessageBox('已有出库记录,不能删除!', '提示', 0); Exit; end; with ADOQueryTemp do begin Close; sql.Clear; sql.Add('exec P_CW_Judge_All @DataID=' + quotedstr(Trim(CDS_Sub.fieldbyname('SPID').AsString))); Open; end; if ADOQueryTemp.FieldByName('intReturn').AsInteger = -1 then begin Application.MessageBox(PChar(ADOQueryTemp.fieldbyname('ShowMsg').AsString), '提示', 0); exit; end; if Application.MessageBox('确定要删除数据吗?', '提示', 32 + 4) <> IDYES then Exit; 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) + ''''); 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(CDS_Sub.fieldbyname('FZSPID').AsString) + ''''); sql.Add('exec P_CW_SXPB ''' + Trim(CDS_Sub.fieldbyname('SPID').AsString) + ''''); {sql.Add('Update CK_SXPB_KC Set KCKGQty=(select sum(KGQty*CRQtyFlag) from CK_SXPB_CR A where A.CRID=CK_SXPB_KC.CRID)'); sql.Add(',KCPiQty=(select sum(PiQty*CRQtyFlag) from CK_SXPB_CR A where A.CRID=CK_SXPB_KC.CRID)'); sql.Add(' where CRID='+Trim(CDS_Sub.fieldbyname('CRID').AsString)); } ExecSQL; end; ADOQueryCmd.Connection.CommitTrans; except ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('删除异常!', '提示', 0); end; end; CDS_Sub.Delete; end; procedure TfrmDJBCKOutPut.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('ToFactoryName', null, []) = True then begin Application.MessageBox('出到加工厂不能为空!', '提示', 0); Exit; end; if CDS_Sub.Locate('CKOrderNo', 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('PiQty', null, []) = True then begin Application.MessageBox('匹数不能为空!', '提示', 0); Exit; end; if CDS_Sub.Locate('JYFS', null, []) = True then begin Application.MessageBox('检验方式不能为空!', '提示', 0); Exit; end; CDS_Sub.DisableControls; with CDS_Sub do begin First; while not Eof do begin if Trim(CDS_Sub.fieldbyname('CRType').AsString) = '平移出库' then begin if (Trim(CDS_Sub.fieldbyname('FromFactoryName').AsString) = Trim(CDS_Sub.fieldbyname('ToFactoryName').AsString)) and (Trim(CDS_Sub.fieldbyname('ORDSubIdRK').AsString) = Trim(CDS_Sub.fieldbyname('ORDSubIdCK').AsString)) then begin CDS_Sub.EnableControls; Application.MessageBox('同一单号,同一工厂不能平移数据!', '提示', 0); Exit; end; end else begin if Trim(CDS_Sub.fieldbyname('CRType').AsString) = '检验出库' then begin if Trim(CDS_Sub.fieldbyname('CKOrderNo').AsString) = '' then begin CDS_Sub.EnableControls; Application.MessageBox('出到计划单不能为空!', '提示', 0); Exit; end; end; end; Next; end; end; CDS_Sub.EnableControls; if SaveCKData() then begin Application.MessageBox('保存成功!', '提示', 0); ModalResult := 1; Exit; end; end; procedure TfrmDJBCKOutPut.v1Column1PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmClothContractListHZCX := TfrmClothContractListHZCX.Create(Application); with frmClothContractListHZCX do begin if ShowModal = 1 then begin with Self.CDS_Sub do begin Edit; FieldByName('CGConNo').Value := Trim(frmClothContractListHZCX.Order_Main.fieldbyname('ConNo').AsString); FieldByName('CGConMainId').Value := Trim(frmClothContractListHZCX.Order_Main.fieldbyname('MainId').AsString); FieldByName('CGConSubId').Value := Trim(frmClothContractListHZCX.Order_Main.fieldbyname('SubId').AsString); FieldByName('FactoryName').Value := Trim(frmClothContractListHZCX.Order_Main.fieldbyname('FactoryNoName').AsString); FieldByName('SXName').Value := Trim(frmClothContractListHZCX.Order_Main.fieldbyname('C_CodeName').AsString); //Post; end; end; end; finally frmClothContractListHZCX.Free; end; end; procedure TfrmDJBCKOutPut.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('ToFactoryName').Value := Trim(frmZdyAttachGYS.CDS_HZ.fieldbyname('COName').AsString); //Post; end; end; end; finally frmZdyAttachGYS.Free; end; end; procedure TfrmDJBCKOutPut.v1Column17PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin inherited; try frmZDYHelp := TfrmZDYHelp.Create(Application); with frmZDYHelp do begin flag := 'SPHX'; flagname := '花型'; if ShowModal = 1 then begin with Self.CDS_Sub do begin Edit; FieldByName('SPHX').Value := Trim(frmZDYHelp.ClientDataSet1.fieldbyname('ZdyName').AsString); end; end; end; finally frmZDYHelp.Free; end; end; procedure TfrmDJBCKOutPut.v1Column19PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin inherited; try frmZDYHelp := TfrmZDYHelp.Create(Application); with frmZDYHelp do begin flag := 'SPhx'; flagname := '花型'; if ShowModal = 1 then begin with Self.CDS_Sub do begin Edit; FieldByName('sphx').Value := Trim(frmZDYHelp.ClientDataSet1.fieldbyname('ZdyName').AsString); end; end; end; finally frmZDYHelp.Free; end; end; procedure TfrmDJBCKOutPut.v1Column5PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmProductOrderListSel := TfrmProductOrderListSel.Create(Application); with frmProductOrderListSel do begin FTPID := Trim(CDS_Sub.fieldbyname('TPID').AsString); CANSHU2 := SELF.canshu2; if ShowModal = 1 then begin with Self.CDS_Sub do begin Edit; FieldByName('ORDMainIdCK').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('MainId').AsString); FieldByName('ORDSubIdCK').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('SubId').AsString); FieldByName('CKOrderNo').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('OrderNo').AsString); FieldByName('CKConMainId').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('ConMainId').AsString); FieldByName('CKConSubId').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('ConSubId').AsString); FieldByName('CKConNo').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('ConNo').AsString); FieldByName('SPColor').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('PrtColor').AsString); FieldByName('SPHX').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('PRTHX').AsString); FieldByName('SPMF').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('MPRTMF').AsString); FieldByName('SPKZ').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('MPRTKZ').AsString); FieldByName('SPColorNo').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('PRTColorNo').AsString); FieldByName('SPCF').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('MPRTCF').AsString); FieldByName('CustomerNoName').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('BuyName').AsString); FieldByName('SPName').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('MPRTCodeName').AsString); FieldByName('spcode').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('MPRTCode').AsString); FieldByName('SPHXKH').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('PRTHXKH').AsString); Post; end; end; end; finally frmProductOrderListSel.Free; end; // try // frmProductOrderLBNameSel := TfrmProductOrderLBNameSel.Create(Application); // with frmProductOrderLBNameSel do // begin // Forderno := Self.CDS_Sub.fieldbyname('QCOrderNo').AsString; // FColor := Self.CDS_Sub.fieldbyname('SPColor').AsString; // FCROrderNo := Self.CDS_Sub.fieldbyname('SCOrderNo').AsString; // if ShowModal = 1 then // begin // with Self.CDS_Sub do // begin // Edit; // FieldByName('CKConMainId').Value := Trim(frmProductOrderLBNameSel.Order_Main.fieldbyname('MainId').AsString); // FieldByName('CKConSubId').Value := Trim(frmProductOrderLBNameSel.Order_Main.fieldbyname('SubId').AsString); // FieldByName('CKConNo').Value := Trim(frmProductOrderLBNameSel.Order_Main.fieldbyname('ConNo').AsString); // FieldByName('SPColor').Value := Trim(frmProductOrderLBNameSel.Order_Main.fieldbyname('SCSColor').AsString); // FieldByName('SPHX').Value := Trim(frmProductOrderLBNameSel.Order_Main.fieldbyname('SCSHX').AsString); // FieldByName('SPMF').Value := Trim(frmProductOrderLBNameSel.Order_Main.fieldbyname('SCSMF').AsString); // FieldByName('SPKZ').Value := Trim(frmProductOrderLBNameSel.Order_Main.fieldbyname('SCSKZ').AsString); // FieldByName('SPColorNo').Value := Trim(frmProductOrderLBNameSel.Order_Main.fieldbyname('SCSColorno').AsString); // FieldByName('SPCF').Value := Trim(frmProductOrderLBNameSel.Order_Main.fieldbyname('SCSCF').AsString); // FieldByName('CustomerNoName').Value := Trim(frmProductOrderLBNameSel.Order_Main.fieldbyname('BuyName').AsString); // FieldByName('SPName').Value := Trim(frmProductOrderLBNameSel.Order_Main.fieldbyname('SCSName').AsString); // FieldByName('spcode').Value := Trim(frmProductOrderLBNameSel.Order_Main.fieldbyname('SCSCode').AsString); // FieldByName('SPHXKH').Value := Trim(frmProductOrderLBNameSel.Order_Main.fieldbyname('SCSKHHX').AsString); // end; // end; // end; // finally // frmProductOrderLBNameSel.Free; // end; end; procedure TfrmDJBCKOutPut.v2Column6PropertiesEditValueChanged(Sender: TObject); var mvalue, FFieldName: string; begin mvalue := TcxTextEdit(Sender).EditingText; FFieldName := Trim(Tv1.Controller.FocusedColumn.DataBinding.FilterFieldName); if mvalue = '' then mvalue := '0'; with CDS_Sub do begin Edit; FieldByName(FFieldName).Value := mvalue; Post; end; UpKYKC(); end; procedure TfrmDJBCKOutPut.Tv1MouseDown(Sender: TObject; Button: TMouseButton; Shift: TShiftState; X, Y: Integer); var FFSPID: string; begin if CDS_Sub.IsEmpty then Exit; if Trim(CDS_Sub.fieldbyname('SPID').AsString) <> '' then 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 v1CRType.Options.Editing := False; end; end; end; procedure TfrmDJBCKOutPut.Image2Click(Sender: TObject); begin Panel4.Visible := False; end; procedure TfrmDJBCKOutPut.N3Click(Sender: TObject); begin CopyAddRow(Tv1, CDS_Sub); with CDS_Sub do begin Edit; FieldByName('SPID').Value := ''; FieldByName('Qty').Value := 0; FieldByName('PiQty').Value := 0; Post; end; end; procedure TfrmDJBCKOutPut.ToolButton1Click(Sender: TObject); begin Panel4.Visible := True; end; procedure TfrmDJBCKOutPut.ToolButton2Click(Sender: TObject); begin CopyAddRow(Tv1, CDS_Sub); with CDS_Sub do begin Edit; FieldByName('SPID').Value := ''; FieldByName('Qty').Value := 0; FieldByName('PiQty').Value := 0; Post; end; end; procedure TfrmDJBCKOutPut.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 TfrmDJBCKOutPut.Button2Click(Sender: TObject); var CRType, GangNo, Note, RCGangNo, ToFactoryNo, ToFactoryName, JYFS: string; PiQty: Integer; Xs, 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); GangNo := Trim(CDS_Sub.fieldbyname('GangNo').AsString); PiQty := CDS_Sub.fieldbyname('PiQty').AsInteger; Qty := CDS_Sub.fieldbyname('Qty').AsFloat; Xs := CDS_Sub.fieldbyname('Xs').AsFloat; Note := Trim(CDS_Sub.fieldbyname('Note').AsString); RCGangNo := Trim(CDS_Sub.fieldbyname('RCGangNo').AsString); ToFactoryNo := Trim(CDS_Sub.fieldbyname('ToFactoryNo').AsString); ToFactoryName := Trim(CDS_Sub.fieldbyname('ToFactoryName').AsString); JYFS := Trim(CDS_Sub.fieldbyname('JYFS').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('GangNo').Value := GangNo; if CheckBox3.Checked then FieldByName('PiQty').Value := PiQty; if CheckBox4.Checked then FieldByName('Xs').Value := Xs; if CheckBox5.Checked then FieldByName('Note').Value := Note; if CheckBox6.Checked then FieldByName('Qty').Value := Qty; if CheckBox7.Checked then begin FieldByName('ToFactoryNo').Value := ToFactoryNo; FieldByName('ToFactoryName').Value := ToFactoryName; end; if chkJYFS.Checked then FieldByName('JYFS').Value := JYFS; Post; Next; end; end; CDS_Sub.EnableControls; except Application.MessageBox('替换异常!', '提示', 0); end; end; procedure TfrmDJBCKOutPut.ToolButton3Click(Sender: TObject); var Gint: Integer; begin if CDS_Sub.IsEmpty then Exit; CDS_Sub.First; if Trim(CDS_Sub.fieldbyname('GangNo').AsString) = '' then begin Gint := 1; end else begin Gint := CDS_Sub.fieldbyname('GangNo').AsInteger; end; CDS_Sub.DisableControls; with CDS_Sub do begin First; while not eof do begin Edit; FieldByName('GangNo').Value := IntToStr(Gint); Post; Next; Gint := Gint + 1; end; end; CDS_Sub.EnableControls; end; procedure TfrmDJBCKOutPut.Tv1Column1PropertiesEditValueChanged(Sender: TObject); var mvalue, FFieldName: string; begin mvalue := TcxTextEdit(Sender).EditingText; FFieldName := Trim(Tv1.Controller.FocusedColumn.DataBinding.FilterFieldName); with CDS_Sub do begin Edit; FieldByName(FFieldName).Value := mvalue; if mvalue = '成品' then Fieldbyname('JYFS').AsString := '机检'; if mvalue = '半成品' then Fieldbyname('JYFS').AsString := '桌检'; Post; end; tv1.Controller.EditingController.ShowEdit(); end; procedure TfrmDJBCKOutPut.Tv1Column2PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin inherited; try frmZDYHelp := TfrmZDYHelp.Create(Application); with frmZDYHelp do begin flag := 'SPColorNo'; flagname := '色号'; if ShowModal = 1 then begin with Self.CDS_Sub do begin Edit; FieldByName('SPColorNo').Value := Trim(frmZDYHelp.ClientDataSet1.fieldbyname('ZdyName').AsString); end; end; end; finally frmZDYHelp.Free; end; end; procedure TfrmDJBCKOutPut.Tv1CustomDrawIndicatorCell(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; end.