⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 fachprd.cpp

📁 科思ERP部分源码及控件
💻 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, HWND chWnd, AnsiString MidCode,AnsiString WhereStr)
        : TRecBaseForm(Owner,chWnd,MidCode,WhereStr)
{
   InitRsGlkm("");
   IsUserCheck = true;
}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChPrd::InitEditControl()
{
    AnsiString Sql;
    Sql="select  fadncode,fadnname,FadnPeriod  from sdfadn   order By fadncode";
    FillComboBox(Handle,scFaChgFMonth,"select FcMonth from sdFc order By FcMonth","FcMonth");
    FillEdit(Handle,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);
}
//---------------------------------------------------------------------------

//---------------------------------------------------------------------------
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("FaChgCode");
    sgFaChPrd->LocateGrid(1,seFaChgCode->Text);
    sdFaChgDate->Text=GetFieldValue("FaChgDate");
    scFaChgFMonth->Text=GetFieldValue("FaChgFMonth");
    seFaChgFadn->LocateKey(GetFieldValue("FaChgFadn"));
    seFaChgFadn->Text=seFaChgFadn->ItemData[0];
    seFaChgFadnName->Text=seFaChgFadn->ItemData[1];
    seFaChgOPeriod->Text=GetFieldValue("FaChgOPeriod");
    seFaChgNPeriod->Text=GetFieldValue("FaChgNPeriod");
    seFaChgDesc->Text=GetFieldValue("FaChgDesc");
    labFaChgUser->Caption=GetFieldValue("FaChgUser");
    chkFaChgCheck->Checked=(GetFieldValue("FaChgCheck")==1)? true: false;
    if(chkFaChgCheck->Checked)
      SetCheckToolbarStatus(true);
    else
      SetCheckToolbarStatus(false);
    labFaChgChecker->Caption=GetFieldValue("FaChgChecker");
    labFaChgCheckDate->Caption=GetFieldValue("FaChgCheckDate");
    seFaChgOGlkm->Text=GetFieldValue("FaChgOGlkm");
    chkFaChgPost->Checked=GetFieldValue("FaChgPost")=="1";
    labFaChgSysDate->Caption=GetFieldValue("FaChgSysDate");
}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChPrd::SendDataToComObject()
{
    SetFieldValue("FaChgType","6");
    SetFieldValue("FaChgCode",seFaChgCode->Text);
    SetFieldValue("FaChgDate",sdFaChgDate->Text);
    SetFieldValue("FaChgFMonth",scFaChgFMonth->Text);
    SetFieldValue("FaChgFadn",seFaChgFadn->Text);
    SetFieldValue("FaChgDesc",seFaChgDesc->Text);
    SetFieldValue("FaChgOPeriod",seFaChgOPeriod->Text);
    SetFieldValue("FaChgNPeriod",seFaChgNPeriod->Text);
    SetFieldValue("FaChgUser",labFaChgUser->Caption);
    SetFieldValue("FaChgOGlkm",seFaChgOGlkm->Text);
    SetFieldValue("FaChgPost",chkFaChgPost->Checked ? "1":"0");
}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChPrd::WaitUserInput()
{
   seFaChgCode->SetFocus();
}
//---------------------------------------------------------------------------
AnsiString __fastcall TfrmFaChPrd::GetDataToGrid()
{
    AnsiString  s;
    seFaChgFadn->LocateKey(GetFieldValue("FaChgFadn"));
    s = "\t" +GetFieldValue("FaChgCode")+
        "\t" +GetFieldValue("FaChgFadn")+
        "\t" +seFaChgFadn->ItemData[1]+
        "\t" +GetFieldValue("FaChgDate");
    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)
{
   if(OpenGlkmForm())
     seFaChgOGlkm->Text=GetGlkmValue(gtOpenForm, "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(Query,seFaChgFadn,Sql,"fadncode","fadnname","FadnPeriod");
          }
         break;
        case euSdFc:
          if(ShowUpdateMessage(MsgSrc,MsgType))
            FillComboBox(Query,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) 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=new  TComResultSet(Handle,g_ClientHandle);
      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;
      } 
    }

}
//---------------------------------------------------------------------------
bool __fastcall TfrmFaChPrd::BeforeCheck()
{
  SetFieldValue("FaChgCheck",1);
  SetFieldValue("FaChgChecker",g_sdUserCode);
  SetFieldValue("FaChgCheckDate",g_sdCurDate);
  return true;
}
//---------------------------------------------------------------------------
bool __fastcall TfrmFaChPrd::BeforeUnCheck()
{
  SetFieldValue("FaChgCheck",0);
  SetFieldValue("FaChgChecker","");
  SetFieldValue("FaChgCheckDate",NULL);
  return true;
}
//---------------------------------------------------------------------------

void __fastcall TfrmFaChPrd::FormClose(TObject *Sender,
      TCloseAction &Action)
{
   //delete g_sdRsGlkm;
   TRecBaseForm::FormClose(Sender,Action);
        
}
//---------------------------------------------------------------------------

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -