📄 fachdvd.cpp
字号:
//---------------------------------------------------------------------------
#include <vcl.h>
#pragma hdrstop
#include "FaChDvd.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"
TfrmFaChDvd *frmFaChDvd;
//---------------------------------------------------------------------------
__fastcall TfrmFaChDvd::TfrmFaChDvd(TComponent* Owner)
: TRecBaseForm(Owner,euSdFaChg,"")
{
}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChDvd::InitEditControl()
{
FillComboBox(scFaChgFMonth,"select FcMonth from sdFc order By FcMonth","FcMonth");
FillEdit(seFaChgFadn,"select fadncode,fadnname,FadnDVal from sdfadn order By fadncode","fadncode","fadnname","FadnDVal");
ClientGroup->AddComponent(2,false,false,true,FloatPanel1,FloatPanel1->Name);
ClientGroup->AddComponent(2,true,true,false, sgFaChDvd,sgFaChDvd->Name);
ClientGroup->AddComponent(2,false,false,false, seFaChgCode,seFaChgCode->Name);
ClientGroup->AddComponent(2,true,true,true,scFaChgFMonth,scFaChgFMonth->Name);
}
//---------------------------------------------------------------------------
AnsiString __fastcall TfrmFaChDvd::GetFieldValue(int FieldIndex)
{
WideString S;
S = ReadFieldValue(comServer,FieldIndex);
return(S);
}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChDvd::ClearControl(bool BringToNext)
{
if(!BringToNext)
{
seFaChgCode->Text =""; //变动单号
sdFaChgDate->Text =g_sdCurDate;//变动日期
scFaChgFMonth->Text =g_sdEMonth;//财务月份
seFaChgFadn->Text =""; //设备编码
seFaChgFadnName->Text =""; //设备名称
seFaChgDesc->Text =""; //变动原因
seFaChgODval->Text =""; //变动前累计折旧
seFaChgNDval->Text =""; //变动后累计折旧
labFaChgUser->Caption =g_sdUserCode;//操作员
chkFaChgCheck->Checked =false; //审核标志
labFaChgChecker->Caption=""; //审核人
labFaChgCheckDate->Caption=""; //审核日期
seFaChgOGlkm->Text =""; //对方科目
chkFaChgPost->Checked =false; //制凭证标志
labFaChgSysDate->Caption=""; //系统日期
}
}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChDvd::GetDataFromComObject()
{
seFaChgCode->Text=GetFieldValue(fiFaChgCode);
sgFaChDvd->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];
seFaChgODval->Text=GetFieldValue(fiFaChgODVal);
seFaChgNDval->Text=GetFieldValue(fiFaChgNDVal);
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 TfrmFaChDvd::SendDataToComObject()
{
WriteFieldValue(comServer,fiFaChgType,"4");
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,fiFaChgODVal,seFaChgODval->Text);
WriteFieldValue(comServer,fiFaChgNDVal,seFaChgNDval->Text);
WriteFieldValue(comServer,fiFaChgUser,labFaChgUser->Caption);
WriteFieldValue(comServer,fiFaChgOGlkm,seFaChgOGlkm->Text);
WriteFieldValue(comServer,fiFaChgPost,chkFaChgPost->Checked ? "1":"0");
}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChDvd::WaitUserInput()
{
seFaChgCode->SetFocus();
}
//---------------------------------------------------------------------------
AnsiString __fastcall TfrmFaChDvd::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 TfrmFaChDvd::RefreshGridData(int mAction)
{
AnsiString ItemStr;
ItemStr = GetDataToGrid();
if (mAction == 0) //Add
{
sgFaChDvd->AddItem(ItemStr);
}
else if(mAction == 1) //Modify
{
int i = sgFaChDvd->Row;
sgFaChDvd->RemoveItem(i);
sgFaChDvd->AddItem(ItemStr,i);
}
else if(mAction == 2) //Delete
{
sgFaChDvd->RemoveItem(sgFaChDvd->Row);
}
}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChDvd::FillGridWithData()
{
AnsiString ItemStr;
comServer->FilterString="FACHGTYPE='4'";
comServer->Query();
comServer->MoveFirst();
sgFaChDvd->RowCount = 1;
while (comServer->Eof == 0)
{
ItemStr = GetDataToGrid();
sgFaChDvd->AddItem(ItemStr);
comServer->MoveNext();
}
}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChDvd::FormShow(TObject *Sender)
{
FillGridWithData();
comServer->MoveFirst();
GetDataFromComObject();
}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChDvd::seFaChgOGlkmButtonClick(TObject *Sender)
{
OpenGlkmQuery();
if(QueryStatus==1)
seFaChgOGlkm->Text=GetGlkmValue("GLKMCODE");
}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChDvd::RefreshUpdateData(int MsgSrc,int MsgType)
{
switch(MsgSrc)
{
case euSdFadn:
if(ShowUpdateMessage(MsgSrc,MsgType))
FillEdit(seFaChgFadn,"select fadncode,fadnname,FadnDVal from sdfadn order By fadncode","fadncode","fadnname","FadnDVal");
break;
case euSdFc:
if(ShowUpdateMessage(MsgSrc,MsgType))
FillComboBox(scFaChgFMonth,"select FcMonth from sdFc order By FcMonth","FcMonth");
break;
default:
break;
}
}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChDvd::seFaChgCodeKeyDown(TObject *Sender, WORD &Key,
TShiftState Shift)
{
if(Key==13 && CurrentState==caNormal)
{
comServer->LocateByKey(seFaChgCode->Text);
GetDataFromComObject();
}
}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChDvd::sgFaChDvdClick(TObject *Sender)
{
if (sgFaChDvd->Row > 0)
comServer->LocateByKey(sgFaChDvd->TextMatrix[sgFaChDvd->Row][1]);
if (!comServer->Eof)
GetDataFromComObject();
}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChDvd::seFaChgFadnButtonClick(TObject *Sender)
{
AnsiString SqlStr;
TfrmWnQuery *p;
SqlStr="003[设备编码][设备名称][累计折旧]select fadncode, fadnname,FadnDVal from sdfadn where (FadnDec=0 and FadnDisCard=0) 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];
seFaChgODval->Text=p->ColData[3];
}
delete p;
}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChDvd::seFaChgFadnKeyDown(TObject *Sender, WORD &Key,
TShiftState Shift)
{
if(Key==13)
{
TComResultSet *TResultSet=NewResultSet();
AnsiString SQL="select fadncode, fadnname,FadnDVal from sdfadn ";
SQL+=" where (FadnDec=0 and FadnDisCard=0) 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");
seFaChgODval->Text=TResultSet->FieldByName("FadnDval");
TResultSet->Close();
}
__finally
{
delete TResultSet;
}
}
}
//---------------------------------------------------------------------------
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -