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

📄 sohcheck.cpp

📁 速达开源ERP系统
💻 CPP
字号:
//---------------------------------------------------------------------------

#include <vcl.h>
#pragma hdrstop

#include "SohCheck.h"
//---------------------------------------------------------------------------
#pragma package(smart_init)
#pragma link "ListBaseForm"
#pragma link "DateEdit"
#pragma link "SDComboBox"
#pragma link "SDEdit"
#pragma link "SDGrid"
#pragma resource "*.dfm"
TfrmSohCheck *frmSohCheck;
//---------------------------------------------------------------------------
__fastcall TfrmSohCheck::TfrmSohCheck(TComponent* Owner)
        :TListBaseForm(Owner,euSdSoh,"")
{
}
//---------------------------------------------------------------------------
void __fastcall TfrmSohCheck::InitEditControl()
{
 FillComboBox(scSohSaler,"Select userCode,UserName from sdUser where UserCode in (select SalerCode from SdSaler)","UserName","UserCode");
 FillComboBox(scSohClient,"Select ClientCode,ClientName from sdClient where ClientCancel=0","ClientName","ClientCode");
}
//---------------------------------------------------------------------------

void __fastcall TfrmSohCheck::ClearControl()
{
           seSohCodeF->Text            ="";
           seSohCodeT->Text            ="";
           deSohDateF->Text            ="";
           deSohDateT->Text            ="";
           scSohClient->ItemIndex      =-1;
           scSohSaler->ItemIndex       =-1;

           SohGrid->RowCount=1;
           SodGrid->RowCount=1;
           btnCheck->Enabled=false;
}
//---------------------------------------------------------------------------

void __fastcall TfrmSohCheck::GetDataFromComObject(int Section)
{
}
//---------------------------------------------------------------------------

void __fastcall TfrmSohCheck::SendDataToComObject(int Section)
{
}
//---------------------------------------------------------------------------

void __fastcall TfrmSohCheck::WaitUserInput(int Section)
{
}
void __fastcall TfrmSohCheck::ChangeToBrowseState(bool Browse)
{
  ClearControl();
}
//---------------------------------------------------------------------------
void __fastcall TfrmSohCheck::DisplayBill()
{
        FillHeadGridWithData();
        comServer->MoveFirst();
        FillDetailGridWithData();
}
//---------------------------------------------------------------------------

void __fastcall TfrmSohCheck::GetBill(AnsiString WhereStr)
{
    comServer->FilterString=WideString(WhereStr);
    comServer->Query();
    if (comServer->RecordCount!=0)      //Found it
       {
         btnCheck->Enabled=true;
         DisplayBill();
       }
       else
        ShowMessageWindow("在数据库中没有查到所需记录,请重新输入条件",mwsInformation);
   RecodCount->Caption="查询单据数为:"+IntToStr(comServer->RecordCount);
}
//---------------------------------------------------------------------------

void __fastcall TfrmSohCheck::FillDetailGridWithData()
{
      int i;
      AnsiString ItemStr;
      SodGrid->RowCount=1;
      for (i=0;i<comServer->ItemCount;i++)
      {
          comServer->LocateItemByIndex(i);
          ItemStr="\t"+GetDetailValue(fiSodLine)+"\t"+
                    GetDetailValue(fiSodGoods)+"\t"+GetDetailValue(fiSodUnit)+"\t"+
                    GetDetailValue(fiSodPrice)+"\t"+GetDetailValue(fiSodDisc)+"\t"+
                    GetDetailValue(fiSodQty)+"\t"+GetDetailValue(fiSodRecDate);
          SodGrid->AddItem(ItemStr);
      }
}
void __fastcall TfrmSohCheck::FillHeadGridWithData()
{
      int i;
      AnsiString HeadStr;
      SohGrid->RowCount=1;
      for (i=0;i<comServer->RecordCount;i++)
      {
          comServer->LocateByIndex(i);
          HeadStr="\t"+AnsiString("  ")+"\t"+GetHeadValue(fiSohCode)+"\t"+GetHeadValue(fiSohContract)+"\t"+
                       GetHeadValue(fiSohClient)+"\t"+GetHeadValue(fiSohDate)+"\t"+
                       GetHeadValue(fiSohCurrency)+"\t"+GetHeadValue(fiSohSettleMode)+"\t"+
                       GetHeadValue(fiSohSaler);
          SohGrid->AddItem(HeadStr);
      }

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

AnsiString __fastcall TfrmSohCheck::GetHeadValue(int Index)
{
        WideString S;
        S = ReadFieldValue(comServer,Index);
        return S;
}
//---------------------------------------------------------------------------

AnsiString __fastcall TfrmSohCheck::GetDetailValue(int Index)
{
        WideString S;
        S = ReadItemValue(comServer,Index);
        return S;
}
//---------------------------------------------------------------------------
void __fastcall TfrmSohCheck::SetHeadValue(int Index,AnsiString Value)
{
       WriteFieldValue(comServer,Index,WideString(Value));
}

//---------------------------------------------------------------------------

void __fastcall TfrmSohCheck::SetDetailValue(int Index,AnsiString Value)
{
       WriteItemValue(comServer,Index,WideString(Value));
}
//---------------------------------------------------------------------------



void __fastcall TfrmSohCheck::FormShow(TObject *Sender)
{
//       InitEditControl();
       ClearControl();
       ChangeToBrowseState(true);

}
//---------------------------------------------------------------------------
AnsiString __fastcall TfrmSohCheck::GetWhereSQLString()
{
     AnsiString WhereStr;
     WhereStr="SohCheck=0 and SohCancel=0";
     WhereStr=WhereStr+" and SohClient in (select ClientCode from sdClient where ClientCancel=0)";
     if(!seSohCodeF->Text.IsEmpty())
        WhereStr=WhereStr+" and SohCode>='"+Trim(seSohCodeF->Text)+"'";
     if(!seSohCodeT->Text.IsEmpty())
        WhereStr=WhereStr+" and SohCode<='"+Trim(seSohCodeT->Text)+"'";
     if(!scSohSaler->Text.IsEmpty())
        WhereStr=WhereStr+" and SohSaler='"+Trim(scSohSaler->ItemData[1])+"'";
     if(!deSohDateF->Text.IsEmpty())
        WhereStr=WhereStr+" and SohDate>='"+FormatDateTime("YYYY-MM-DD",deSohDateF->Date)+"'";
     if(!deSohDateT->Text.IsEmpty())
        WhereStr=WhereStr+" and SohDate<='"+FormatDateTime("YYYY-MM-DD",deSohDateT->Date)+"'";
     if(!scSohClient->Text.IsEmpty())
        WhereStr=WhereStr+" and SohClient='"+Trim(scSohClient->ItemData[1])+"'";
   return(WhereStr);
}


void __fastcall TfrmSohCheck::btnClearClick(TObject *Sender)
{
       ClearControl();
}
//---------------------------------------------------------------------------

void __fastcall TfrmSohCheck::btnQueryClick(TObject *Sender)
{
 SohGrid->RowCount=1;
 SodGrid->RowCount=1;
 btnCheck->Enabled=false;

  AnsiString WhereStr=GetWhereSQLString();
  GetBill(WhereStr);
}
//---------------------------------------------------------------------------



void __fastcall TfrmSohCheck::SohGridClick(TObject *Sender)
{
    if(SohGrid->Row>0)
    {
      comServer->LocateByKey(WideString(SohGrid->TextMatrix[SohGrid->Row][2]));
     if(SohGrid->Col == 1)
     {
      if(SohGrid->TextMatrix[SohGrid->Row][1]=="√")
        {
           SohGrid->TextMatrix[SohGrid->Row][1]="";
         }
        else
         {
           SohGrid->TextMatrix[SohGrid->Row][1]="√";
         }
      }
      FillDetailGridWithData();
     }
}
//---------------------------------------------------------------------------

void __fastcall TfrmSohCheck::btnCheckClick(TObject *Sender)
{
  for(int i=1; i<SohGrid->RowCount;i++)
  {
   if(SohGrid->TextMatrix[i][1]=="√")
   {
    comServer->LocateByKey(WideString(SohGrid->TextMatrix[i][2]));
    SetHeadValue(fiSohChecker,g_sdUserCode);
    try{
       comServer->Check(1);
    }
    catch(Exception &e)
    {
     throw Exception(e.Message);
    }

   }
 }
  ClearControl();
  btnQueryClick(Sender);
}
//---------------------------------------------------------------------------


void __fastcall TfrmSohCheck::btnQuiteClick(TObject *Sender)
{
 Close();
}
//---------------------------------------------------------------------------

void __fastcall TfrmSohCheck::SohGridMouseMove(TObject *Sender,
      TShiftState Shift, int X, int Y)
{
   int Column,Row;
   SohGrid->MouseToCell(X,Y,Column,Row);
   if(Column==1&&Row>0)
      SohGrid->Cursor=crHandPoint;
   else
      SohGrid->Cursor=crDefault;

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

⌨️ 快捷键说明

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