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

📄 fachdmc.cpp

📁 科思ERP部分源码及控件
💻 CPP
字号:
//---------------------------------------------------------------------------

#include <vcl.h>
#pragma hdrstop

#include "FaChWP.h"
#include "FaChDmc.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"
TfrmFaChDmc *frmFaChDmc;
//---------------------------------------------------------------------------
__fastcall TfrmFaChDmc::TfrmFaChDmc(TComponent* Owner, HWND chWnd, AnsiString MidCode,AnsiString WhereStr)
        : TRecBaseForm(Owner,chWnd,MidCode,WhereStr)
{
   InitRsGlkm("");
   IsUserCheck = true;
}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChDmc::InitEditControl()
{
    FillComboBox(Handle,scFaChgFMonth,"select FcMonth from sdFc order By FcMonth","FcMonth");
    FillEdit(Handle,seFaChgFadn,"select  fadncode,fadnname,Fadnfadm  from sdfadn  order By fadncode","fadncode","fadnname","Fadnfadm");
    FillComboBox(Handle,scFaChgOFadm,"select  fadmcode,fadmname  from sdfadm order By fadmcode","fadmname","fadmcode");
    FillComboBox(Handle,scFaChgNFadm,"select  fadmcode,fadmname  from sdfadm order By fadmcode","fadmname","fadmcode");
    ClientGroup->AddComponent(2,false,false,true,FloatPanel1,FloatPanel1->Name);
    ClientGroup->AddComponent(2,true,true,false, sgFaChDmc,sgFaChDmc->Name);
    ClientGroup->AddComponent(2,true,true,true, scFaChgOFadm,scFaChgOFadm->Name);
    ClientGroup->AddComponent(2,false,false,false, seFaChgCode,seFaChgCode->Name);
    ClientGroup->AddComponent(2,true,true,true,scFaChgFMonth,scFaChgFMonth->Name);
}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChDmc::ClearControl(bool BringToNext)
{
     if(!BringToNext)
    {

       seFaChgCode->Text      ="";         //变动单号
       sdFaChgDate->Text      =g_sdCurDate;//变动日期
       scFaChgFMonth->Text    =g_sdEMonth;//财务月份
       seFaChgFadn->Text      ="";         //设备编码
       seFaChgFadnName->Text  ="";         //设备名称
       seFaChgDesc->Text      ="";         //变动原因
       scFaChgOFadm->Text      ="";         //变动前原值
       scFaChgNFadm->ItemIndex =-1;         //变动后原值
       labFaChgUser->Caption   =g_sdUserCode;//操作员
       chkFaChgCheck->Checked  =false;      //审核标志
       labFaChgChecker->Caption="";         //审核人
       labFaChgCheckDate->Caption="";         //审核日期
       seFaChgOGlkm->Text      ="";         //对方科目
       chkFaChgPost->Checked   =false;         //制凭证标志
       labFaChgSysDate->Caption="";         //系统日期
    }

}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChDmc::GetDataFromComObject()
{
    seFaChgCode->Text=GetFieldValue("FaChgCode");
    sgFaChDmc->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];
    seFaChgDesc->Text=GetFieldValue("FaChgDesc");
    scFaChgOFadm->LocateKey(GetFieldValue("FaChgOFadm"));
    scFaChgOFadm->Text=scFaChgOFadm->ItemData[0];
    scFaChgNFadm->LocateKey(GetFieldValue("FaChgNFadm"));
    scFaChgNFadm->Text=scFaChgNFadm->ItemData[0];
    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 TfrmFaChDmc::SendDataToComObject()
{
    SetFieldValue("FaChgType","5");
    SetFieldValue("FaChgCode",seFaChgCode->Text);
    SetFieldValue("FaChgDate",sdFaChgDate->Text);
    SetFieldValue("FaChgFMonth",scFaChgFMonth->Text);
    SetFieldValue("FaChgFadn",seFaChgFadn->Text);
    SetFieldValue("FaChgDesc",seFaChgDesc->Text);
    SetFieldValue("FaChgOFadm",scFaChgOFadm->ItemData[1]);
    SetFieldValue("FaChgNFadm",scFaChgNFadm->ItemData[1]);
    SetFieldValue("FaChgUser",labFaChgUser->Caption);
    SetFieldValue("FaChgOGlkm",seFaChgOGlkm->Text);
    SetFieldValue("FaChgPost",chkFaChgPost->Checked ? "1":"0");
    SetFieldValue("FaChgCheck",chkFaChgCheck->Checked ? "1":"0");
    SetFieldValue("FaChgChecker",labFaChgChecker->Caption);
}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChDmc::WaitUserInput()
{
   seFaChgCode->SetFocus();
}
//---------------------------------------------------------------------------
AnsiString __fastcall TfrmFaChDmc::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 TfrmFaChDmc::RefreshGridData(int mAction)
{
    AnsiString ItemStr;
    ItemStr = GetDataToGrid();
    if (mAction ==  0)   //Add
    {
        sgFaChDmc->AddItem(ItemStr);
    }
    else if(mAction ==  1)   //Modify
    {
        int i   =   sgFaChDmc->Row;
        sgFaChDmc->RemoveItem(i);
        sgFaChDmc->AddItem(ItemStr,i);
    }
    else if(mAction ==  2)      //Delete
    {
        sgFaChDmc->RemoveItem(sgFaChDmc->Row);
    }
}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChDmc::FillGridWithData()
{
    AnsiString ItemStr;
    comServer->FilterString="FACHGTYPE='5'";
    comServer->Query();
    comServer->MoveFirst();
    sgFaChDmc->RowCount    =   1;
    while (comServer->Eof   ==  0)
    {
        ItemStr =  GetDataToGrid();
        sgFaChDmc->AddItem(ItemStr);
        comServer->MoveNext();
    }
}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChDmc::FormShow(TObject *Sender)
{
    FillGridWithData();
    comServer->MoveFirst();
    GetDataFromComObject();
}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChDmc::seFaChgOGlkmButtonClick(TObject *Sender)
{
   if(OpenGlkmForm())
     seFaChgOGlkm->Text=GetGlkmValue(gtOpenForm, "GLKMCODE");
}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChDmc::scFaChgNFadmClick(TObject *Sender)
{
    AnsiString Passtemp,m_Sql,LabCap[4];
    TComResultSet *FadnResultSet=new  TComResultSet(Handle,g_ClientHandle);
    try
    {
     if(seFaChgFadn->Text.IsEmpty())
       throw Exception("设备编码不能为空");
     TfrmChWP *TempChWP=new TfrmChWP(this);
     TempChWP->ShowModal();
     if(TempChWP->btOk->ModalResult==mrYes)
     {
       FadnResultSet->Close();
       m_ChWP[0]=TempChWP->seBWork->Text;
       m_ChWP[1]=TempChWP->seAWork->Text;
       m_ChWP[2]=TempChWP->seTWork->Text;
       m_ChWP[3]=TempChWP->seBPeriod->Text;
       m_ChWP[4]=TempChWP->seAPeriod->Text;
       m_ChWP[5]=TempChWP->sePeriod->Text;
     }
    }
    __finally
    {
     delete FadnResultSet;
    }
}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChDmc::RefreshUpdateData(int MsgSrc,int MsgType)
{
/*
      switch(MsgSrc)
      {
        case euSdFadm:
          if(ShowUpdateMessage(MsgSrc,MsgType))
          {
            FillComboBox(Query,scFaChgOFadm,"select  fadmcode,fadmname  from sdfadm order By fadmcode","fadmname","fadmcode");
            FillComboBox(Query,scFaChgNFadm,"select  fadmcode,fadmname  from sdfadm order By fadmcode","fadmname","fadmcode");
          }
         break;
        case euSdFadn:
          if(ShowUpdateMessage(MsgSrc,MsgType))
            FillEdit(Query,seFaChgFadn,"select  fadncode,fadnname,Fadnfadm  from sdfadn  order By fadncode","fadncode","fadnname","Fadnfadm");
         break;
        case euSdFc:
          if(ShowUpdateMessage(MsgSrc,MsgType))
            FillComboBox(Query,scFaChgFMonth,"select FcMonth from sdFc order By FcMonth","FcMonth");
         break;
       default:
         break;
      }
*/
}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChDmc::seFaChgCodeKeyDown(TObject *Sender, WORD &Key,
      TShiftState Shift)
{
    if(Key==13 && CurrentState==caNormal)
    {
      comServer->LocateByKey(seFaChgCode->Text);
      GetDataFromComObject();
    }

}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChDmc::sgFaChDmcClick(TObject *Sender)
{
    if (sgFaChDmc->Row > 0)
         comServer->LocateByKey(sgFaChDmc->TextMatrix[sgFaChDmc->Row][1]);
    if (!comServer->Eof)
         GetDataFromComObject();

}
//---------------------------------------------------------------------------

void __fastcall TfrmFaChDmc::seFaChgFadnButtonClick(TObject *Sender)
{
    AnsiString SqlStr;
    TfrmWnQuery *p;
    SqlStr="003[设备编码][设备名称][折旧方法]select fadncode, fadnname,Fadnfadm 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];
      scFaChgOFadm->LocateKey(p->ColData[3]);
    }
    delete p;
}
//---------------------------------------------------------------------------

void __fastcall TfrmFaChDmc::seFaChgFadnKeyDown(TObject *Sender, WORD &Key,
      TShiftState Shift)
{
    if(Key==13)
    {
      TComResultSet *TResultSet=new  TComResultSet(Handle,g_ClientHandle);
      AnsiString SQL="select fadncode, fadnname,Fadnfadm from sdfadn  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");
       scFaChgOFadm->LocateKey(TResultSet->FieldByName("Fadnfadm"));
       TResultSet->Close();
      }
      __finally
      {
       delete TResultSet;
      } 
    }
}
//---------------------------------------------------------------------------
void __fastcall TfrmFaChDmc::muSaveClick(TObject *Sender)
{
    AnsiString m_Sql;
    TComResultSet *FadnWP=new  TComResultSet(Handle,g_ClientHandle);
    TRecBaseForm::muSaveClick(Sender);
    m_Sql="Update sdfadn set fadnBWork='"+m_ChWP[0]+
          "' , fadnAWork='"+m_ChWP[1]+
          "' , fadnTWork='"+m_ChWP[2]+
          "' , fadnBPeriod='"+m_ChWP[3]+
          "' , fadnAPeriod='"+m_ChWP[4]+
          "' , fadnPeriod='"+m_ChWP[5]+
          "' where fadncode='"+seFaChgFadn->Text+"'" ;
    try
    {
    FadnWP->Execute(m_Sql);
    }
    __finally
    {
      delete FadnWP;
    }  

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


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

}
//---------------------------------------------------------------------------

⌨️ 快捷键说明

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