123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547 |
- // AnalogDlg.cpp : implementation file
- //
- #include "stdafx.h"
- #include "IDE.h"
- #include "DlgNoticeRec.h"
- #include "Syslib.h"
- #ifdef _DEBUG
- #define new DEBUG_NEW
- #undef THIS_FILE
- static char THIS_FILE[] = __FILE__;
- #endif
- /////////////////////////////////////////////////////////////////////////////
- // CDlgNoticeRec dialog
- CDlgNoticeRec::CDlgNoticeRec(CWnd* pParent /*=NULL*/)
- : CDialog(CDlgNoticeRec::IDD, pParent)
- {
- //{{AFX_DATA_INIT(CDlgNoticeRec)
- // NOTE: the ClassWizard will add member initialization here
- //}}AFX_DATA_INIT
- m_ctrlEmailRec.RegisterWindowClass(g_hLangDLL);
- m_ctrlTelRec.RegisterWindowClass(g_hLangDLL);
- m_ctrlSmsRec.RegisterWindowClass(g_hLangDLL);
- }
- void CDlgNoticeRec::DoDataExchange(CDataExchange* pDX)
- {
- CDialog::DoDataExchange(pDX);
- //{{AFX_DATA_MAP(CDlgNoticeRec)
- DDX_Control(pDX, IDC_GRID_REC, m_ctrlEmailRec);
- DDX_Control(pDX, IDC_GRID_REC2, m_ctrlTelRec);
- DDX_Control(pDX, IDC_GRID_REC3, m_ctrlSmsRec);
- //}}AFX_DATA_MAP
- DDX_Control(pDX, IDC_DT_START_DATE, m_ctrlStartDate);
- DDX_Control(pDX, IDC_DT_END_DATE, m_ctrlEndDate);
- DDX_Control(pDX, IDC_COMBO_DEV, m_ctrlDevName);
- DDX_Control(pDX, IDC_EDT_VAR_DESC, m_ctrlVarDesc);
- }
- BEGIN_MESSAGE_MAP(CDlgNoticeRec, CDialog)
- //{{AFX_MSG_MAP(CDlgNoticeRec)
- //}}AFX_MSG_MAP
- ON_BN_CLICKED(IDC_BTN_CLOSE, OnBnClickedBtnClose)
- ON_BN_CLICKED(IDC_BTN_QUERY, OnBnClickedBtnQuery)
- ON_BN_CLICKED(IDC_BTN_DEL, OnBnClickedBtnDel)
- ON_BN_CLICKED(IDC_BTN_EXPORT, OnBnClickedBtnExport)
- ON_BN_CLICKED(IDC_BTN_CLOSE2, OnBnClickedBtnClose2)
- ON_BN_CLICKED(IDC_BTN_CLOSE3, OnBnClickedBtnClose3)
- END_MESSAGE_MAP()
- /////////////////////////////////////////////////////////////////////////////
- // CDlgNoticeRec message handlers
- void CDlgNoticeRec::OnOK()
- {
- // TODO: Add extra validation here
-
- CDialog::OnOK();
- }
- void CDlgNoticeRec::OnCancel()
- {
- // TODO: Add extra cleanup here
-
- CDialog::OnCancel();
- }
- BOOL CDlgNoticeRec::OnInitDialog()
- {
- CDialog::OnInitDialog();
- m_btnQuery.SubclassDlgItem(IDC_BTN_QUERY, this);
- m_btnQuery.SetBitmaps(IDB_FRESH, RGB(255, 0, 255));
- m_btnQuery.SetFlat(FALSE);
- m_btnQuery.SetAlign(CButtonST::ST_ALIGN_HORIZ);
- m_btnExit.SubclassDlgItem(IDC_BTN_CLOSE, this);
- m_btnExit.SetBitmaps(IDB_EXIT , RGB(192, 192, 192));
- m_btnExit.SetFlat(FALSE);
- m_btnExit.SetAlign(CButtonST::ST_ALIGN_HORIZ);
- m_btnDel.SubclassDlgItem(IDC_BTN_DEL, this);
- m_btnDel.SetBitmaps(IDB_DEL , RGB(255,0 , 255));
- m_btnDel.SetFlat(FALSE);
- m_btnDel.SetAlign(CButtonST::ST_ALIGN_HORIZ);
- m_btnExport.SubclassDlgItem(IDC_BTN_EXPORT, this);
- m_btnExport.SetBitmaps(IDB_INTO, RGB(255, 0, 255));
- m_btnExport.SetFlat(FALSE);
- m_btnExport.SetAlign(CButtonST::ST_ALIGN_HORIZ);
- CTime tmToday; //今天的日期
- CTime tmPreTwoDay; //前两天的日期
- CTimeSpan tmspanTwoDay(1,0,0,0); //两天的时间距离
- tmToday=CTime::GetCurrentTime();//获得当前日期
- tmPreTwoDay=tmToday-tmspanTwoDay;
- UpdateData(TRUE);//时间更新为当前时间
-
- m_ctrlStartDate.SetFormat("yyyy-M-d HH:mm:ss");
- m_ctrlStartDate.SetTime( &tmPreTwoDay );
- m_ctrlEndDate.SetFormat("yyyy-M-d HH:mm:ss");
- m_ctrlEndDate.SetTime( &tmToday );
- bool bTel=false,bSms=false,bEmail=false;
- CDBInterface::GetInstancePtr()->JudgeIsTSE( bTel,bSms,bEmail );
- m_ctrlDevName.ResetContent();
-
- SetFields();
- if( bEmail )
- {
- m_ctrlDevName.AddString(g_strLogModEmail);
- RequeryEmail();
- }
- if( bTel )
- {
- m_ctrlDevName.AddString(g_strLogModNotice);
- if( !bEmail )
- RequeryTel();
- }
- if( bSms )
- {
- m_ctrlDevName.AddString(g_strLogModSms);
- if( !bEmail && !bTel )
- RequerySms();
- }
- //int nChannelSize = pDevicesManager->m_channels.GetSize();
- //for( int i = 0; i < nChannelSize; i++ )
- //{
- // int nDeviceSize = pDevicesManager->m_channels[i]->m_Devices.GetSize();
- // for( int j = 0; j < nDeviceSize; j++ )
- // {
- // m_ctrlDevName.AddString(pDevicesManager->m_channels[i]->m_Devices[j]->m_strName);
- // }
- //}
- m_ctrlDevName.SetCurSel(0);
-
- return TRUE; // return TRUE unless you set the focus to a control
- // EXCEPTION: OCX Property Pages should return FALSE
- }
- void CDlgNoticeRec::SetFields()
- {
- CRect rectFrame;
- this->GetWindowRect( rectFrame );ScreenToClient( &rectFrame );
- CRect rect;
- GetDlgItem( IDC_GRID_REC )->GetWindowRect( rect );ScreenToClient( &rect );
- rect.right = rectFrame.right-10;
- rect.bottom = rectFrame.bottom-10;
- GetDlgItem( IDC_GRID_REC )->MoveWindow( rect );
- GetDlgItem( IDC_GRID_REC2 )->MoveWindow( rect );
- GetDlgItem( IDC_GRID_REC3 )->MoveWindow( rect );
- int i;
- m_ctrlEmailRec.m_field.SetSize(4);
- i=0;
- m_ctrlEmailRec.m_field[i].Field=_T("id");
- m_ctrlEmailRec.m_field[i].Caption=_T("ID");
- m_ctrlEmailRec.m_field[i].With = 50;
- m_ctrlEmailRec.m_field[i].Find=true;
- i=1;
- m_ctrlEmailRec.m_field[i].Field=_T("emailaddr");
- m_ctrlEmailRec.m_field[i].Caption=g_strLogModEmail;
- m_ctrlEmailRec.m_field[i].With=150;
- m_ctrlEmailRec.m_field[i].Find=true;
- i=2;
- m_ctrlEmailRec.m_field[i].Field=_T("contents");
- m_ctrlEmailRec.m_field[i].Caption=g_strLogModContents;
- m_ctrlEmailRec.m_field[i].With=378;
- m_ctrlEmailRec.m_field[i].Find=true;
- i=3;
- m_ctrlEmailRec.m_field[i].Field=_T("sendtime");
- m_ctrlEmailRec.m_field[i].Caption=g_strLogModTime;
- m_ctrlEmailRec.m_field[i].With=200;
- m_ctrlEmailRec.m_field[i].Find=true;
- //电话记录
- m_ctrlTelRec.m_field.SetSize(4);
- i=0;
- m_ctrlTelRec.m_field[i].Field=_T("id");
- m_ctrlTelRec.m_field[i].Caption=_T("ID");
- m_ctrlTelRec.m_field[i].With = 50;
- m_ctrlTelRec.m_field[i].Find=true;
- i=1;
- m_ctrlTelRec.m_field[i].Field=_T("telnum");
- m_ctrlTelRec.m_field[i].Caption=g_strLogModNotice;
- m_ctrlTelRec.m_field[i].With=150;
- m_ctrlTelRec.m_field[i].Find=true;
- i=2;
- m_ctrlTelRec.m_field[i].Field=_T("contents");
- m_ctrlTelRec.m_field[i].Caption=g_strLogModContents;
- m_ctrlTelRec.m_field[i].With=378;
- m_ctrlTelRec.m_field[i].Find=true;
- i=3;
- m_ctrlTelRec.m_field[i].Field=_T("sendtime");
- m_ctrlTelRec.m_field[i].Caption=g_strLogModTime;
- m_ctrlTelRec.m_field[i].With=200;
- m_ctrlTelRec.m_field[i].Find=true;
- //短信记录
- m_ctrlSmsRec.m_field.SetSize(4);
- i=0;
- m_ctrlSmsRec.m_field[i].Field=_T("id");
- m_ctrlSmsRec.m_field[i].Caption=_T("ID");
- m_ctrlSmsRec.m_field[i].With = 50;
- m_ctrlSmsRec.m_field[i].Find=true;
- i=1;
- m_ctrlSmsRec.m_field[i].Field=_T("telnum");
- m_ctrlSmsRec.m_field[i].Caption=g_strLogModSms;
- m_ctrlSmsRec.m_field[i].With=150;
- m_ctrlSmsRec.m_field[i].Find=true;
- i=2;
- m_ctrlSmsRec.m_field[i].Field=_T("contents");
- m_ctrlSmsRec.m_field[i].Caption=g_strLogModContents;
- m_ctrlSmsRec.m_field[i].With=378;
- m_ctrlSmsRec.m_field[i].Find=true;
- i=3;
- m_ctrlSmsRec.m_field[i].Field=_T("sendtime");
- m_ctrlSmsRec.m_field[i].Caption=g_strLogModTime;
- m_ctrlSmsRec.m_field[i].With=200;
- m_ctrlSmsRec.m_field[i].Find=true;
- // m_ctrlAnalogGrid.Execute(m_pConnection,"ProductId"/*Primary key field */
- // ,"*"//fields in SELECT statment
- // ,"Products" //from
- // ,"" // where
- // ,0); // order by N of the Grid column
- }
- void CDlgNoticeRec::RequeryEmail()
- {
- CString strWhere;
- //strWhere.Format(" uid <> \'%s\'", "admin");
- CString strStartTime, strEndTime, strStartDate, strEndDate;
- CString strTelNum, strContent;
- CTime tmToday;
- CTime tmPreTwoDay;
- m_ctrlStartDate.GetTime( tmPreTwoDay );
- m_ctrlEndDate.GetTime( tmToday );
- strStartDate.Format( "%d-%d-%d %d:%d:%d", tmPreTwoDay.GetYear(), tmPreTwoDay.GetMonth(), tmPreTwoDay.GetDay(),
- tmPreTwoDay.GetHour(), tmPreTwoDay.GetMinute(), tmPreTwoDay.GetSecond() );
- strEndDate.Format( "%d-%d-%d %d:%d:%d", tmToday.GetYear(), tmToday.GetMonth(), tmToday.GetDay(),
- tmToday.GetHour(), tmToday.GetMinute(), tmToday.GetSecond() );
- strWhere = "sendtime >= '" + strStartDate + "' and sendtime <= '" + strEndDate + "'";
- //int nIndex = -1;
- ////nIndex = m_ctrlDevName.GetCurSel();
- CString strDevName, strVarDesc, strDevWhere, strVarWhere;
- //m_ctrlDevName.GetLBText(nIndex, strDevName);
- //if( nIndex!=0 )//if( strDevName.Compare(g_strAll) != 0 )
- //{
- // strDevWhere.Format(" and logtype = \'%d\'", 1);
- // strWhere += strDevWhere;
- //}
- m_ctrlEmailRec.Execute(_T("id")/*Primary key field */
- ,_T("*")//fields in SELECT statment
- ,_T("t_email_rec") //from
- ,strWhere // where
- ,0,0); // order by N of the Grid column
- }
- void CDlgNoticeRec::RequeryTel()
- {
- CString strWhere;
- //strWhere.Format(" uid <> \'%s\'", "admin");
- CString strStartTime, strEndTime, strStartDate, strEndDate;
- CString strTelNum, strContent;
- CTime tmToday;
- CTime tmPreTwoDay;
- m_ctrlStartDate.GetTime( tmPreTwoDay );
- m_ctrlEndDate.GetTime( tmToday );
- strStartDate.Format( "%d-%d-%d %d:%d:%d", tmPreTwoDay.GetYear(), tmPreTwoDay.GetMonth(), tmPreTwoDay.GetDay(),
- tmPreTwoDay.GetHour(), tmPreTwoDay.GetMinute(), tmPreTwoDay.GetSecond() );
- strEndDate.Format( "%d-%d-%d %d:%d:%d", tmToday.GetYear(), tmToday.GetMonth(), tmToday.GetDay(),
- tmToday.GetHour(), tmToday.GetMinute(), tmToday.GetSecond() );
- strWhere = "sendtime >= '" + strStartDate + "' and sendtime <= '" + strEndDate + "'";
- //int nIndex = -1;
- //nIndex = m_ctrlDevName.GetCurSel();
- CString strDevName, strVarDesc, strDevWhere, strVarWhere;
- //m_ctrlDevName.GetLBText(nIndex, strDevName);
- //if( nIndex!=0 )//if( strDevName.Compare(g_strAll) != 0 )
- //{
- // strDevWhere.Format(" and logtype = \'%d\'", 2);
- // strWhere += strDevWhere;
- //}
- m_ctrlTelRec.Execute(_T("id")/*Primary key field */
- ,_T("*")//fields in SELECT statment
- ,_T("t_notice_rec") //from
- ,strWhere // where
- ,0,0); // order by N of the Grid column
- }
- void CDlgNoticeRec::RequerySms()
- {
- CString strWhere;
- //strWhere.Format(" uid <> \'%s\'", "admin");
- CString strStartTime, strEndTime, strStartDate, strEndDate;
- CString strTelNum, strContent;
- CTime tmToday;
- CTime tmPreTwoDay;
- m_ctrlStartDate.GetTime( tmPreTwoDay );
- m_ctrlEndDate.GetTime( tmToday );
- strStartDate.Format( "%d-%d-%d %d:%d:%d", tmPreTwoDay.GetYear(), tmPreTwoDay.GetMonth(), tmPreTwoDay.GetDay(),
- tmPreTwoDay.GetHour(), tmPreTwoDay.GetMinute(), tmPreTwoDay.GetSecond() );
- strEndDate.Format( "%d-%d-%d %d:%d:%d", tmToday.GetYear(), tmToday.GetMonth(), tmToday.GetDay(),
- tmToday.GetHour(), tmToday.GetMinute(), tmToday.GetSecond() );
- strWhere = "sendtime >= '" + strStartDate + "' and sendtime <= '" + strEndDate + "'";
- //int nIndex = -1;
- //nIndex = m_ctrlDevName.GetCurSel();
- CString strDevName, strVarDesc, strDevWhere, strVarWhere;
- //m_ctrlDevName.GetLBText(nIndex, strDevName);
- //if( nIndex!=0 )//if( strDevName.Compare(g_strAll) != 0 )
- //{
- // strDevWhere.Format(" and logtype = \'%d\'", 3);
- // strWhere += strDevWhere;
- //}
- m_ctrlSmsRec.Execute(_T("id")/*Primary key field */
- ,_T("*")//fields in SELECT statment
- ,_T("t_sms_rec") //from
- ,strWhere // where
- ,0,0); // order by N of the Grid column
- }
- BOOL CDlgNoticeRec::OnNotify(WPARAM wParam, LPARAM lParam, LRESULT* pResult)
- {
- LPNMHDR pNmhdr = (LPNMHDR)lParam;
- // TODO: 在此添加专用代码和/或调用基类
- if (wParam == (WPARAM)m_ctrlEmailRec.GetDlgCtrlID())
- {
- *pResult = 1;
- GV_DISPINFO *pDispInfo = (GV_DISPINFO*)lParam;
- m_ctrlEmailRec.SetValue(pDispInfo);
- }
- if (wParam == (WPARAM)m_ctrlTelRec.GetDlgCtrlID())
- {
- *pResult = 1;
- GV_DISPINFO *pDispInfo = (GV_DISPINFO*)lParam;
- m_ctrlTelRec.SetValue(pDispInfo);
- }
- if (wParam == (WPARAM)m_ctrlSmsRec.GetDlgCtrlID())
- {
- *pResult = 1;
- GV_DISPINFO *pDispInfo = (GV_DISPINFO*)lParam;
- m_ctrlSmsRec.SetValue(pDispInfo);
- }
- return CDialog::OnNotify(wParam, lParam, pResult);
- }
- BEGIN_EVENTSINK_MAP(CDlgNoticeRec, CDialog)
- //{{AFX_EVENTSINK_MAP(CDlgNoticeRec)
- //}}AFX_EVENTSINK_MAP
- END_EVENTSINK_MAP()
- void CDlgNoticeRec::OnBnClickedBtnClose()
- {
- // TODO: 在此添加控件通知处理程序代码
- OnCancel();
- }
- void CDlgNoticeRec::OnBnClickedBtnQuery()
- {
- // TODO: 在此添加控件通知处理程序代码
- UpdateData();
- int nIndex = -1;
- nIndex = m_ctrlDevName.GetCurSel();
- if( nIndex==-1 )
- return;
- CString sLBText;
- m_ctrlDevName.GetLBText( nIndex,sLBText );
- if( sLBText==g_strLogModEmail )
- {
- GetDlgItem( IDC_GRID_REC )->ShowWindow( SW_SHOW );
- GetDlgItem( IDC_GRID_REC2 )->ShowWindow( SW_HIDE );
- GetDlgItem( IDC_GRID_REC3 )->ShowWindow( SW_HIDE );
- RequeryEmail();
- }
- else if( sLBText==g_strLogModNotice )
- {
- GetDlgItem( IDC_GRID_REC )->ShowWindow( SW_HIDE );
- GetDlgItem( IDC_GRID_REC2 )->ShowWindow( SW_SHOW );
- GetDlgItem( IDC_GRID_REC3 )->ShowWindow( SW_HIDE );
- RequeryTel();
- }
- else if( sLBText==g_strLogModSms )
- {
- GetDlgItem( IDC_GRID_REC )->ShowWindow( SW_HIDE );
- GetDlgItem( IDC_GRID_REC2 )->ShowWindow( SW_HIDE );
- GetDlgItem( IDC_GRID_REC3 )->ShowWindow( SW_SHOW );
- RequerySms();
- }
- }
- void CDlgNoticeRec::OnBnClickedBtnDel()
- {
- UpdateData();
- int nIndex = -1;
- nIndex = m_ctrlDevName.GetCurSel();
- if( nIndex==-1 )
- return;
- CString sLBText;
- m_ctrlDevName.GetLBText( nIndex,sLBText );
- //Email记录 电话记录 短信记录
- if( sLBText==g_strLogModEmail )
- {
- int nCount = m_ctrlEmailRec.GetRowCount();
- CString sID;
-
- if( nCount>0 )
- if (MessageBox (g_strMsgConfirmDelRecord, g_strMsgPrompt, MB_YESNO|MB_DEFBUTTON2 | MB_ICONQUESTION) != IDYES)
- return;
- for( int nRow=0;nRow<nCount;nRow++ )
- {
- sID = m_ctrlEmailRec.GetCell( nRow, 0 )->GetText();
- CDBInterface::GetInstancePtr()->DelTableData( "t_email_rec","id",(char *)(LPCTSTR)sID,2 );
- }
- m_ctrlEmailRec.DeleteAllItems();
- RequeryEmail();
- }
- else if( sLBText==g_strLogModNotice )
- {
- int nCount = m_ctrlTelRec.GetRowCount();
- CString sID;
-
- if( nCount>0 )
- if (MessageBox (g_strMsgConfirmDelRecord, g_strMsgPrompt, MB_YESNO|MB_DEFBUTTON2 | MB_ICONQUESTION) != IDYES)
- return;
- for( int nRow=0;nRow<nCount;nRow++ )
- {
- sID = m_ctrlTelRec.GetCell( nRow, 0 )->GetText();
- CDBInterface::GetInstancePtr()->DelTableData( "t_notice_rec","id",(char *)(LPCTSTR)sID,2 );
- }
- m_ctrlTelRec.DeleteAllItems();
- RequeryTel();
- }
- else if( sLBText==g_strLogModSms )
- {
- int nCount = m_ctrlSmsRec.GetRowCount();
- CString sID;
-
- if( nCount>0 )
- if (MessageBox (g_strMsgConfirmDelRecord, g_strMsgPrompt, MB_YESNO|MB_DEFBUTTON2 | MB_ICONQUESTION) != IDYES)
- return;
- for( int nRow=0;nRow<nCount;nRow++ )
- {
- sID = m_ctrlSmsRec.GetCell( nRow, 0 )->GetText();
- CDBInterface::GetInstancePtr()->DelTableData( "t_sms_rec","id",(char *)(LPCTSTR)sID,2 );
- }
- m_ctrlSmsRec.DeleteAllItems();
- RequerySms();
- }
- }
- void CDlgNoticeRec::OnBnClickedBtnExport()
- {
- // TODO: 在此添加控件通知处理程序代码
- int nIndex = -1;
- nIndex = m_ctrlDevName.GetCurSel();
- if( nIndex==-1 )
- return;
- CString sLBText;
- m_ctrlDevName.GetLBText( nIndex,sLBText );
- //Email记录 电话记录 短信记录
- if( sLBText==g_strLogModEmail )
- {
- ExportListToExcel( (CDataGrid*)&m_ctrlEmailRec, "邮件通知记录" );
- }
- else if( sLBText==g_strLogModNotice )
- {
- ExportListToExcel( (CDataGrid*)&m_ctrlTelRec, "语音通知记录" );
- }
- else if( sLBText==g_strLogModSms )
- {
- ExportListToExcel( (CDataGrid*)&m_ctrlSmsRec, "短信通知记录" );
- }
- //CString strFileName;
- //strFileName.Format("%s\\%s", g_strDirectory, "data.csv");
- //m_ctrlGridRec.Save(strFileName);
- }
- void CDlgNoticeRec::OnBnClickedBtnClose2()
- {
- // TODO: 在此添加控件通知处理程序代码
- //if( !pDevicesManager->Connection(g_strServerIP, g_strServerPort) )
- //{
- // pDevicesManager->SetSocketStatus(FALSE);
- //}
- //else
- //{
- // pDevicesManager->SetSocketStatus(TRUE);
- //}
- }
- void CDlgNoticeRec::OnBnClickedBtnClose3()
- {
- // TODO: 在此添加控件通知处理程序代码
- //pDevicesManager->DisConnection();
- }
|