D7gmYushang/应收应付/U_YFKInput.pas

1022 lines
31 KiB
ObjectPascal
Raw Permalink Normal View History

2025-09-24 13:13:14 +08:00
unit U_YFKInput;
interface
uses
Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
Dialogs, ComCtrls, ToolWin, cxStyles, cxCustomData, cxGraphics, cxFilter,
cxData, cxDataStorage, cxEdit, DB, cxDBData, cxGridLevel, cxClasses,
cxControls, cxGridCustomView, cxGridCustomTableView, cxGridTableView,
cxGridDBTableView, cxGrid, cxGridCustomPopupMenu, cxGridPopupMenu, ADODB,
DBClient, ExtCtrls, StdCtrls, BtnEdit, cxButtonEdit, cxTextEdit,
cxDropDownEdit, cxLookAndFeels, cxLookAndFeelPainters, cxNavigator, cxCalendar,
cxCurrencyEdit;
type
TfrmYFKInput = class(TForm)
DataSource1: TDataSource;
YFSub: TClientDataSet;
cxGridPopupMenu1: TcxGridPopupMenu;
ToolBar1: TToolBar;
TSave: TToolButton;
TBClose: TToolButton;
ToolBar2: TToolBar;
TADD: TToolButton;
TDEl: TToolButton;
Panel1: TPanel;
cxGrid1: TcxGrid;
Tv1: TcxGridDBTableView;
v1_KXType: TcxGridDBColumn;
v1Qty: TcxGridDBColumn;
v1Price: TcxGridDBColumn;
v1QtyUnit: TcxGridDBColumn;
v1Money: TcxGridDBColumn;
v1note: TcxGridDBColumn;
cxGridLevel1: TcxGridLevel;
Label1: TLabel;
YFID: TEdit;
Label2: TLabel;
Label3: TLabel;
CRTime: TDateTimePicker;
Note: TMemo;
PayMent: TBtnEditA;
FactoryName: TBtnEditA;
Label4: TLabel;
Label6: TLabel;
ADOQueryTmp: TADOQuery;
ADOQueryCmd: TADOQuery;
Label8: TLabel;
SYRName: TBtnEditA;
Label9: TLabel;
Money: TEdit;
Label10: TLabel;
HuiLv: TEdit;
BZType: TComboBox;
Label11: TLabel;
Label12: TLabel;
BBMoney: TEdit;
v1Column3: TcxGridDBColumn;
Label7: TLabel;
v1Column4: TcxGridDBColumn;
ToolButton1: TToolButton;
v1Column5: TcxGridDBColumn;
Label5: TLabel;
ishs: TComboBox;
YFName: TBtnEditA;
Label13: TLabel;
FtySYRName: TBtnEditA;
v1Column7: TcxGridDBColumn;
v1Column10: TcxGridDBColumn;
ToolButton2: TToolButton;
Tv1Column1: TcxGridDBColumn;
Tv1Column2: TcxGridDBColumn;
Tv1Column3: TcxGridDBColumn;
Tv1Column4: TcxGridDBColumn;
Tv1Column5: TcxGridDBColumn;
Tv1Column6: TcxGridDBColumn;
Label14: TLabel;
Label15: TLabel;
YWY: TBtnEditA;
YWZB: TBtnEditA;
ToolButton3: TToolButton;
ToolButton4: TToolButton;
Edit1: TEdit;
ToolButton5: TToolButton;
cxStyleRepository1: TcxStyleRepository;
cxStyle1: TcxStyle;
procedure TBCloseClick(Sender: TObject);
procedure FormShow(Sender: TObject);
procedure TSaveClick(Sender: TObject);
procedure FactoryNameBtnClick(Sender: TObject);
procedure PayMentBtnClick(Sender: TObject);
procedure v1P_SpecPropertiesButtonClick(Sender: TObject; AButtonIndex: Integer);
procedure v1QtyUnitPropertiesButtonClick(Sender: TObject; AButtonIndex: Integer);
procedure TADDClick(Sender: TObject);
procedure TDElClick(Sender: TObject);
procedure v1QtyPropertiesEditValueChanged(Sender: TObject);
procedure SYRNameBtnClick(Sender: TObject);
procedure v1Column3PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer);
procedure HuiLvKeyPress(Sender: TObject; var Key: Char);
procedure Panel1Click(Sender: TObject);
procedure HuiLvExit(Sender: TObject);
procedure v1MoneyPropertiesEditValueChanged(Sender: TObject);
procedure ToolButton1Click(Sender: TObject);
procedure YFNameBtnClick(Sender: TObject);
procedure FtySYRNameBtnClick(Sender: TObject);
procedure ToolButton2Click(Sender: TObject);
procedure YWYBtnClick(Sender: TObject);
procedure YWZBBtnClick(Sender: TObject);
procedure ToolButton3Click(Sender: TObject);
procedure ToolButton4Click(Sender: TObject);
procedure ToolButton5Click(Sender: TObject);
private
procedure initGrid();
procedure SaveDate();
procedure HJJE();
{ Private declarations }
public
FYFID: string;
{ Public declarations }
end;
var
frmYFKInput: TfrmYFKInput;
implementation
uses
U_Fun10, U_ZDYHelp, U_ZdyAttachment, U_dataLink, U_ZdyAttachGYS, U_SXCKNewList,
U_PBRKlistSel, U_CPManageSel, U_ZZJWLRKListSel, U_BpRklistsel, U_SXXSListSel2;
{$R *.dfm}
procedure TfrmYFKInput.HJJE();
var
FMoney, FHuiLv, FBBMoney: double;
begin
if TV1.DataController.Summary.FooterSummaryValues[1] <> NULL then
FMoney := TV1.DataController.Summary.FooterSummaryValues[1]
else
FMoney := 0;
FHuiLv := strtofloat(HuiLv.Text);
if FHuiLv = 0 then
FHuiLv := 1;
FBBMoney := FHuiLv * FMoney;
Money.Text := floattostr(FMoney);
HuiLv.Text := floattostr(FHuiLv);
BBMoney.Text := floattostr(FBBMoney);
end;
procedure TfrmYFKInput.SaveDate();
var
MaxYFSID, MaxYFID: string;
begin
ADOQueryCmd.Connection.BeginTrans;
try
if trim(FYFID) = '' then
begin
if GetLSNo(ADOQueryTmp, MaxYFID, 'YF', 'YF_Money_CR_Sub', 4, 1) = False then
begin
Application.MessageBox(<><C8A1><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʧ<EFBFBD>ܣ<EFBFBD>', '<27><>ʾ', 0);
Exit;
end;
YFID.Text := MaxYFID;
end
else
begin
MaxYFID := trim(FYFID);
end;
with ADOQueryCmd do
begin
close;
sql.Clear;
sql.add('select * from YF_Money_CR where YFID=' + quotedstr(FYFID));
open;
end;
with ADOQueryCmd do
begin
if trim(FYFID) = '' then
begin
append;
Fieldbyname('YFID').value := trim(MaxYFID);
FieldByName('CRType').Value := <><D3A6><EFBFBD><EFBFBD><EFBFBD>Ǽ<EFBFBD>';
FieldByName('CRFlag').Value := <><D3A6><EFBFBD><EFBFBD>';
FieldByName('QtyFlag').Value := 1;
FieldByName('status').Value := '0';
FieldByName('Filler').Value := Trim(DName);
end
else
begin
edit;
FieldByName('Editer').Value := Trim(DName);
FieldByName('EditTime').Value := SGetServerDateTime(ADOQueryTmp);
end;
SSetsaveSqlnew(ADOQueryCmd, 'YF_Money_CR', panel1, 0);
post;
end;
with YFSub do
begin
first;
while not eof do
begin
if fieldbyname('YFSID').AsString = '' then
begin
if GetLSNo(ADOQueryTmp, MaxYFSID, 'YFS', 'YF_Money_CR_Sub', 4, 1) = False then
begin
Application.MessageBox(<><C8A1><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʧ<EFBFBD>ܣ<EFBFBD>', '<27><>ʾ', 0);
Exit;
end;
end
else
begin
MaxYFSID := YFSub.fieldbyname('YFSID').AsString;
end;
with ADOQueryCmd do
begin
close;
sql.Clear;
sql.add('select * from YF_Money_CR_Sub where YFSID=' + Quotedstr(trim(MaxYFSID)));
open;
end;
if ADOQueryCmd.IsEmpty then
begin
ADOQueryCmd.append;
ADOQueryCmd.Fieldbyname('YFSID').value := trim(MaxYFSID);
ADOQueryCmd.Fieldbyname('YFID').value := trim(MaxYFID);
end
else
begin
ADOQueryCmd.edit;
end;
SSetSaveDataCDSNew(ADOQueryCmd, Tv1, YFSub, 'YF_Money_CR_Sub', 0);
with ADOQueryTmp do
begin
close;
sql.Clear;
sql.add('update YP_InOut set status=''1'',price= ' + YFSub.fieldbyname('price').asstring);
sql.Add(',money=ISNULL(QTY,0)*' + YFSub.fieldbyname('price').asstring);
sql.Add(' where crid=' + QuotedStr(YFSub.fieldbyname('yfpzno').AsString));
ExecSQL;
end;
ADOQueryCmd.Post;
with YFSub do
begin
Edit;
YFSub.Fieldbyname('YFSID').value := trim(MaxYFSID);
YFSub.Fieldbyname('YFID').value := trim(MaxYFID);
Post;
end;
next;
end;
end;
ADOQueryCmd.Connection.CommitTrans;
application.MessageBox('<27><><EFBFBD><EFBFBD><EFBFBD>ɹ<EFBFBD><C9B9><EFBFBD>', '<27><>ʾ');
// FYFID := '';
// initGrid();
Modalresult := 1;
except
ADOQueryCmd.Connection.RollbackTrans;
application.MessageBox('<27><><EFBFBD><EFBFBD>ʧ<EFBFBD>ܣ<EFBFBD>', '<27><>ʾ', MB_ICONERROR);
end;
end;
procedure TfrmYFKInput.initGrid();
begin
with ADOQueryTmp do
begin
close;
sql.Clear;
sql.Add('select * from YF_Money_CR where YFID=' + quotedstr(trim(FYFID)));
open;
end;
if ADOQueryTmp.isempty = False then
begin
SCSHDataNew(ADOQueryTmp, Panel1, 0);
end
else
begin
HuiLv.Text := '1';
CRTime.DateTime := SGetServerDate(ADOQueryTmp);
end;
with ADOQueryTmp do
begin
close;
sql.Clear;
sql.Add('select * from YF_Money_CR_Sub where YFID=''' + trim(FYFID) + '''');
open;
end;
SCreateCDS20(ADOQueryTmp, YFSub);
SInitCDSData20(ADOQueryTmp, YFSub);
end;
procedure TfrmYFKInput.TBCloseClick(Sender: TObject);
begin
WriteCxGrid(trim(self.Caption), Tv1, '<27><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>');
Close;
end;
procedure TfrmYFKInput.FormShow(Sender: TObject);
begin
ReadCxGrid(trim(self.Caption), Tv1, '<27><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>');
initGrid();
end;
procedure TfrmYFKInput.TSaveClick(Sender: TObject);
begin
yfname.SetFocus;
if trim(FactoryName.Text) = '' then
begin
application.MessageBox('<27>Է<EFBFBD><D4B7><EFBFBD>λ<EFBFBD><CEBB><EFBFBD><EFBFBD>Ϊ<EFBFBD><CEAA>', '<27><>ʾ');
exit;
end;
// if trim(YFGSType.Text) = '' then
// begin
// application.MessageBox('Ӧ<><D3A6><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ϊ<EFBFBD><CEAA>', '<27><>ʾ');
// exit;
// end;
if trim(ishs.Text) = '' then
begin
application.MessageBox('<27>Ƿ<EFBFBD><C7B7><EFBFBD>˰<EFBFBD><CBB0><EFBFBD><EFBFBD>Ϊ<EFBFBD><CEAA>', '<27><>ʾ');
exit;
end;
if YFSub.Locate('KXType', null, []) then
begin
application.MessageBox('<27><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ͳ<EFBFBD><CDB2><EFBFBD>Ϊ<EFBFBD><CEAA>', '<27><>ʾ');
exit;
end;
if YFSub.Locate('KXType', '', []) then
begin
application.MessageBox('<27><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ͳ<EFBFBD><CDB2><EFBFBD>Ϊ<EFBFBD><CEAA>', '<27><>ʾ');
exit;
end;
SaveDate();
end;
procedure TfrmYFKInput.FactoryNameBtnClick(Sender: TObject);
begin
try
frmZdyAttachGYS := TfrmZdyAttachGYS.Create(Application);
with frmZdyAttachGYS do
begin
if ShowModal = 1 then
begin
FactoryName.Text := Trim(CDS_HZ.fieldbyname('CoHRName').AsString);
FtySYRName.Text := Trim(CDS_HZ.fieldbyname('CoHRName').AsString);
end;
end;
finally
frmZdyAttachGYS.Free;
end;
end;
procedure TfrmYFKInput.PayMentBtnClick(Sender: TObject);
begin
try
frmZDYHelp := TfrmZDYHelp.Create(Application);
with frmZDYHelp do
begin
flag := 'PayMent';
flagname := '<27><><EFBFBD>ʽ';
if ShowModal = 1 then
begin
PayMent.Text := Trim(ClientDataSet1.fieldbyname('ZDYName').AsString);
end;
end;
finally
frmZDYHelp.Free;
end;
end;
procedure TfrmYFKInput.v1P_SpecPropertiesButtonClick(Sender: TObject; AButtonIndex: Integer);
begin
try
frmZDYHelp := TfrmZDYHelp.Create(Application);
with frmZDYHelp do
begin
flag := 'KXType1';
flagname := '<27><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>';
if ShowModal = 1 then
begin
Self.YFSub.Edit;
Self.YFSub.FieldByName('KXType').Value := Trim(ClientDataSet1.fieldbyname('ZDYName').AsString);
end;
end;
finally
frmZDYHelp.Free;
end;
end;
procedure TfrmYFKInput.v1QtyUnitPropertiesButtonClick(Sender: TObject; AButtonIndex: Integer);
begin
try
frmZDYHelp := TfrmZDYHelp.Create(Application);
with frmZDYHelp do
begin
flag := 'QtyUnit';
flagname := '<27><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>λ';
if ShowModal = 1 then
begin
Self.YFSub.Edit;
Self.YFSub.FieldByName('QtyUnit').Value := Trim(ClientDataSet1.fieldbyname('ZDYName').AsString);
end;
end;
finally
frmZDYHelp.Free;
end;
end;
procedure TfrmYFKInput.TADDClick(Sender: TObject);
begin
with YFSub do
begin
Append;
FieldByName('Qty').Value := 0;
FieldByName('Price').Value := 0;
FieldByName('MxMoney').Value := 0;
Post;
end;
end;
procedure TfrmYFKInput.TDElClick(Sender: TObject);
begin
if YFSub.IsEmpty then
exit;
if application.MessageBox(<><C8B7>Ҫɾ<D2AA><C9BE><EFBFBD><EFBFBD>', '<27><>ʾ', 1) = 2 then
exit;
if trim(YFSub.fieldbyname('YFSID').asstring) = '' then
begin
YFSub.delete;
HJJE();
end
else
begin
with ADOQueryTmp do
begin
close;
sql.clear;
sql.add('delete from YF_Money_CR_Sub where YFSID=''' + trim(YFSub.fieldbyname('YFSID').asstring) + ''' ');
execsql;
end;
YFSub.delete;
HJJE();
TSave.Click;
end;
end;
procedure TfrmYFKInput.v1QtyPropertiesEditValueChanged(Sender: TObject);
var
mvalue, FFieldName: string;
FQty, FPrice, FMxMoney, FXGFEE: double;
begin
mvalue := TcxTextEdit(Sender).EditingText;
FFieldName := Trim(Tv1.Controller.FocusedColumn.DataBinding.FilterFieldName);
if Trim(mvalue) = '' then
begin
mvalue := '0';
end;
with YFSub do
begin
Edit;
FieldByName(FFieldName).Value := Trim(mvalue);
Post;
end;
with YFSub do
begin
Edit;
FXGFEE := FieldByName('XGFEE').AsFloat;
FQty := FieldByName('Qty').AsFloat;
FPrice := FieldByName('Price').AsFloat;
Post;
end;
FMxMoney := strtofloat(format('%.2f', [FQty * FPrice + FXGFEE]));
with YFSub do
begin
Edit;
FieldByName(FFieldName).Value := Trim(mvalue);
FieldbyName('MxMoney').Value := FMxMoney;
Post;
end;
tv1.Controller.EditingController.ShowEdit();
HJJE();
end;
procedure TfrmYFKInput.SYRNameBtnClick(Sender: TObject);
begin
try
frmZDYHelp := TfrmZDYHelp.Create(Application);
with frmZDYHelp do
begin
flag := 'GSTTPB';
flagname := '<27><><EFBFBD><EFBFBD>';
V1Name.Caption := '<27><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>';
if ShowModal = 1 then
begin
SYRName.Text := Trim(ClientDataSet1.fieldbyname('ZdyName').AsString);
end;
end;
finally
frmZDYHelp.Free;
end;
end;
procedure TfrmYFKInput.v1Column3PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer);
begin
try
frmZDYHelp := TfrmZDYHelp.Create(Application);
with frmZDYHelp do
begin
flag := 'MPRTCodeName';
flagname := '<27><>Ʒ<EFBFBD><C6B7><EFBFBD><EFBFBD>';
if ShowModal = 1 then
begin
with YFSub do
begin
Edit;
FieldByName('CPName').Value := Trim(ClientDataSet1.fieldbyname('ZDYName').AsString);
FieldByName('CPCode').Value := Trim(ClientDataSet1.fieldbyname('ZDYNo').AsString);
end;
end;
end;
finally
frmZDYHelp.Free;
end;
//self.tv1.Controller.EditingController.ShowEdit();
end;
procedure TfrmYFKInput.HuiLvKeyPress(Sender: TObject; var Key: Char);
begin
if not (((Key >= '0') and (Key <= '9')) or (Key = '.') or (Key = #8)) then
begin
Key := #0;
end
else if (pos('.', TEdit(Sender).text) <> 0) then
begin
if Key = '.' then
begin
Key := #0;
end;
end;
end;
procedure TfrmYFKInput.Panel1Click(Sender: TObject);
begin
yfname.SetFocus;
end;
procedure TfrmYFKInput.HuiLvExit(Sender: TObject);
begin
HJJE();
end;
procedure TfrmYFKInput.v1MoneyPropertiesEditValueChanged(Sender: TObject);
var
mvalue, FFieldName: string;
begin
mvalue := TcxTextEdit(Sender).EditingText;
FFieldName := Trim(Tv1.Controller.FocusedColumn.DataBinding.FilterFieldName);
if Trim(mvalue) = '' then
begin
mvalue := '0';
end;
with YFSub do
begin
Edit;
FieldByName(FFieldName).Value := Trim(mvalue);
Post;
end;
tv1.Controller.EditingController.ShowEdit();
HJJE();
end;
procedure TfrmYFKInput.ToolButton1Click(Sender: TObject);
var
CFactoryName, CKXType: string;
CQtyFlag: integer;
begin
try
frmSXCKNewList := TfrmSXCKNewList.create(self);
with frmSXCKNewList do
begin
with frmSXCKNewList do
begin
if showmodal = 1 then
begin
CFactoryName := Trim(CDS_Main.fieldbyname('HRNAME').AsString);
CRTime.DateTime := CDS_Main.fieldbyname('CRTime').AsDateTime;
YFName.Text := '<27><>Ʒ';
YWY.Text := CDS_Main.fieldbyname('YWY').AsString;
YWZB.Text := CDS_Main.fieldbyname('YWZB').AsString;
while CDS_Main.Locate('SSel', true, []) do
begin
if trim(CFactoryName) <> Trim(CDS_Main.fieldbyname('HRNAME').AsString) then
begin
Application.MessageBox('<27><><EFBFBD><EFBFBD>ѡ<EFBFBD><D1A1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Է<EFBFBD><D4B7><EFBFBD>λ!', '<27><>ʾ', 0);
Exit;
end;
self.YFSub.Append;
self.YFSub.FieldByName('YFPZNO').Value := CDS_Main.FieldByName('SPID').Value;
self.YFSub.FieldByName('MXOrderNo').Value := CDS_Main.FieldByName('QCorderNo').Value;
self.YFSub.FieldByName('CPCode').Value := CDS_Main.FieldByName('SPCode').Value;
self.YFSub.FieldByName('RKDATE').Value := CDS_Main.FieldByName('CRTIME').Value;
self.YFSub.FieldByName('CPSpec').Value := CDS_Main.FieldByName('SPSpec').Value;
self.YFSub.FieldByName('CPBatchNO').Value := CDS_Main.FieldByName('PIHAO').Value;
self.YFSub.FieldByName('CPColor').Value := CDS_Main.FieldByName('SPColor').Value;
self.YFSub.FieldByName('CPGANGNO').Value := CDS_Main.FieldByName('GHAO').Value;
self.YFSub.FieldByName('CPMF').Value := CDS_Main.FieldByName('SPMF').Value;
self.YFSub.FieldByName('CPKZ').Value := CDS_Main.FieldByName('SPKZ').Value;
self.YFSub.FieldByName('SLD').Value := CDS_Main.FieldByName('SLD').Value;
if Trim(CDS_Main.fieldbyname('CRType').AsString) = '<27>˻<EFBFBD><CBBB><EFBFBD><EFBFBD><EFBFBD>' then
begin
CQtyFlag := -1;
CKXType := '<27><><EFBFBD><EFBFBD><EFBFBD>˻<EFBFBD>';
end
else
begin
CQtyFlag := 1;
CKXType := trim(CDS_Main.fieldbyname('CRType').AsString);
end;
// else if Trim(CDS_Main.fieldbyname('CRType').AsString) = '<27>ɹ<EFBFBD><C9B9><EFBFBD><EFBFBD><EFBFBD>' then
// begin
// CQtyFlag := 1;
// CKXType := '<27><><EFBFBD><EFBFBD><EFBFBD>ɹ<EFBFBD>';
// end
// else
// begin
// CQtyFlag := 1;
// CKXType := '<27><><EFBFBD><EFBFBD><EFBFBD>ӹ<EFBFBD>';
// end;
self.YFSub.FieldByName('KXType').Value := CKXType;
self.YFSub.FieldByName('PS').Value := CQtyFlag * CDS_Main.FieldByName('PiQty').AsInteger;
self.YFSub.FieldByName('Qty').Value := CQtyFlag * CDS_Main.FieldByName('Qty').AsFloat;
self.YFSub.FieldByName('QtyUnit').Value := CDS_Main.FieldByName('QtyUnit').Value;
self.YFSub.FieldByName('Price').Value := CDS_Main.FieldByName('Price').AsFloat;
self.YFSub.FieldByName('MxMoney').Value := CQtyFlag * CDS_Main.FieldByName('Price').AsFloat * CDS_Main.FieldByName('Qty').AsFloat;
self.YFSub.post;
if CDS_Main.FieldByName('YunFei').AsFloat > 0 then
begin
self.YFSub.Append;
self.YFSub.FieldByName('YFPZNO').Value := CDS_Main.FieldByName('SPID').Value;
self.YFSub.FieldByName('CPCode').Value := CDS_Main.FieldByName('SPCode').Value;
self.YFSub.FieldByName('CPName').Value := CDS_Main.FieldByName('SPName').Value;
self.YFSub.FieldByName('CPSpec').Value := CDS_Main.FieldByName('SPSpec').Value;
self.YFSub.FieldByName('CPBatchNO').Value := CDS_Main.FieldByName('BatchNO').Value;
self.YFSub.FieldByName('KXType').Value := '<27>˷<EFBFBD>';
self.YFSub.FieldByName('Price').Value := 0;
self.YFSub.FieldByName('PS').Value := 0;
self.YFSub.FieldByName('Qty').Value := 0;
self.YFSub.FieldByName('MxMoney').Value := CDS_Main.FieldByName('YunFei').AsFloat;
self.YFSub.post;
end;
CDS_Main.Delete;
end;
self.FactoryName.Text := Trim(CFactoryName);
HJJE();
end;
end;
end;
finally
frmSXCKNewList.free;
end;
end;
procedure TfrmYFKInput.YFNameBtnClick(Sender: TObject);
begin
try
frmZDYHelp := TfrmZDYHelp.Create(Application);
with frmZDYHelp do
begin
flag := 'YFName1';
flagname := '<27><>Ŀ<EFBFBD><C4BF>ժҪ';
if ShowModal = 1 then
begin
YFName.Text := Trim(ClientDataSet1.fieldbyname('ZDYName').AsString);
end;
end;
finally
frmZDYHelp.Free;
end;
end;
procedure TfrmYFKInput.FtySYRNameBtnClick(Sender: TObject);
begin
try
frmZDYHelp := TfrmZDYHelp.Create(Application);
with frmZDYHelp do
begin
flag := 'YFFtySYRName';
flagname := '<27>Է<EFBFBD>̧ͷ';
if ShowModal = 1 then
begin
FtySYRName.Text := Trim(ClientDataSet1.fieldbyname('ZdyName').AsString);
end;
end;
finally
frmZDYHelp.Free;
end;
end;
procedure TfrmYFKInput.ToolButton2Click(Sender: TObject);
var
CFactoryName, CKXType: string;
CQtyFlag: integer;
begin
try
frmBpRklistsel := TfrmBpRklistsel.create(self);
with frmBpRklistsel do
begin
if showmodal = 1 then
begin
CFactoryName := Trim(CDS_Main.fieldbyname('HRNAME').AsString);
CRTime.DateTime := CDS_Main.fieldbyname('CRTime').AsDateTime;
Self.YWzb.Text := CDS_Main.fieldbyname('YWzb').AsString;
Self.YWY.Text := CDS_Main.fieldbyname('YWY').AsString;
YFName.Text := '<27><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>';
while CDS_Main.Locate('SSel', true, []) do
begin
if trim(CFactoryName) <> Trim(CDS_Main.fieldbyname('HRNAME').AsString) then
begin
Application.MessageBox('<27><><EFBFBD><EFBFBD>ѡ<EFBFBD><D1A1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Է<EFBFBD><D4B7><EFBFBD>λ!', '<27><>ʾ', 0);
Exit;
end;
self.YFSub.Append;
self.YFSub.FieldByName('YFPZNO').Value := CDS_Main.FieldByName('CRID').Value;
self.YFSub.FieldByName('MXOrderNo').Value := CDS_Main.FieldByName('FromOrderNo').Value;
self.YFSub.FieldByName('CPCode').Value := CDS_Main.FieldByName('P_Code').Value;
self.YFSub.FieldByName('CPName').Value := CDS_Main.FieldByName('P_CodeName').Value;
self.YFSub.FieldByName('CPSpec').Value := CDS_Main.FieldByName('P_SPEC').Value;
self.YFSub.FieldByName('CPColor').Value := CDS_Main.FieldByName('P_Color').Value;
self.YFSub.FieldByName('CPMF').Value := CDS_Main.FieldByName('P_SMF').Value;
self.YFSub.FieldByName('CPKZ').Value := CDS_Main.FieldByName('P_SKZ').Value;
if CDS_Main.FieldByName('crtype').Value = '<27><>Ӧ<EFBFBD><D3A6><EFBFBD>˻<EFBFBD>' then
begin
self.YFSub.FieldByName('PS').Value := 0 - CDS_Main.FieldByName('RollNum').AsInteger;
self.YFSub.FieldByName('Qty').Value := 0 - CDS_Main.FieldByName('Qty').AsFloat;
end
else
begin
self.YFSub.FieldByName('PS').Value := CDS_Main.FieldByName('RollNum').AsInteger;
self.YFSub.FieldByName('Qty').Value := CDS_Main.FieldByName('Qty').AsFloat;
end;
self.YFSub.FieldByName('KXType').Value := CDS_Main.FieldByName('crtype').Value;
self.YFSub.FieldByName('QtyUnit').Value := CDS_Main.FieldByName('QtyUnit').Value;
self.YFSub.FieldByName('Price').Value := CDS_Main.FieldByName('Price').AsFloat;
self.YFSub.FieldByName('MxMoney').Value := CDS_Main.FieldByName('money').AsFloat;
self.YFSub.FieldByName('rkdate').Value := CDS_Main.FieldByName('CRTime').AsFloat;
self.YFSub.post;
CDS_Main.Delete;
end;
self.FactoryName.Text := Trim(CFactoryName);
HJJE();
end;
end;
finally
frmBpRklistsel.free;
end;
end;
procedure TfrmYFKInput.YWYBtnClick(Sender: TObject);
begin
try
frmZDYHelp := TfrmZDYHelp.Create(Application);
with frmZDYHelp do
begin
flag := 'YWY';
flagname := <><D2B5>Ա';
if ShowModal = 1 then
begin
Self.YWY.Text := Trim(frmZDYHelp.ClientDataSet1.fieldbyname('ZdyName').AsString);
end;
end;
finally
frmZDYHelp.Free;
end;
end;
procedure TfrmYFKInput.YWZBBtnClick(Sender: TObject);
begin
try
frmZDYHelp := TfrmZDYHelp.Create(Application);
with frmZDYHelp do
begin
flag := 'SalesClass';
flagname := <><D2B5><EFBFBD><EFBFBD><EFBFBD><EFBFBD>';
if ShowModal = 1 then
begin
YWZB.Text := Trim(frmZDYHelp.ClientDataSet1.fieldbyname('ZdyName').AsString);
end;
end;
finally
frmZDYHelp.Free;
end;
end;
procedure TfrmYFKInput.ToolButton3Click(Sender: TObject);
var
CFactoryName, CKXType: string;
CQtyFlag: integer;
begin
try
frmSXCKNewList := TfrmSXCKNewList.create(self);
with frmSXCKNewList do
begin
with frmSXCKNewList do
begin
FCKName := '<27><><EFBFBD><EFBFBD>';
if showmodal = 1 then
begin
CFactoryName := Trim(CDS_Main.fieldbyname('HRNAME').AsString);
CRTime.DateTime := CDS_Main.fieldbyname('CRTime').AsDateTime;
YFName.Text := '<27><><EFBFBD><EFBFBD>';
YWY.Text := CDS_Main.fieldbyname('YWY').AsString;
YWZB.Text := CDS_Main.fieldbyname('YWZB').AsString;
while CDS_Main.Locate('SSel', true, []) do
begin
if trim(CFactoryName) <> Trim(CDS_Main.fieldbyname('HRNAME').AsString) then
begin
Application.MessageBox('<27><><EFBFBD><EFBFBD>ѡ<EFBFBD><D1A1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Է<EFBFBD><D4B7><EFBFBD>λ!', '<27><>ʾ', 0);
Exit;
end;
self.YFSub.Append;
self.YFSub.FieldByName('YFPZNO').Value := CDS_Main.FieldByName('SPID').Value;
self.YFSub.FieldByName('MXOrderNo').Value := CDS_Main.FieldByName('QCorderNo').Value;
self.YFSub.FieldByName('CPCode').Value := CDS_Main.FieldByName('SPCode').Value;
self.YFSub.FieldByName('RKDATE').Value := CDS_Main.FieldByName('CRTIME').Value;
self.YFSub.FieldByName('CPSpec').Value := CDS_Main.FieldByName('SPSpec').Value;
self.YFSub.FieldByName('CPBatchNO').Value := CDS_Main.FieldByName('PIHAO').Value;
self.YFSub.FieldByName('CPColor').Value := CDS_Main.FieldByName('SPColor').Value;
self.YFSub.FieldByName('CPGANGNO').Value := CDS_Main.FieldByName('GHAO').Value;
self.YFSub.FieldByName('CPMF').Value := CDS_Main.FieldByName('SPMF').Value;
self.YFSub.FieldByName('CPKZ').Value := CDS_Main.FieldByName('SPKZ').Value;
self.YFSub.FieldByName('SLD').Value := CDS_Main.FieldByName('SLD').Value;
if Trim(CDS_Main.fieldbyname('CRType').AsString) = '<27>˻<EFBFBD><CBBB><EFBFBD><EFBFBD><EFBFBD>' then
begin
CQtyFlag := -1;
CKXType := '<27><><EFBFBD><EFBFBD><EFBFBD>˻<EFBFBD>';
end
else if Trim(CDS_Main.fieldbyname('CRType').AsString) = '<27>ɹ<EFBFBD><C9B9><EFBFBD><EFBFBD><EFBFBD>' then
begin
CQtyFlag := 1;
CKXType := '<27><><EFBFBD><EFBFBD><EFBFBD>ɹ<EFBFBD>';
end
else
begin
CQtyFlag := 1;
CKXType := '<27><><EFBFBD><EFBFBD><EFBFBD>ӹ<EFBFBD>';
end;
self.YFSub.FieldByName('KXType').Value := CKXType;
self.YFSub.FieldByName('PS').Value := CQtyFlag * CDS_Main.FieldByName('PiQty').AsInteger;
self.YFSub.FieldByName('Qty').Value := CQtyFlag * CDS_Main.FieldByName('Qty').AsFloat;
self.YFSub.FieldByName('QtyUnit').Value := CDS_Main.FieldByName('QtyUnit').Value;
self.YFSub.FieldByName('Price').Value := CDS_Main.FieldByName('Price').AsFloat;
self.YFSub.FieldByName('MxMoney').Value := CQtyFlag * CDS_Main.FieldByName('Price').AsFloat * CDS_Main.FieldByName('Qty').AsFloat;
self.YFSub.post;
if CDS_Main.FieldByName('YunFei').AsFloat > 0 then
begin
self.YFSub.Append;
self.YFSub.FieldByName('YFPZNO').Value := CDS_Main.FieldByName('SPID').Value;
self.YFSub.FieldByName('CPCode').Value := CDS_Main.FieldByName('SPCode').Value;
self.YFSub.FieldByName('CPName').Value := CDS_Main.FieldByName('SPName').Value;
self.YFSub.FieldByName('CPSpec').Value := CDS_Main.FieldByName('SPSpec').Value;
self.YFSub.FieldByName('CPBatchNO').Value := CDS_Main.FieldByName('BatchNO').Value;
self.YFSub.FieldByName('KXType').Value := '<27>˷<EFBFBD>';
self.YFSub.FieldByName('Price').Value := 0;
self.YFSub.FieldByName('PS').Value := 0;
self.YFSub.FieldByName('Qty').Value := 0;
self.YFSub.FieldByName('MxMoney').Value := CDS_Main.FieldByName('YunFei').AsFloat;
self.YFSub.post;
end;
CDS_Main.Delete;
end;
self.FactoryName.Text := Trim(CFactoryName);
HJJE();
end;
end;
end;
finally
frmSXCKNewList.free;
end;
end;
procedure TfrmYFKInput.ToolButton4Click(Sender: TObject);
var
FValue, FFValue, FColumn, FFColumn: string;
begin
if YFSub.IsEmpty then
Exit;
if Application.MessageBox(<><C8B7>Ҫ<EFBFBD><D2AA><EFBFBD>Ƶ<EFBFBD><C6B5><EFBFBD><EFBFBD><EFBFBD>', '<27><>ʾ', 1) = 2 then
exit;
with YFSub do
begin
DisableControls;
First;
while not Eof do
begin
Edit;
FieldByName('Price').Value := StrToFloatDef(Edit1.Text, 0);
FieldByName('MXmoney').Value := (StrToFloatDef(Edit1.Text, 0) * FieldByName('qty').AsFloat + StrToFloatDef(FieldByName('XGFEE').AsString, 0));
tv1.Controller.EditingController.ShowEdit();
Post;
Next;
end;
tv1.Controller.EditingController.ShowEdit();
// ToolBar5.SetFocus;
// HJ();
EnableControls;
end;
HJJE();
end;
procedure TfrmYFKInput.ToolButton5Click(Sender: TObject);
var
CFactoryName, CKXType: string;
CQtyFlag: integer;
begin
try
frmSXXSListSel2 := TfrmSXXSListSel2.create(self);
with frmSXXSListSel2 do
begin
if showmodal = 1 then
begin
CFactoryName := Trim(CDS_Main.fieldbyname('CustomerNoName').AsString);
if trim(CFactoryName) <> Trim(CDS_Main.fieldbyname('CustomerNoName').AsString) then
begin
Application.MessageBox('<27><><EFBFBD><EFBFBD>ѡ<EFBFBD><D1A1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Է<EFBFBD><D4B7><EFBFBD>λ!', '<27><>ʾ');
Exit;
end;
if FactoryName.Text <> '' then
begin
if trim(CFactoryName) <> Trim(FactoryName.Text) then
begin
Application.MessageBox('<27><><EFBFBD><EFBFBD>ѡ<EFBFBD><D1A1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Է<EFBFBD><D4B7><EFBFBD>λ!', '<27><>ʾ');
exit;
end;
end;
CRTime.DateTime := CDS_Main.fieldbyname('wcdate').AsDateTime;
FtySYRName.Text := CDS_Main.fieldbyname('CustomerNoName').AsString;
FactoryName.Text := CDS_Main.fieldbyname('CustomerNoName').AsString;
// MDTT.Text := CDS_Main.fieldbyname('CustomerNoName').AsString;
YWY.Text := CDS_Main.fieldbyname('Salesman').AsString;
YWZB.Text := CDS_Main.fieldbyname('SalesCLASS').AsString;
NOTE.Text := CDS_Main.fieldbyname('NOTE').AsString;
with CDS_SUB do
begin
First;
while not Eof do
begin
self.YFSub.Append;
self.YFSub.FieldByName('YFPZNO').Value := CDS_Main.FieldByName('FSID').Value;
self.YFSub.FieldByName('KXType').Value := '<27><>Ӧ<EFBFBD><D3A6><EFBFBD>˻<EFBFBD>';
self.YFSub.FieldByName('CPCode').Value := CDS_SUB.FieldByName('SPrtCodeName').Value;
self.YFSub.FieldByName('CPColor').Value := CDS_SUB.FieldByName('prtcolor').Value;
self.YFSub.FieldByName('CPgangno').Value := CDS_SUB.FieldByName('ganghao').Value;
self.YFSub.FieldByName('PS').Value := 0 - CDS_SUB.FieldByName('FHPS').AsInteger;
self.YFSub.FieldByName('QtyUnit').Value := CDS_Main.FieldByName('hzunit').Value;
if (CDS_Main.FieldByName('hzunit').Value = 'KG') or (CDS_Main.FieldByName('hzunit').Value = '<27><><EFBFBD><EFBFBD>') then
begin
self.YFSub.FieldByName('Qty').Value := 0 - CDS_SUB.FieldByName('FHQTY').AsFloat;
end
else
begin
self.YFSub.FieldByName('Qty').Value := 0 - CDS_SUB.FieldByName('FHms').AsFloat;
end;
self.YFSub.FieldByName('Price').Value := CDS_SUB.FieldByName('Price').AsFloat;
self.YFSub.FieldByName('xGFEE').Value := CDS_SUB.FieldByName('BGFEE').AsFloat;
self.YFSub.FieldByName('MxMoney').Value := 0 - CDS_SUB.FieldByName('Money').AsFloat;
self.YFSub.post;
Next;
end;
end;
HJJE();
end;
end;
finally
frmSXXSListSel2.free;
end;
end;
end.