vw_arcl.cpp

来自「一个以前收集的基于C/S架构的ERP客户端源代码」· C++ 代码 · 共 305 行

CPP
305
字号
//---------------------------------------------------------------------------

#include <vcl.h>
#pragma hdrstop

#include "VW_Arcl.h"
#include "VW_Arsl.h"
//---------------------------------------------------------------------------
#pragma package(smart_init)
#pragma link "QueryBaseForm"
#pragma link "SDGrid"
#pragma link "KSAdvReport"
#pragma resource "*.dfm"
TfrmVW_Arcl *frmVW_Arcl;
//---------------------------------------------------------------------------
__fastcall TfrmVW_Arcl::TfrmVW_Arcl(TComponent* Owner, HWND chWnd, AnsiString MidCode,AnsiString WhereStr)
        : TQueryBaseForm(Owner,chWnd,MidCode,WhereStr)
{
 FilterStr="";
 sSQL="";
 LateBillCode="";
 PageControl1->ActivePage=TabSheet1;
 sgArcl->RowCount=1;
 sgArcl_N->RowCount=1;
}
//---------------------------------------------------------------------------
__fastcall TfrmVW_Arcl::TfrmVW_Arcl(TComponent* Owner,AnsiString wherestr)
        : TQueryBaseForm(Owner)
{
 FilterStr="";
 sSQL="";
 LateBillCode="";
 PageControl1->ActivePage=TabSheet1;
 sgArcl->RowCount=1;
 sgArcl_N->RowCount=1;

 tbControl->Enabled=false;
 TBorderIcons tempBI = BorderIcons;
 tempBI >> biMinimize;
 BorderIcons = tempBI;
 FilterStr=wherestr;
 FillGridWithData();
}
//---------------------------------------------------------------------------
void __fastcall TfrmVW_Arcl::tbQueryClick(TObject *Sender)
{
  //if(!ShowQueryWindow())
   // return;
  try{
    StartWaitForm("正在查询,请稍候...");
    FillGridWithData();
  }
  __finally
  {
    EndWaitForm();
  }
}
//---------------------------------------------------------------------------
void __fastcall TfrmVW_Arcl::ClearControl(bool BringToNext)
{
 return;
}
//---------------------------------------------------------------------------
void __fastcall TfrmVW_Arcl::GetDataFromComObject()
{
 return;
}
//---------------------------------------------------------------------------
void __fastcall TfrmVW_Arcl::WaitUserInput()
{
 return;
}
//---------------------------------------------------------------------------
void __fastcall TfrmVW_Arcl::RefreshGridData(int mAction)
{
 return;
}
//---------------------------------------------------------------------------
void __fastcall TfrmVW_Arcl::DisplayBill()
{
 return;
}
//---------------------------------------------------------------------------
void __fastcall TfrmVW_Arcl::GetBill(AnsiString BillID)
{
 return;
}
//---------------------------------------------------------------------------
//获取查询语句
AnsiString __fastcall TfrmVW_Arcl::GetQueryStr()
{
 AnsiString Selectstr,Fromstr,Wherestr,Orderstr;
 Selectstr="select  "
          +AnsiString("ArclFmonth, ")          //月份
          +AnsiString("ArclClient, ")          //客户
          +AnsiString("ArclCurrency, ")        //币种
          +AnsiString("ArclBoyAmt, ")          //年初金额
          +AnsiString("ArclNBoyAmt, ")         //本币金额
          +AnsiString("ArclBopAmt, ")          //期初金额
          +AnsiString("ArclNBopAmt, ")         //本币期初金额
          +AnsiString("ArclIopAmt, ")          //本期发生额
          +AnsiString("ArclNIopAmt, ")         //本币本期发生额
          +AnsiString("ArclOopAmt, ")          //本期收款额
          +AnsiString("ArclNOopAmt, ")         //本币本期收款额
          +AnsiString("ArclIoyAmt, ")          //本年发生额
          +AnsiString("ArclNIoyAmt, ")         //本币本年发生额
          +AnsiString("ArclOoyAmt, ")          //本年收款额
          +AnsiString("ArclNOoyAmt, ")         //本币本年收款额
          +AnsiString("ArclAoyAmt, ")          //本年累计
          +AnsiString("ArclNAoyAmt ");         //本币本年累计
 Fromstr=" from SDVW_Arcl ";
 if(FilterStr=="")
  Wherestr="";
 else
  Wherestr=" where "+FilterStr;
 Orderstr=" order by ArclFmonth desc,ArclClient ";
 sSQL=Selectstr+Fromstr+Wherestr+Orderstr;
 return(sSQL);
}
//---------------------------------------------------------------------------
void __fastcall TfrmVW_Arcl::FillGridWithData()
{
 TComResultSet *RsQuery;
 AnsiString ItemStr,sSql;
 //获取查询语句
 sSql=GetQueryStr();
 if(sSql=="")
  return;
 sgArcl->RowCount=1;
 sgArcl_N->RowCount=1;
 LateBillCode="";
 RsQuery=new  TComResultSet(Handle,g_ClientHandle);
 RsQuery->Open(sSql,"");
 RsQuery->MoveFirst();
 while( RsQuery->Eof == 0)
 {
  ItemStr=     RsQuery->FieldByName("ArclFmonth")+
          "\t"+RsQuery->FieldByName("ArclClient")+
          "\t"+RsQuery->FieldByName("ArclCurrency")+
          "\t"+RsQuery->FieldByName("ArclBopAmt")+
          "\t"+RsQuery->FieldByName("ArclIopAmt")+
          "\t"+RsQuery->FieldByName("ArclOopAmt")+
          "\t"+RsQuery->FieldByName("ArclBoyAmt")+
          "\t"+RsQuery->FieldByName("ArclIoyAmt")+
          "\t"+RsQuery->FieldByName("ArclOoyAmt")+
          "\t"+RsQuery->FieldByName("ArclAoyAmt");
  sgArcl->AddItem(ItemStr);
  ItemStr=     RsQuery->FieldByName("ArclFmonth")+
          "\t"+RsQuery->FieldByName("ArclClient")+
          "\t"+RsQuery->FieldByName("ArclCurrency")+
          "\t"+RsQuery->FieldByName("ArclNBopAmt")+
          "\t"+RsQuery->FieldByName("ArclNIopAmt")+
          "\t"+RsQuery->FieldByName("ArclNOopAmt")+
          "\t"+RsQuery->FieldByName("ArclNBoyAmt")+
          "\t"+RsQuery->FieldByName("ArclNIoyAmt")+
          "\t"+RsQuery->FieldByName("ArclNOoyAmt")+
          "\t"+RsQuery->FieldByName("ArclNAoyAmt");
  sgArcl_N->AddItem(ItemStr);
  RsQuery->MoveNext();
 }
 RsQuery->Close();
 delete RsQuery;
}
//---------------------------------------------------------------------------
AnsiString __fastcall TfrmVW_Arcl::DataConvert(AnsiString sFieldName,AnsiString sFieldValue)
{
 sFieldName=UpperCase(sFieldName);
 return("");
}
//---------------------------------------------------------------------------
void __fastcall TfrmVW_Arcl::muFirstClick(TObject *Sender)
{
 if(PageControl1->ActivePage == TabSheet1)
 {
   if(sgArcl->RowCount > 1)
   {
    sgArcl->Row=1;
   }
 }
 else
 {
   if(sgArcl_N->RowCount > 1)
   {
    sgArcl_N->Row=1;
   }
 }
}
//---------------------------------------------------------------------------
void __fastcall TfrmVW_Arcl::tbPreviousClick(TObject *Sender)
{
 if(PageControl1->ActivePage == TabSheet1)
 {
   if(sgArcl->RowCount > 1 && sgArcl->Row > 1)
   {
    sgArcl->Row=sgArcl->Row-1;
   }
 }
 else
 {
   if(sgArcl_N->RowCount > 1 && sgArcl_N->Row > 1)
   {
    sgArcl_N->Row=sgArcl_N->Row-1;
   }
 }
}
//---------------------------------------------------------------------------
void __fastcall TfrmVW_Arcl::muNextClick(TObject *Sender)
{
 if(PageControl1->ActivePage == TabSheet1)
 {
   if(sgArcl->RowCount > 1 && sgArcl->Row < sgArcl->RowCount-1)
   {
    sgArcl->Row=sgArcl->Row+1;
   }
 }
 else
 {
   if(sgArcl_N->RowCount > 1 && sgArcl_N->Row < sgArcl_N->RowCount-1)
   {
    sgArcl_N->Row=sgArcl_N->Row+1;
   }
 }
}
//---------------------------------------------------------------------------
void __fastcall TfrmVW_Arcl::muLastClick(TObject *Sender)
{
 if(PageControl1->ActivePage == TabSheet1)
 {
   if(sgArcl->RowCount > 1)
   {
    sgArcl->Row=sgArcl->RowCount-1;
   }
 }
 else
 {
   if(sgArcl_N->RowCount > 1)
   {
    sgArcl_N->Row=sgArcl_N->RowCount-1;
   }
 }
}
//---------------------------------------------------------------------------
void __fastcall TfrmVW_Arcl::tbRefreshClick(TObject *Sender)
{
 if(sSQL=="")
  return;
 FillGridWithData();
}
//---------------------------------------------------------------------------
void __fastcall TfrmVW_Arcl::sgArclClick(TObject *Sender)
{
 int ARow;
 if(PageControl1->ActivePage == TabSheet1)
 {
  ARow=sgArcl->Row;
  sgArcl_N->Row=ARow;
 }
 else
 {
  ARow=sgArcl_N->Row;
  sgArcl->Row=ARow;
 }
}
//---------------------------------------------------------------------------

void __fastcall TfrmVW_Arcl::sgArclDblClick(TObject *Sender)
{
 int ARow;
 AnsiString stmp;
 if(PageControl1->ActivePage == TabSheet1)
  ARow=sgArcl->Row;
 else
  ARow=sgArcl_N->Row;
 if(ARow < 1)
  return;
 TfrmVW_Arsl *p;
 try
 {
    StartWaitForm("正在启动应收明细账查询,请稍候...");
    stmp=" ArslFmonth='"+sgArcl->Cells[0][ARow]+"' and ArslClient='"+sgArcl->Cells[1][ARow]
        +"' and ArslCurrency='"+sgArcl->Cells[2][ARow]+"'";
    p=new TfrmVW_Arsl(this,stmp);
 }
 __finally
 {
    EndWaitForm();
 }
 p->ShowModal();
 delete p;

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


void __fastcall TfrmVW_Arcl::tbExportClick(TObject *Sender)
{
 if(PageControl1->ActivePage == TabSheet1)
  QueryGrid=sgArcl_N;
 else
  QueryGrid=sgArcl;
 TQueryBaseForm::tbExportClick(Sender);
}
//---------------------------------------------------------------------------

⌨️ 快捷键说明

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