// TabDlg.cpp : implementation file // #include "stdafx.h" #include "smsmanager.h" #include "TabDlg.h" #ifdef _DEBUG #define new DEBUG_NEW #undef THIS_FILE static char THIS_FILE[] = __FILE__; #endif ///////////////////////////////////////////////////////////////////////////// // CTabDlg dialog #include "MainFrm.h" #include "ProcessSocket.h" CTabDlg::CTabDlg(CWnd* pParent /*=NULL*/) : CDialog(CTabDlg::IDD, pParent) , m_bJCB(FALSE) { //{{AFX_DATA_INIT(CTabDlg) m_lCorp = -1; m_tBegin = COleDateTime::GetCurrentTime(); m_tEnd = COleDateTime::GetCurrentTime(); m_lMobileType = -1; m_bOld = FALSE; m_lAgent = -1; //}}AFX_DATA_INIT m_bInit = false; m_bRefresh = false; m_lQueryAgentID =0; m_bQueryAll = false; m_lAllSend = 0; m_lAllRecv = 0; m_lCurCorpID=0; m_lQueryCurCorpID = 0; lSmsCount=0; lSmsCountIndex=0; lSendCount=0; lSendCountIndex=0; lReportSucessCount=0; lReportSucessCountIndex=0; lReportFailCount=0; lReportFailCountIndex=0; lFailPerIndex=0; lMmsSmsCount=0; lMmsSmsCountIndex=0; lMmsSendCount=0; lMmsSendCountIndex=0; lMmsReportSucessCount=0; lMmsReportSucessCountIndex=0; lMmsReportFailCount=0; lMmsReportFailCountIndex=0; lMmsFailPerIndex=0; lOldIndex=0; lAddIndex=0; lUsedIndex=0; lMmsOldIndex=0; lMmsAddIndex=0; lMmsUsedIndex=0; } void CTabDlg::DoDataExchange(CDataExchange* pDX) { CDialog::DoDataExchange(pDX); //{{AFX_DATA_MAP(CTabDlg) DDX_Control(pDX, IDC_TAB_AGENTID, m_E_AgentID); DDX_Control(pDX, IDC_TAB_AGENT, m_L_Agent); DDX_Control(pDX, IDC_TAB_CORPID, m_E_CorpID); DDX_Control(pDX, IDC_TAB_CORP, m_L_Corp); DDX_Control(pDX, IDC_TAB_S1, m_S_S1); DDX_Control(pDX, IDC_TAB_LIST, m_wndList); DDX_CBIndex(pDX, IDC_TAB_CORP, m_lCorp); DDX_DateTimeCtrl(pDX, IDC_TAB_TBEGIN, m_tBegin); DDX_DateTimeCtrl(pDX, IDC_TAB_TEND, m_tEnd); DDX_CBIndex(pDX, IDC_TAB_AGENT, m_lAgent); //}}AFX_DATA_MAP DDX_Check(pDX, IDC_TAB_JCB, m_bJCB); } BEGIN_MESSAGE_MAP(CTabDlg, CDialog) //{{AFX_MSG_MAP(CTabDlg) ON_WM_SIZE() ON_BN_CLICKED(IDC_TAB_QUERY, OnTabQuery) ON_BN_CLICKED(IDC_TAB_OLD, OnTabOld) ON_BN_CLICKED(IDC_TAB_QUERY2, OnTabQuery2) ON_NOTIFY(NM_RCLICK, IDC_TAB_LIST, OnRclickTabList) ON_BN_CLICKED(IDC_TAB_QUERY3, OnTabQuery3) ON_BN_CLICKED(IDC_TAB_QUERY4, OnTabQuery4) //}}AFX_MSG_MAP ON_COMMAND(MENU_TAB_COPY , On_User_Copy ) ON_COMMAND(MENU_TAB_COPYEX , On_User_CopyEx ) END_MESSAGE_MAP() ///////////////////////////////////////////////////////////////////////////// // CTabDlg message handlers BOOL CTabDlg::ReShow(BOOL bRefresh) { ShowWindow( SW_SHOW ); if ( bRefresh || !m_bRefresh ) { RefreshInfo(); } return true; } BOOL CTabDlg::OnInitDialog() { CDialog::OnInitDialog(); //取得共用参数 //CMainFrame * pFrame = static_cast ((CMainFrame *)AfxGetMainWnd()); this->GetParent()->GetParentFrame(); m_pMainFrame = (CMainFrame *)this->GetParent()->GetParentFrame(); m_pSocket = &m_pMainFrame->m_Socket; //初始化List m_Image.Create(16,16,ILC_COLOR16|ILC_MASK,5,5); // m_Image.Add(AfxGetApp()->LoadIcon(IDI_L_TAB) ); m_wndList.SubClassWindow2(); if ( m_pMainFrame->GetUserPurview(PURVIEW_MANAGER_ADD,false) ) { m_wndList.SetHeadings(_T("序号,50; 企业ID,60;企业名称,120;短信数量,100;短信提交量,100;短信回执成功,100;短信回执失败,100;短信失败率,100;彩信数量,100;彩信提交量,100;彩信回执成功,100;彩信回执失败,100;彩信失败率,100;")); } else { m_wndList.SetHeadings(_T("序号,50; 企业ID,60;企业名称,120;短信数量,100;彩信数量,100;")); } //m_wndList.SetHeadings(_T("序号,50; 短信类型,100;短信数量,100;计费数量,100;")); m_wndList.SetGridLines(true); m_wndList.SetImageList(&m_Image,LVSIL_SMALL); m_bInit = true; /* //默认取上月的内容 SYSTEMTIME t; ::GetLocalTime(&t); t.wDay = 1;//从1号起 t.wMonth = t.wMonth-1; if ( t.wMonth <=0 ) { t.wMonth = 12; t.wYear = t.wYear-1; } m_tBegin.SetDate( t.wYear,t.wMonth,t.wDay ); //起始 if ( t.wMonth == 1 || t.wMonth == 3 || t.wMonth == 5 || t.wMonth == 7 || t.wMonth == 8 || t.wMonth == 10 || t.wMonth == 12 ) { t.wDay = 31; } else if (t.wMonth == 2 ) t.wDay = 28; else t.wDay = 30; m_tEnd.SetDate( t.wYear,t.wMonth,t.wDay );//结束 */ SYSTEMTIME t; ::GetLocalTime(&t); m_tBegin.SetDate( t.wYear,t.wMonth,1 ); //起始 m_tEnd.SetDate( t.wYear,t.wMonth,t.wDay );//结束 #ifdef SMSCENTER_NX COleDateTime t2 = COleDateTime::GetCurrentTime(); COleDateTimeSpan tSpan2(1,0,0,0); t2 = t2-tSpan2; m_tEnd.SetDate( t2.GetYear(),t2.GetMonth(),t2.GetDay() );//结束 #endif m_lMobileType = 0; //默认查看所有手机类型 #ifdef SMSCENTER_ADC GetDlgItem(IDC_TAB_QUERY4)->ShowWindow(SW_SHOW); #endif #ifdef SMSCENTER_NX GetDlgItem(IDC_TAB_AGENT_S)->ShowWindow(SW_HIDE); GetDlgItem(IDC_TAB_AGENT)->ShowWindow(SW_HIDE); GetDlgItem(IDC_TAB_AGENTID)->ShowWindow(SW_HIDE); GetDlgItem(IDC_TAB_QUERY3)->ShowWindow(SW_HIDE); GetDlgItem(IDC_TAB_JCB)->ShowWindow(SW_HIDE); #endif UpdateData(false); return TRUE; // return TRUE unless you set the focus to a control // EXCEPTION: OCX Property Pages should return FALSE } void CTabDlg::OnSize(UINT nType, int cx, int cy) { CDialog::OnSize(nType, cx, cy); if ( m_bInit ) { CRect rect; m_S_S1.GetWindowRect(&rect); m_wndList.MoveWindow( 0 , 0+rect.Height()+5 , cx,cy-rect.Height()-5); } } BOOL CTabDlg::ReHide() { ShowWindow( SW_HIDE ); return true; } BOOL CTabDlg::RefreshInfo() { if ( !m_pMainFrame->GetUserPurview(PURVIEW_TAB) ) { return false; } m_pMainFrame->SendFrame(SMSFUNC_CORP_NAME,NULL,0); m_pMainFrame->SendFrame(SMSFUNC_AGENT_NAME,NULL,0); //取代理信息 return true; } BOOL CTabDlg::ProcessSocket(Socket_Head *pHead) { CString strTemp; //取过滤信息 if (pHead->lFuncType == SMSFUNC_CORP_NAME) { m_bRefresh = true; //已经刷新过 ANS_Corp_Name * pCorp = (ANS_Corp_Name *)pHead->pFrame; ANS_Corp_NameData * pData = (ANS_Corp_NameData *)(pHead->pFrame+sizeof(ANS_Corp_Name)); m_L_Corp.ResetContent(); //删除原已有的企业 m_L_Corp.AddString( _T("所有企业") ); this->Close_Corp(); //关闭原队列 for ( int i=0;ilCount;i++ ) { ANS_Corp_NameData * pNewData = new ANS_Corp_NameData; *pNewData = *pData; POSITION pos = m_Corp.AddTail(pNewData); strTemp.Format( _T("%d-%s"),pData->lCorpID,pData->szCorpName); long lItem = m_L_Corp.AddString( strTemp ); m_L_Corp.SetItemData( lItem , (DWORD_PTR)pos); pData ++; } m_L_Corp.SetCurSel(0); return true; } //取代理商信息 if (pHead->lFuncType == SMSFUNC_AGENT_NAME) { ANS_Agent_Name * pAgent = (ANS_Agent_Name *)pHead->pFrame; ANS_Agent_NameData * pData = (ANS_Agent_NameData *)(pHead->pFrame+sizeof(ANS_Agent_Name)); this->Close_Agent(); m_L_Agent.ResetContent(); long lItem; CString strTemp; POSITION pos; lItem = m_L_Agent.AddString( _T("所有代理商") ); m_L_Agent.SetItemData( lItem , (DWORD_PTR)-10); lItem = m_L_Agent.AddString( _T("自有用户") ); m_L_Agent.SetItemData( lItem , (DWORD_PTR)-11); lItem = m_L_Agent.AddString( _T("代理用户") ); m_L_Agent.SetItemData( lItem , (DWORD_PTR)-12); for ( int i=0;ilCount;i++ ) { ANS_Agent_NameData * pNewData = new ANS_Agent_NameData; *pNewData = *pData; pos = m_Agent.AddTail(pNewData); strTemp.Format( _T("%d-%s"),pNewData->lAgentID,pNewData->szAgentName); lItem = m_L_Agent.AddString( strTemp ); //m_L_Agent.SetItemData( lItem , (DWORD_PTR)pos); m_L_Agent.SetItemData( lItem , (DWORD_PTR)pNewData->lAgentID); pData ++; } m_L_Agent.SetCurSel(0); return true; } if ( pHead->lFuncType == SMSFUNC_TAB ) { ANS_Tab * pTab = (ANS_Tab *)pHead->pFrame; ANS_TabData * pData = (ANS_TabData *)(pHead->pFrame+sizeof(ANS_Tab)); if ( m_bQueryAll ) { TCHAR Buf[32]; long lCount; //_T("序号,50;企业ID,80;企业名称,150; 发送数量,100;接收数量,100;")); lCount = m_wndList.GetItemCount(); m_wndList.InsertItem( lCount , _itot(lCount+1,Buf,10),0); //序号 _stprintf(Buf , _T("%d") , m_lCurCorpID); m_wndList.SetItemText(lCount,1,Buf); m_wndList.SetItemText(lCount,2,m_strCurName); long lSendCount=0; long lRecvCount=0; for ( int i=0;ilCount;i++) { switch( pData->lSmsType ) { case SMSTYPE_RECV: lRecvCount += pData->lCount; break; default: lSendCount += pData->lSFCount; break; } pData++; } m_lAllSend +=lSendCount; m_lAllRecv +=lRecvCount; m_wndList.SetItemText( lCount ,3 , _itot(lSendCount,Buf,10)); //数量 m_wndList.SetItemText( lCount ,4 , _itot(lRecvCount,Buf,10)); //数量 QueryNext(); } else { TCHAR Buf[32]; long lCount; long lSmsCount = 0; long lSmsSFCount=0; for ( int i=0;ilCount;i++) { lCount = m_wndList.GetItemCount(); m_wndList.InsertItem( lCount , _itot(i+1,Buf,10),0); //序号 _tcscpy( Buf , _T("未知") ); switch( pData->lSmsType ) { case SMSTYPE_SEND: _tcscpy(Buf , _T("发 送") ); break; case SMSTYPE_ZF: _tcscpy(Buf , _T("转 发") ); break; case SMSTYPE_ALARM: _tcscpy(Buf , _T("日程提醒") ); break; case SMSTYPE_EMAIL: _tcscpy(Buf , _T("短信邮差") ); break; case SMSTYPE_RECV: _tcscpy(Buf , _T("接 收") ); break; case SMSTYPE_SP: _tcscpy(Buf , _T("娱乐短信") ); break; case SMSTYPE_SWT: _tcscpy(Buf , _T("短信商务通") ); break; #ifdef SMSCENTER_ADC case SMSTYPE_ADC: _tcscpy(Buf , _T("ADC业务") ); break; #endif } m_wndList.SetItemText( lCount ,1 , Buf ); //类型 m_wndList.SetItemText( lCount ,2 , _itot(pData->lCount,Buf,10)); //数量 m_wndList.SetItemText( lCount ,3 , _itot(pData->lSFCount,Buf,10)); //数量 lSmsCount += pData->lCount; lSmsSFCount += pData->lSFCount; pData++; } lCount = m_wndList.GetItemCount(); m_wndList.InsertItem( lCount , _T(""),0); //合计 m_wndList.SetItemText( lCount,1, _T("合 计")); //合计 m_wndList.SetItemText( lCount,2, _itot(lSmsCount,Buf,10)); //合计 m_wndList.SetItemText( lCount,3, _itot(lSmsSFCount,Buf,10)); //合计 } return true; } if ( pHead->lFuncType == SMSFUNC_ADCHTHS ) { ANS_ADCHTHS * pTab = (ANS_ADCHTHS *)pHead->pFrame; ANS_ADCHTHSData * pData = (ANS_ADCHTHSData *)(pHead->pFrame+sizeof(ANS_ADCHTHS)); TCHAR Buf[32]; CString str; for ( int i=0;ilCount;i++) { //_T("序号,50; 企业名称,120;业务员名称,80;代理商名称,120;回收日期;120;")); //(_T("序号,50; 企业名称,250;业务员名称,80;代理商名称,180;回收日期,120;开通,60;创建日期,120;开通日期,120;")); m_wndList.InsertItem( i , _itot(i+1,Buf,10),0); //序号 str.Format( _T("%d - %s") , pData->lCorpID , pData->szCorpName ); m_wndList.SetItemText(i,1,str); m_wndList.SetItemText(i,2,pData->szYWYName); m_wndList.SetItemText(i,3,pData->szAgentName); str.Format( _T("%04d.%02d.%02d") , pData->tHSTime.wYear,pData->tHSTime.wMonth,pData->tHSTime.wDay ); m_wndList.SetItemText(i,4,str); if ( pData->szStatus[0] == '1' ) m_wndList.SetItemText(i,5,_T(" 否")); else m_wndList.SetItemText(i,5,_T(" 是")); str.Format( _T("%04d.%02d.%02d") , pData->tRegTime.wYear,pData->tRegTime.wMonth,pData->tRegTime.wDay ); m_wndList.SetItemText(i,6,str); str.Format( _T("%04d.%02d.%02d") , pData->tKTTime.wYear,pData->tKTTime.wMonth,pData->tKTTime.wDay ); m_wndList.SetItemText(i,7,str); pData ++; } return true; } return false; } void CTabDlg::Close() { Close_Corp(); Close_Agent(); } void CTabDlg::OnTabQuery() { UpdateData(true); if ( m_tEnd < m_tBegin ) { MessageBox( _T("查询结束日期不能小于起始日期,请改正!") , _T("错误") , MB_ICONWARNING ); return ; } if ( m_tBegin>COleDateTime::GetCurrentTime() ) { MessageBox( _T("查询起始日期不能大于当前日期,请改正!") , _T("错误") , MB_ICONWARNING ); return ; } lSmsCount=0; lSmsCountIndex=0; lSendCount=0; lSendCountIndex=0; lReportSucessCount=0; lReportSucessCountIndex=0; lReportFailCount=0; lReportFailCountIndex=0; lFailPerIndex=0; lMmsSmsCount=0; lMmsSmsCountIndex=0; lMmsSendCount=0; lMmsSendCountIndex=0; lMmsReportSucessCount=0; lMmsReportSucessCountIndex=0; lMmsReportFailCount=0; lMmsReportFailCountIndex=0; lMmsFailPerIndex=0; lOldIndex=0; lAddIndex=0; lUsedIndex=0; lMmsOldIndex=0; lMmsAddIndex=0; lMmsUsedIndex=0; m_tBegin.GetAsSystemTime(m_tQueryBegin); m_tEnd.GetAsSystemTime(m_tQueryEnd); m_tQueryEnd.wHour=23; m_tQueryEnd.wMinute=59; m_tQueryEnd.wSecond=59; m_bQueryJCB = m_bJCB; if ( m_lAgent == 0 ) //选择了所有代理商 { m_bQueryAll = false; m_wndList.DeleteAllItems(); m_wndList.DeleteAllColumns(); CString strHead = _T("序号,50;企业ID,60;企业名称,120; 短信数量,100;短信提交量,100;短信回执成功,100;短信回执失败,100;短信失败率,100;彩信数量,100;彩信提交量,100;彩信回执成功,100;彩信回执失败,100;彩信失败率,100;"); if ( m_pMainFrame->GetUserPurview(PURVIEW_MANAGER_ADD,false) ) { strHead = _T("序号,50;企业ID,60;企业名称,120; 短信数量,100;短信提交量,100;短信回执成功,100;短信回执失败,100;短信失败率,100;彩信数量,100;彩信提交量,100;彩信回执成功,100;彩信回执失败,100;彩信失败率,100;"); } else { strHead = _T("序号,50; 企业名称,120;短信数量,100;彩信数量,100;"); } long lCorpID = -1; if ( m_lCorp <= 0 ) //选了所有企业 { lCorpID = -1; } else { POSITION pos = (POSITION)m_L_Corp.GetItemData(m_lCorp); POSITION pos2 = pos; ANS_Corp_NameData * pData = m_Corp.GetNext( pos ); if (pData) { lCorpID = pData->lCorpID; } else { return; } } BOOL bJCB=false; if ( this->m_bJCB && lCorpID>0) { strHead = strHead + _T("短信上期结存,100;短信本期新增,100;短信本期结存,100;彩信上期结存,100;彩信本期新增,100;彩信本期结存,100;"); bJCB = true; } m_wndList.SetHeadings(strHead); //pTab->lMobileType = m_lMobileType-1; //手机类型 //pTab->bOld = m_bOld; //是否查询旧数据 #ifdef SMSCENTER_NX if (lCorpID <= 0) { m_bQueryAll = true; m_lAllSend = 0; m_lAllRecv = 0; m_lCurCorpID = 0; m_lQueryCurCorpID = 0; m_strCurName = _T(""); QueryNext(); return; } #endif REQ_Bill4 * pBill = new REQ_Bill4;memset(pBill,0,sizeof(REQ_Bill4)); pBill->lUserID = -1; //查询用户ID m_tBegin.GetAsSystemTime(pBill->tBegin); m_tEnd.GetAsSystemTime(pBill->tEnd); pBill->lCorpID = lCorpID; pBill->tEnd.wHour=23; pBill->tEnd.wMinute=59; pBill->tEnd.wSecond=59; pBill->bJCB = bJCB; //查询结存表 m_pMainFrame->SendFrame(SMSFUNC_BILL4,(BYTE*)pBill,sizeof(REQ_Bill4)); } else { m_wndList.DeleteAllItems(); m_wndList.DeleteAllColumns(); CString strHead = _T("序号,50; 企业ID,60;企业名称,120;短信数量,100;短信提交量,100;短信回执成功,100;短信回执失败,100;短信失败率,100;彩信数量,100;彩信提交量,100;彩信回执成功,100;彩信回执失败,100;彩信失败率,100;"); if ( m_pMainFrame->GetUserPurview(PURVIEW_MANAGER_ADD,false) ) { strHead = _T("序号,50; 企业ID,60;企业名称,120;短信数量,100;短信提交量,100;短信回执成功,100;短信回执失败,100;短信失败率,100;彩信数量,100;彩信提交量,100;彩信回执成功,100;彩信回执失败,100;彩信失败率,100;"); } else { strHead = _T("序号,50; 企业ID,60;企业名称,120;短信数量,100;彩信数量,100;"); } if ( this->m_bJCB) strHead = strHead + _T("短信上期结存,100;短信本期新增,100;短信本期结存,100;彩信上期结存,100;彩信本期新增,100;彩信本期结存,100;"); m_wndList.SetHeadings(strHead); m_lQueryAgentID = m_L_Agent.GetItemData(m_lAgent); m_bQueryAll = true; m_lAllSend = 0; m_lAllRecv = 0; m_lCurCorpID=0; m_lQueryCurCorpID=0; m_strCurName = _T(""); QueryNext(); } return ; } void CTabDlg::OnTabOld() { if ( m_B_Old.GetCheck() ) { GetDlgItem(IDC_TAB_MOBILETYPE)->EnableWindow(true); } else { GetDlgItem(IDC_TAB_MOBILETYPE)->EnableWindow(false); } } void CTabDlg::OnTabQuery2() { CString strTemp; CString strFind; m_E_CorpID.GetWindowText(strFind); if ( strFind.GetLength()<=0 ) return ; long lSel = m_L_Corp.GetCurSel(); long lCount = m_L_Corp.GetCount(); for ( int i=lSel+1 ; i=0 ) { m_L_Corp.SetCurSel(i); return ; } } for ( i=0 ; i=0 ) { m_L_Corp.SetCurSel(i); return ; } } } void CTabDlg::OnRclickTabList(NMHDR* pNMHDR, LRESULT* pResult) { *pResult = 0; ShowRMenu(); } void CTabDlg::ShowRMenu() { if (!m_pMainFrame->GetUserPurview(PURVIEW_TAB,false)) //没有查看权限 return ; CMenu menu; menu.CreatePopupMenu(); //复制 menu.AppendMenu(MF_STRING , MENU_TAB_COPY, _T(" 复制_表格 ") ); menu.AppendMenu(MF_STRING , MENU_TAB_COPYEX, _T(" 复制_帐单 ") ); //显示菜单 POINT pt ; ::GetCursorPos( &pt ); //this->ClientToScreen( &pt); menu.TrackPopupMenu(TPM_LEFTBUTTON | TPM_RIGHTBUTTON,pt.x,pt.y, this, NULL); menu.DestroyMenu(); } void CTabDlg::On_User_Copy() { m_wndList.CopyToClipboard(); return ; } void CTabDlg::On_User_CopyEx() { CString strTab; SYSTEMTIME t;::GetLocalTime(&t); long lCount=m_wndList.GetItemCount(); for ( int i=0 ; i0 ) strSmsCount = m_wndList.GetItemText(i,lSmsCountIndex); if ( lMmsSmsCountIndex>0 ) strMmsSmsCount = m_wndList.GetItemText(i,lMmsSmsCountIndex); BOOL bJCB = false; if ( lOldIndex>0 ) { bJCB = true; strOld = m_wndList.GetItemText(i,lOldIndex); } if ( lAddIndex>0 ) strAdd = m_wndList.GetItemText(i,lAddIndex); if ( lUsedIndex>0 ) strUsed = m_wndList.GetItemText(i,lUsedIndex); if ( lMmsOldIndex>0 ) strMmsOld = m_wndList.GetItemText(i,lMmsOldIndex); if ( lMmsAddIndex>0 ) strMmsAdd = m_wndList.GetItemText(i,lMmsAddIndex); if ( lMmsUsedIndex>0 ) strMmsUsed = m_wndList.GetItemText(i,lMmsUsedIndex); CString strTemp,strTemp2; CString strHead; CString strJCB; #ifdef MOBSET_OEM strHead += _T("\r\n\r\n 业务帐单\r\n\r\n\r\n"); #else strHead += _T("\r\n\r\n 短信易业务帐单\r\n\r\n\r\n"); #endif strTemp.Format( _T(" 企业ID:%s\r\n") , strCorpID ); strHead += strTemp; strTemp.Format( _T(" 企业名称:%s\r\n") , strCorpName); strHead += strTemp; strTemp.Format( _T(" 帐单时段:%04d年%02d月%02d日 -- %04d年%02d月%02d日\r\n"),m_tQueryBegin.wYear,m_tQueryBegin.wMonth,m_tQueryBegin.wDay,m_tQueryEnd.wYear,m_tQueryEnd.wMonth,m_tQueryEnd.wDay); strHead += strTemp; strTemp.Format( _T(" 查询时间:%04d年%02d月%02d日 %02d:%02d\r\n\r\n\r\n") , t.wYear,t.wMonth,t.wDay,t.wHour,t.wMinute ); strHead += strTemp; long lSmsCount = 0; long lSmsSFCount = 0; strTab=strTab + strHead+_T(" 业务类型 业务数量"); if ( bJCB ) { strTab+= _T(" 上期结存 本期新增 本期结存"); } strTab += _T("\r\n"); strTab+=_T(" =================================="); if ( bJCB ) { strTab+= _T("==========================================="); } strTab += _T("\r\n"); for ( int i=0;i<2;i++) { if ( i==0 ) { strTemp2.Format( _T("%8s") , _T("短信") ); strTemp= strTemp2; strTemp2.Format( _T("%21s") , strSmsCount ); strTemp+= strTemp2; if ( bJCB ) { strTemp2.Format( _T("%16s") , strOld ); strTemp+= strTemp2; strTemp2.Format( _T("%16s") , strAdd ); strTemp+= strTemp2; strTemp2.Format( _T("%16s") , strUsed ); strTemp+= strTemp2; } strTemp+=_T("\r\n"); } if ( i==1 ) { strTemp2.Format( _T("%8s") , _T("彩信") ); strTemp= strTemp2; strTemp2.Format( _T("%21s") , strMmsSmsCount ); strTemp+= strTemp2; if ( bJCB ) { strTemp2.Format( _T("%16s") , strMmsOld ); strTemp+= strTemp2; strTemp2.Format( _T("%16s") , strMmsAdd ); strTemp+= strTemp2; strTemp2.Format( _T("%16s") , strMmsUsed ); strTemp+= strTemp2; } strTemp+=_T("\r\n"); } strTab += strTemp; } strTab+=_T(" ----------------------------------"); if ( bJCB ) { strTab+=_T("-------------------------------------------"); } strTab +=_T("\r\n\r\n\r\n"); } HGLOBAL hglbCopy; LPTSTR lptstrCopy; if (!OpenClipboard()) return ; EmptyClipboard(); hglbCopy = GlobalAlloc(GMEM_MOVEABLE, (strTab.GetLength()+1)*sizeof(TCHAR)); if (hglbCopy == NULL) { CloseClipboard(); return ; } lptstrCopy = (TCHAR *)GlobalLock(hglbCopy); _tcscpy(lptstrCopy,strTab); GlobalUnlock(hglbCopy); #ifdef _UNICODE ::SetClipboardData(CF_UNICODETEXT, hglbCopy); #else ::SetClipboardData(CF_TEXT, hglbCopy); #endif CloseClipboard(); return ; } void CTabDlg::Close_Agent() { //清除队列中的内容 while (!m_Agent.IsEmpty()) { ANS_Agent_NameData * pAgent = m_Agent.GetHead(); m_Agent.RemoveHead(); delete pAgent; } } void CTabDlg::Close_Corp() { //清除队列中的内容 while (!m_Corp.IsEmpty()) { ANS_Corp_NameData * pData = m_Corp.GetHead(); m_Corp.RemoveHead(); delete pData; } } void CTabDlg::QueryNext() { if ( m_lQueryCurCorpID>=m_L_Corp.GetCount()-1 ) //查询完毕 { long lItem=m_wndList.GetItemCount(); m_wndList.InsertItem(lItem,_T(""),0); m_wndList.InsertItem(lItem,_T("合计"),0); CString str; str.Format(_T("%d") , lSmsCount ); m_wndList.SetItemText(lItem,lSmsCountIndex,str); str.Format(_T("%d") , lMmsSmsCount ); m_wndList.SetItemText(lItem,lMmsSmsCountIndex,str); return; } m_lQueryCurCorpID ++ ; m_L_Corp.SetCurSel(m_lQueryCurCorpID); POSITION pos = (POSITION)m_L_Corp.GetItemData(m_lQueryCurCorpID); POSITION pos2 = pos; ANS_Corp_NameData * pData = m_Corp.GetNext( pos ); if (pData) { #ifndef SMSCENTER_NX if ( (m_lQueryAgentID == -11 && pData->lAgentID<=0 ) || (m_lQueryAgentID == -12 && pData->lAgentID>0 ) || (pData->lAgentID == m_lQueryAgentID )) #else if (true) #endif { REQ_Bill4 * pBill = new REQ_Bill4;memset(pBill,0,sizeof(REQ_Bill4)); pBill->lUserID = -1; //查询用户ID pBill->tBegin = m_tQueryBegin; pBill->tEnd = m_tQueryEnd; pBill->bJCB = m_bQueryJCB; pBill->lCorpID = pData->lCorpID; m_lCurCorpID = pData->lCorpID; m_strCurName = pData->szCorpName; m_pMainFrame->SendFrame(SMSFUNC_BILL4,(BYTE*)pBill,sizeof(REQ_Bill4)); } else { QueryNext(); } } else { return; } } void CTabDlg::OnTabQuery3() { CString strTemp; CString strFind; m_E_AgentID.GetWindowText(strFind); if ( strFind.GetLength()<=0 ) return ; long lSel = m_L_Agent.GetCurSel(); long lCount = m_L_Agent.GetCount(); for ( int i=lSel+1 ; i=0 ) { m_L_Agent.SetCurSel(i); //OnSelchangeUserAgent(); return ; } } for ( i=0 ; i=0 ) { m_L_Agent.SetCurSel(i); //OnSelchangeUserAgent(); return ; } } } void CTabDlg::OnTabQuery4() { UpdateData(true); if ( m_tEnd < m_tBegin ) { MessageBox( _T("查询结束日期不能小于起始日期,请改正!") , _T("错误") , MB_ICONWARNING ); return ; } m_wndList.DeleteAllItems(); m_wndList.DeleteAllColumns(); m_wndList.SetHeadings(_T("序号,50; 企业名称,250;业务员名称,80;代理商名称,180;回收日期,120;开通,60;创建日期,120;开通日期,120;")); REQ_ADCHTHS * pTab = new REQ_ADCHTHS;memset(pTab,0,sizeof(REQ_ADCHTHS)); m_tBegin.GetAsSystemTime( pTab->tBegin ); m_tEnd.GetAsSystemTime( pTab->tEnd ); m_pMainFrame->SendFrame(SMSFUNC_ADCHTHS,(BYTE*)pTab,sizeof(REQ_ADCHTHS)); } BOOL CTabDlg::ProcessSocket(Socket_Head_Add *pHead, BYTE *pFrame) { CString str; if ( pHead->lFuncType == SMSFUNC_BILL4 ) { ANS_Bill4 * pBill = (ANS_Bill4 *)pFrame; ANS_BillData4 * pData = (ANS_BillData4 *)(pFrame+sizeof(ANS_Bill4)); if ( pBill->lCount ==2 ) { long lItem = m_wndList.GetItemCount(); str.Format(_T("%d") , lItem+1); m_wndList.InsertItem(lItem,str,0); long lTemp=1; str.Format(_T("%d") , pBill->lCorpID); m_wndList.SetItemText(lItem,lTemp++,str); m_wndList.SetItemText(lItem,lTemp++,pBill->szCorpName); str.Format(_T("%d") , pData[0].lSendCount ); lSmsCount += pData[0].lSendCount; lSmsCountIndex = lTemp; m_wndList.SetItemText(lItem,lTemp++,str); if ( m_pMainFrame->GetUserPurview(PURVIEW_MANAGER_ADD,false) ) { str.Format(_T("%d") , pData[0].lSend ); lSendCountIndex = lTemp; m_wndList.SetItemText(lItem,lTemp++,str); str.Format(_T("%d") , pData[0].lReportSucess ); lReportSucessCountIndex = lTemp; m_wndList.SetItemText(lItem,lTemp++,str); str.Format(_T("%d") , pData[0].lReportFail ); lReportFailCountIndex = lTemp; m_wndList.SetItemText(lItem,lTemp++,str); str=_T("0.0%"); if ( pData[0].lReportFail >0 && pData[0].lSend>0 ) { str.Format( _T("%.1f%%") , ((float)pData[0].lReportFail/(float)pData[0].lSend)*100.0f); } lFailPerIndex = lTemp; m_wndList.SetItemText(lItem,lTemp++,str); } str.Format(_T("%d") , pData[1].lSendCount ); lMmsSmsCount += pData[1].lSendCount; lMmsSmsCountIndex = lTemp; m_wndList.SetItemText(lItem,lTemp++,str); if ( m_pMainFrame->GetUserPurview(PURVIEW_MANAGER_ADD,false) ) { str.Format(_T("%d") , pData[1].lSend ); lMmsSendCountIndex = lTemp; m_wndList.SetItemText(lItem,lTemp++,str); str.Format(_T("%d") , pData[1].lReportSucess ); lMmsReportSucessCountIndex = lTemp; m_wndList.SetItemText(lItem,lTemp++,str); str.Format(_T("%d") , pData[1].lReportFail ); lMmsReportFailCountIndex = lTemp; m_wndList.SetItemText(lItem,lTemp++,str); str=_T("0.0%"); if ( pData[1].lReportFail >0 && pData[1].lSend>0 ) { str.Format( _T("%.1f%%") , ((float)pData[1].lReportFail/(float)pData[1].lSend)*100.0f); } lMmsFailPerIndex = lTemp; m_wndList.SetItemText(lItem,lTemp++,str); } if ( pBill->bJCB ) { str.Format(_T("%d") , pData[0].jcb.lOldCount ); lOldIndex = lTemp; m_wndList.SetItemText(lItem,lTemp++,str); str.Format(_T("%d") , pData[0].jcb.lAddCount ); lAddIndex = lTemp; m_wndList.SetItemText(lItem,lTemp++,str); str.Format(_T("%d") , pData[0].jcb.lUseCount ); lUsedIndex = lTemp; m_wndList.SetItemText(lItem,lTemp++,str); str.Format(_T("%d") , pData[1].jcb.lOldCount ); lMmsOldIndex = lTemp; m_wndList.SetItemText(lItem,lTemp++,str); str.Format(_T("%d") , pData[1].jcb.lAddCount ); lMmsAddIndex = lTemp; m_wndList.SetItemText(lItem,lTemp++,str); str.Format(_T("%d") , pData[1].jcb.lUseCount ); lMmsUsedIndex = lTemp; m_wndList.SetItemText(lItem,lTemp++,str); } } if ( m_bQueryAll ) QueryNext(); return true; } return false; }