📄 fachprd.cpp
字号:
//---------------------------------------------------------------------------
#include <vcl.h>
#pragma hdrstop
#include "FaChPrd.h"
//---------------------------------------------------------------------------
#pragma package(smart_init)
#pragma link "RecBaseForm"
#pragma link "DateEdit"
#pragma link "fpanel"
#pragma link "SDComboBox"
#pragma link "SDEdit"
#pragma link "SDGrid"
#pragma resource "*.dfm"
TfrmFaChPrd *frmFaChPrd;
//---------------------------------------------------------------------------
__fastcall TfrmFaChPrd::TfrmFaChPrd(TComponent* Owner)
: TRecBaseForm(Owner,euSdFaChg,"")
{
}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChPrd::InitEditControl()
{
AnsiString Sql;
Sql="select fadncode,fadnname,FadnPeriod from sdfadn order By fadncode";
FillComboBox(scFaChgFMonth,"select FcMonth from sdFc order By FcMonth","FcMonth");
FillEdit(seFaChgFadn,Sql,"fadncode","fadnname","FadnPeriod");
ClientGroup->AddComponent(2,false,false,true,FloatPanel1,FloatPanel1->Name);
ClientGroup->AddComponent(2,true,true,false, sgFaChPrd,sgFaChPrd->Name);
ClientGroup->AddComponent(2,false,false,false, seFaChgCode,seFaChgCode->Name);
ClientGroup->AddComponent(2,true,true,true,scFaChgFMonth,scFaChgFMonth->Name);
}
//---------------------------------------------------------------------------
AnsiString __fastcall TfrmFaChPrd::GetFieldValue(int FieldIndex)
{
WideString S;
S = ReadFieldValue(comServer,FieldIndex);
return(S);
}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChPrd::ClearControl(bool BringToNext)
{
if(!BringToNext)
{
seFaChgCode->Text =""; //变动单号
sdFaChgDate->Text =g_sdCurDate;//变动日期
scFaChgFMonth->Text =g_sdEMonth;//财务月份
seFaChgFadn->Text =""; //设备编码
seFaChgFadnName->Text =""; //设备名称
seFaChgDesc->Text =""; //变动原因
seFaChgOPeriod->Text =""; //变动前使用年限
seFaChgNPeriod->Text =""; //变动后使用年限
labFaChgUser->Caption =g_sdUserCode;//操作员
chkFaChgCheck->Checked =false; //审核标志
labFaChgChecker->Caption=""; //审核人
labFaChgCheckDate->Caption=""; //审核日期
seFaChgOGlkm->Text =""; //对方科目
chkFaChgPost->Checked =false; //制凭证标志
labFaChgSysDate->Caption=""; //系统日期
}
}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChPrd::GetDataFromComObject()
{
seFaChgCode->Text=GetFieldValue(fiFaChgCode);
sgFaChPrd->LocateGrid(1,seFaChgCode->Text);
sdFaChgDate->Text=GetFieldValue(fiFaChgDate);
scFaChgFMonth->Text=GetFieldValue(fiFaChgFMonth);
seFaChgFadn->LocateKey(GetFieldValue(fiFaChgFadn));
seFaChgFadn->Text=seFaChgFadn->ItemData[0];
seFaChgFadnName->Text=seFaChgFadn->ItemData[1];
seFaChgOPeriod->Text=GetFieldValue(fiFaChgOPeriod);
seFaChgNPeriod->Text=GetFieldValue(fiFaChgNPeriod);
seFaChgDesc->Text=GetFieldValue(fiFaChgDesc);
labFaChgUser->Caption=GetFieldValue(fiFaChgUser);
chkFaChgCheck->Checked=(GetFieldValue(fiFaChgCheck)==1)? true: false;
if(chkFaChgCheck->Checked)
SetCheckToolbarStatus(true);
else
SetCheckToolbarStatus(false);
labFaChgChecker->Caption=GetFieldValue(fiFaChgChecker);
labFaChgCheckDate->Caption=GetFieldValue(fiFaChgCheckDate);
seFaChgOGlkm->Text=GetFieldValue(fiFaChgOGlkm);
chkFaChgPost->Checked=GetFieldValue(fiFaChgPost)=="1";
labFaChgSysDate->Caption=GetFieldValue(fiFaChgSysDate);
}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChPrd::SendDataToComObject()
{
WriteFieldValue(comServer,fiFaChgType,"6");
WriteFieldValue(comServer,fiFaChgCode,seFaChgCode->Text);
WriteFieldValue(comServer,fiFaChgDate,sdFaChgDate->Text);
WriteFieldValue(comServer,fiFaChgFMonth,scFaChgFMonth->Text);
WriteFieldValue(comServer,fiFaChgFadn,seFaChgFadn->Text);
WriteFieldValue(comServer,fiFaChgDesc,seFaChgDesc->Text);
WriteFieldValue(comServer,fiFaChgOPeriod,seFaChgOPeriod->Text);
WriteFieldValue(comServer,fiFaChgNPeriod,seFaChgNPeriod->Text);
WriteFieldValue(comServer,fiFaChgUser,labFaChgUser->Caption);
WriteFieldValue(comServer,fiFaChgOGlkm,seFaChgOGlkm->Text);
WriteFieldValue(comServer,fiFaChgPost,chkFaChgPost->Checked ? "1":"0");
}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChPrd::WaitUserInput()
{
seFaChgCode->SetFocus();
}
//---------------------------------------------------------------------------
AnsiString __fastcall TfrmFaChPrd::GetDataToGrid()
{
AnsiString s;
seFaChgFadn->LocateKey(GetFieldValue(fiFaChgFadn));
s = "\t" +GetFieldValue(fiFaChgCode)+
"\t" +GetFieldValue(fiFaChgFadn)+
"\t" +seFaChgFadn->ItemData[1]+
"\t" +GetFieldValue(fiFaChgDate);
return(s);
}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChPrd::RefreshGridData(int mAction)
{
AnsiString ItemStr;
ItemStr = GetDataToGrid();
if (mAction == 0) //Add
{
sgFaChPrd->AddItem(ItemStr);
}
else if(mAction == 1) //Modify
{
int i = sgFaChPrd->Row;
sgFaChPrd->RemoveItem(i);
sgFaChPrd->AddItem(ItemStr,i);
}
else if(mAction == 2) //Delete
{
sgFaChPrd->RemoveItem(sgFaChPrd->Row);
}
}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChPrd::FillGridWithData()
{
AnsiString ItemStr;
comServer->FilterString="FACHGTYPE='6'";
comServer->Query();
comServer->MoveFirst();
sgFaChPrd->RowCount = 1;
while (comServer->Eof == 0)
{
ItemStr = GetDataToGrid();
sgFaChPrd->AddItem(ItemStr);
comServer->MoveNext();
}
}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChPrd::FormShow(TObject *Sender)
{
FillGridWithData();
comServer->MoveFirst();
GetDataFromComObject();
}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChPrd::seFaChgOGlkmButtonClick(TObject *Sender)
{
OpenGlkmQuery();
if(QueryStatus==1)
seFaChgOGlkm->Text=GetGlkmValue("GLKMCODE");
}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChPrd::RefreshUpdateData(int MsgSrc,int MsgType)
{
switch(MsgSrc)
{
case euSdFadn:
if(ShowUpdateMessage(MsgSrc,MsgType))
{
AnsiString Sql;
Sql="select fadncode,fadnname,FadnPeriod from sdfadn order By fadncode";
FillEdit(seFaChgFadn,Sql,"fadncode","fadnname","FadnPeriod");
}
break;
case euSdFc:
if(ShowUpdateMessage(MsgSrc,MsgType))
FillComboBox(scFaChgFMonth,"select FcMonth from sdFc order By FcMonth","FcMonth");
break;
default:
break;
}
}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChPrd::seFaChgCodeKeyDown(TObject *Sender, WORD &Key,
TShiftState Shift)
{
if(Key==13 && CurrentState==caNormal)
{
comServer->LocateByKey(seFaChgCode->Text);
GetDataFromComObject();
}
}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChPrd::sgFaChPrdClick(TObject *Sender)
{
if (sgFaChPrd->Row > 0)
comServer->LocateByKey(sgFaChPrd->TextMatrix[sgFaChPrd->Row][1]);
if (!comServer->Eof)
GetDataFromComObject();
}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChPrd::seFaChgFadnButtonClick(TObject *Sender)
{
AnsiString SqlStr;
TfrmWnQuery *p;
SqlStr="003[设备编码][设备名称][使用年限]select fadncode, fadnname,FadnPeriod from sdfadn ";
SqlStr+=" where (fadnDec=0 and fadnDisCard=0) and fadnfadm!='101' order by fadncode ";
try{
StartWaitForm("正在查询,请稍候...");
p=new TfrmWnQuery(this,"设备查询",SqlStr);
}
__finally
{
EndWaitForm();
}
if(p->ShowModal()==mrOk)
{
seFaChgFadn->Text=p->ColData[1];
seFaChgFadnName->Text=p->ColData[2];
seFaChgOPeriod->Text=p->ColData[3];
}
delete p;
}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChPrd::seFaChgFadnKeyDown(TObject *Sender, WORD &Key,
TShiftState Shift)
{
if(Key==13)
{
TComResultSet *TResultSet=NewResultSet();
AnsiString SQL="select fadncode, fadnname,FadnPeriod from sdfadn ";
SQL+=" where (fadnDec=0 and fadnDiscard=0) and fadnfadm!='101' and fadncode='"+seFaChgFadn->Text+"'order by fadncode ";
try
{
TResultSet->Close();
TResultSet->Open(SQL,"");
if(TResultSet->RecordCount<1)
throw Exception("设备编码"+seFaChgFadn->Text+"'不存在或不能输入使用年限");
seFaChgFadnName->Text=TResultSet->FieldByName("fadnname");
seFaChgOPeriod->Text=TResultSet->FieldByName("FadnPeriod");
TResultSet->Close();
}
__finally
{
delete TResultSet;
}
}
}
//---------------------------------------------------------------------------
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -