// TakeFrom.cpp : implementation file // #include "stdafx.h" #include "ylgl.h" #include "TakeFrom.h" #include "MyMdi.H" #include "ModifyDinDan.h" #include "InputPsw.h" #include "ImportPhoto.h" #include "ShowPic.h" #include "TakeMoney2.h" #include "SelWaiter2.h" #include "TakeStautsSel.h" #include "SalaryRateSet2.h" #include "UploadPhoto.h" #ifdef _DEBUG #define new DEBUG_NEW #undef THIS_FILE static char THIS_FILE[] = __FILE__; #endif #pragma comment(lib, "Shlwapi.lib") ///////////////////////////////////////////////////////////////////////////// // TakeFrom IMPLEMENT_DYNCREATE(TakeFrom, MyFormView) TakeFrom::TakeFrom() : MyFormView(TakeFrom::IDD) { //{{AFX_DATA_INIT(TakeFrom) m_filter = _T(""); m_nAdd=0; //}}AFX_DATA_INIT if(g_bAllBranch) { m_nAdd=1; } } TakeFrom::~TakeFrom() { } void TakeFrom::DoDataExchange(CDataExchange* pDX) { MyFormView::DoDataExchange(pDX); //{{AFX_DATA_MAP(TakeFrom) DDX_Control(pDX, IDC_COMBO1, m_combo1); DDX_Control(pDX, IDC_LIST2, m_List1); DDX_Control(pDX, IDC_STATIC1, m_static1); DDX_CBString(pDX, IDC_COMBO1, m_filter); //}}AFX_DATA_MAP } BEGIN_MESSAGE_MAP(TakeFrom, MyFormView) //{{AFX_MSG_MAP(TakeFrom) ON_BN_CLICKED(IDC_BUTclose, OnBUTclose) ON_BN_CLICKED(IDC_BUTTON1, OnButton1) ON_CBN_SELCHANGE(IDC_COMBO1, OnSelchangeCombo1) ON_WM_TIMER() ON_BN_CLICKED(IDC_BUTimportphoto, OnBUTimportphoto) ON_BN_CLICKED(IDC_BUTshowphoto, OnBUTshowphoto) ON_BN_CLICKED(IDC_BUTmoney, OnBUTmoney) ON_BN_CLICKED(IDC_BTNaddsp, OnBTNaddsp) ON_NOTIFY(LVN_ITEMCHANGED, IDC_LIST2, OnItemchangedList2) ON_BN_CLICKED(IDC_BUTTON2, OnButton2) ON_NOTIFY(NM_CLICK, IDC_LIST2, OnClickList2) ON_NOTIFY(NM_DBLCLK, IDC_LIST2, OnDblclkList2) ON_BN_CLICKED(IDC_BTNSEARCHFILTER, OnBtnsearchfilter) ON_BN_CLICKED(IDC_BUTprint3, OnBUTprint3) //}}AFX_MSG_MAP END_MESSAGE_MAP() ///////////////////////////////////////////////////////////////////////////// // TakeFrom diagnostics #ifdef _DEBUG void TakeFrom::AssertValid() const { MyFormView::AssertValid(); } void TakeFrom::Dump(CDumpContext& dc) const { MyFormView::Dump(dc); } #endif //_DEBUG ///////////////////////////////////////////////////////////////////////////// // TakeFrom message handlers void TakeFrom::OnInitialUpdate() { //AfxMessageBox("789"); MyFormView::OnInitialUpdate(); // TODO: Add your specialized code here and/or call the base class CMyMdi Mdi; Mdi.SetSubView((CWnd*)GetParent(), (CWnd*)this); #ifdef LYFZ_VERSION GetDlgItem(IDC_BUTimportphoto)->ShowWindow(0); #endif // Here we create the outbar control using the splitter as its parent // and setting its id to the first pane. CRect rc2; GetWindowRect(rc2); ::MoveWindow(m_hWnd,g_rc.left,g_rc.top,g_rc.Width(),g_rc.Height(),TRUE); EnumChildWindows(m_hWnd,(WNDENUMPROC)EnumChildProc,0); int idarray[]={IDC_BUTprint3,IDC_BUTimportphoto,IDC_BUTshowphoto,IDC_BUTTON2,IDC_BUTclose}; int idcount=5; int btnwid; CRect prerc; for(int a=idcount-2; a>=0; a--) { GetDlgItem(idarray[a+1])->GetWindowRect (prerc); ScreenToClient(prerc); GetDlgItem(idarray[a])->GetWindowRect (rc2); ScreenToClient(rc2); btnwid=rc2.Width (); rc2.right =prerc.left ; rc2.left =rc2.right -btnwid; GetDlgItem(idarray[a])->MoveWindow (rc2); } m_static1.SetFont (&g_titlefont); if(g_bAllBranch==0) { #ifdef CHILD_VERSION #ifdef LKAY_VERSION m_List1.SetHeadings("订单号,100;家长姓名,100;宝宝姓名,100;起始编号,100;景点,100;拍照,100;导片日期,100;摄影师,100;助理,100;化妆师,100;助理,100;接单人,100;套系名称,100;套系价格,100;手机,100;固定电话,100" ); #else m_List1.SetHeadings("订单号,100;家长姓名,100;宝宝姓名,100;起始编号,100;景点,100;拍照,100;拍照日期,100;摄影师,100;助理,100;化妆师,100;助理,100;接单人,100;套系名称,100;套系价格,100;手机,100;固定电话,100" ); #endif #else m_List1.SetHeadings("订单号,100;男宾姓名,100;女宾姓名,100;起始编号,100;景点,100;拍照,100;拍照日期,100;摄影师,100;助理,100;化妆师,100;助理,100;接单人,100;套系名称,100;套系价格,100;男宾电话,100;女宾电话,100" ); #endif m_List1.LoadColumnInfo (114); } else { #ifdef CHILD_VERSION m_List1.SetHeadings("店名,100;订单号,100;家长姓名,100;宝宝姓名,100;起始编号,100;景点,100;拍照,100;拍照日期,100;摄影师,100;助理,100;化妆师,100;助理,100;接单人,100;套系名称,100;套系价格,100;手机,100;固定电话,100" ); #else m_List1.SetHeadings("店名,100;订单号,100;男宾姓名,100;女宾姓名,100;起始编号,100;景点,100;拍照,100;拍照日期,100;摄影师,100;助理,100;化妆师,100;助理,100;接单人,100;套系名称,100;套系价格,100;男宾电话,100;女宾电话,100" ); #endif m_List1.LoadColumnInfo (196); GetDlgItem(IDC_BUTprint3)->ShowWindow (1); } m_List1.m_bSortSupport=0; GetData(); m_combo1.AddString (g_user.name); m_combo1.GetWindowRect (rc2); ScreenToClient(rc2); rc2.bottom +=200; m_combo1.MoveWindow (rc2); GetDlgItem(IDC_BUTclose)->GetWindowRect(rc2); SetComboHei(&m_combo1, rc2.Height ()); } void TakeFrom::FillGrid(BOOL bStatus/*=0*/) { if(g_bSearchFilter) //.按条件查询; { m_List1.DeleteAllItems2(); int ii=0; m_List1.m_arLabels.SetSize( m_List1array.GetSize(), 1 ); int count=0; { BOOL bFinded=0; for(ii=0; iig_filterdate2) { bFinded=0; continue; } } if(g_waiter1!="") // Jeff.查询过滤条件:摄影师; { if(m_List1array.ElementAt (ii).ElementAt (11+m_nAdd)!=g_waiter1) { bFinded=0; continue; } } if(g_waiter2!="") // Jeff.查询过滤条件:选片人; { if(m_List1array.ElementAt (ii).ElementAt (7+m_nAdd)!=g_waiter2) { bFinded=0; continue; } } if(g_waiter3!="") // Jeff.查询过滤条件:化妆师; { if(m_List1array.ElementAt (ii).ElementAt (9+m_nAdd)!=g_waiter3) { bFinded=0; continue; } } if(g_bAllBranch && g_filterbranch!="") // Jeff.集团版查询过滤条件:分店名称; { if(m_List1array.ElementAt (ii).ElementAt (0)!= g_filterbranch) { bFinded=0; continue; } } if(1) { m_List1.m_arLabels.ElementAt (count++).Copy (m_List1array.ElementAt (ii)); bFinded=1; } } } m_List1.m_arLabels.SetSize(count, 1); ii=count; m_List1.m_LabelCount=ii; m_List1.SetItemCountEx (ii); CString str; str.Format ("单数:%d", ii); SetDlgItemText(IDC_STATIC2, str); } else { m_List1.DeleteAllItems2(); int ii=0; m_List1.m_arLabels.SetSize( m_List1array.GetSize(), 1 ); int count=0; if(m_filter.IsEmpty()) { if(bStatus==1) { BOOL bFinded=0; for(ii=0; iiSendMessage(WM_CLOSE); } void TakeFrom::OnSelchangeCombo1() { // TODO: Add your control notification handler code here SetTimer(1, 100, NULL); } void TakeFrom::OnTimer(UINT nIDEvent) { // TODO: Add your message handler code here and/or call default KillTimer(nIDEvent); OnButton1(); } BOOL TakeFrom::PreTranslateMessage(MSG* pMsg) { // TODO: Add your specialized code here and/or call the base class try { if(pMsg->message==WM_KEYDOWN) { switch (pMsg->wParam) { case VK_RETURN: OnButton1(); return 1; case 0x43: // copy if ( ( GetKeyState( VK_CONTROL ) & 0x80 ) ) { GetFocus()->SendMessage(WM_COPY); return TRUE; } break; case 0x56: //Ctrl + V: if ( ( GetKeyState( VK_CONTROL ) & 0x80 ) ) { GetFocus()->SendMessage(WM_PASTE); return TRUE; } break; case 0x58: // cut if ( ( GetKeyState( VK_CONTROL ) & 0x80 ) ) { GetFocus()->SendMessage(WM_CUT); return TRUE; } break; case 0x5A: //undo case 0x59: //redo if ( ( GetKeyState( VK_CONTROL ) & 0x80 ) ) { GetFocus()->SendMessage(WM_UNDO); return TRUE; } break; } } return MyFormView::PreTranslateMessage(pMsg); } catch(...) { } } // Jeff.remark. // 1.弹出"拍照状态确认"对话框前,需要获取订单的拍照状态,以此来确定是否需要禁用check状态框; // // void TakeFrom::OnBUTimportphoto() // 导入原片; { // TODO: Add your control notification handler code here POSITION pos; pos=m_List1.GetFirstSelectedItemPosition(); if(pos==NULL) { AfxMessageBox("请先选中您要导片的定单!", MB_ICONINFORMATION); return; } // 1.选中的起始行号; int iItem=m_List1.GetNextSelectedItem(pos); // 2.选中的行数; int itemcount=m_List1.GetItemCount(); int iItemBak=iItem; CString status2="OK"; CString branch; CString id=m_List1.GetItemText(iItem, 0+m_nAdd); // .OrderNumber订单号; int beginno=atoi(m_List1.GetItemText(iItem, 3+m_nAdd)); // .Jeff.起始编号究竟有什么用? if(g_bAllBranch) branch=m_List1.GetItemText (iItem, 0); // Jeff.多景点时,选择了不是第一个景点,订单是空的; while(id=="") { iItem--; id=m_List1.GetItemText(iItem, 0+m_nAdd); beginno=atoi(m_List1.GetItemText(iItem, 3+m_nAdd)); } int nTopItem = iItem;// Jeff add:记录第一个有订单号的项; //int nNotOkItem = -1; // Jeff add:第一个被记录未拍照ok的子景点项;如果是头景点呢? // .jdpos景点位置;并不能用来判断该订单是否多个景点,因为如果iItem是有订单号的话,无效; int jdpos = iItemBak-iItem; // .订单拍摄如果不是ok状态,设置为拍摄中; BOOL bOK = TRUE; //Jeff.add; #if 0 if(iItemBak != iItem) // .多景点,头景点; { #if 0 // 有下面的while,就不需要这里的判断; if(m_List1.GetItemText(iItem, 5+m_nAdd) != "OK") // Jeff.why not:if(m_List1.GetItemText(iItemBak, 5+m_nAdd) != "OK") 下面处理了iItem++. status2 = "拍摄中"; // .Jeff add:当有两个景点时,防止下面while循环出现少处理尾数的问题; if ( m_List1.GetItemText(iItemBak,5+m_nAdd) != "OK") status2 = "拍摄中"; #endif //BOOL bOK = TRUE;//放到外面去; // Jeff.有订单号的第一个景点. if(m_List1.GetItemText(iItem, 5+m_nAdd) != "OK") { status2 = "拍摄中"; bOK = FALSE; } // Jeff.无订单号的子景点处理; while( m_List1.GetItemText(++iItem, 0 + m_nAdd) == "" && iItem < itemcount) { if(m_List1.GetItemText (iItem, 5+m_nAdd) != "OK") { status2="拍摄中"; bOK = FALSE; break; } } if ( bOK ) status2 = "OK"; // printf("Jeff:多个景点,拍照状态=%s\n\n",status2); } else // Jeff add:当只有一个景点时,因为下面的while循环不处理只有一个景点的情况; { if ( m_List1.GetItemText(iItemBak,5+m_nAdd) != "OK") { status2 = "拍摄中"; bOK = FALSE; } else status2 = "OK"; // printf("Jeff:只有一个景点,拍照状态=%s\n\n",status2); } #endif #if 1 // Jeff.用于判断是否只剩下一个 未OK 状态时,拍照确认对话框的复选是否需要勾上; // 此时iItem为有订单号的头景点; if ( m_List1.GetItemText(iItem,5+m_nAdd) != "OK") { status2 = "拍摄中"; //bOK = FALSE; } // .子景点(如果有的话); ++iItem; while(iItemOnDisconnect(); g_branchname=branch; g_bBranchModify=1; g_pMainWnd->ProcessChatMessageRequest2(sql); g_pMainWnd->OnDisconnect(); g_bBranchModify=0; g_branchip=g_branchname=""; } else g_pMainWnd->ProcessChatMessageRequest2(sql); if(g_bSendOK==0)return; if(g_bAllBranch==0) { GetData(); } else { BOOL bFind=0; for(int i=0; i'OK' then '" +g_date+"' else [time2] end" + " where [id]='"+id+"'"; else if(jdpos==1) sql+="***update dindan set [status]=case when [status]<>'OK' then '"+status2+"' else [status] end,[waiter12]='"+waiter1+"',[waiter22]='"+waiter2+"',[curno]='"+sbeginno+ "', [time2]=case when [status]<>'OK' then '" +g_date+"' else [time2] end" + " where [id]='"+id+"'"; else if(jdpos==2) sql+="***update dindan set [status]=case when [status]<>'OK' then '"+status2+"' else [status] end,[waiter13]='"+waiter1+"',[waiter23]='"+waiter2+"',[curno]='"+sbeginno+ "', [time2]=case when [status]<>'OK' then '" +g_date+"' else [time2] end" + " where [id]='"+id+"'"; else if(jdpos==3) sql+="***update dindan set [status]=case when [status]<>'OK' then '"+status2+"' else [status] end,[waiter14]='"+waiter1+"',[waiter24]='"+waiter2+"',[curno]='"+sbeginno+ "', [time2]=case when [status]<>'OK' then '" +g_date+"' else [time2] end" + " where [id]='"+id+"'"; else sql+="***update dindan set [status]=case when [status]<>'OK' then '"+status2+"' else [status] end,[curno]='"+sbeginno+"' where [id]='"+id+"'"; // printf("Jeff:拍照中,SQL=%s\n\n",sql); } else // ==ok时,才记录拍照时间; { /*if(jdpos==0) sql+="***update dindan set [status]='"+status2+"',[waiter1]='"+waiter1+"',[waiter2]='"+waiter2+"',[curno]='"+sbeginno+ "', [time2]=case when isnull([time2],'')='' then '" +g_date+"' else [time2] end" + " where [id]='"+id+"'"; else if(jdpos==1) sql+="***update dindan set [status]='"+status2+"',[waiter12]='"+waiter1+"',[waiter22]='"+waiter2+"',[curno]='"+sbeginno+ "', [time2]=case when isnull([time2],'')='' then '" +g_date+"' else [time2] end" +" where [id]='"+id+"'"; else if(jdpos==2) sql+="***update dindan set [status]='"+status2+"',[waiter13]='"+waiter1+"',[waiter23]='"+waiter2+"',[curno]='"+sbeginno+ "', [time2]=case when isnull([time2],'')='' then '" +g_date+"' else [time2] end" + " where [id]='"+id+"'"; else if(jdpos==3) sql+="***update dindan set [status]='"+status2+"',[waiter14]='"+waiter1+"',[waiter24]='"+waiter2+"',[curno]='"+sbeginno+ "', [time2]=case when isnull([time2],'')='' then '" +g_date+"' else [time2] end" + " where [id]='"+id+"'"; else sql+="***update dindan set [status]='"+status2+"',[curno]='"+sbeginno+ "', [time2]=case when isnull([time2],'')='' then '" +g_date+"' else [time2] end" + " where [id]='"+id+"'";*/ // 当数据库原本status为OK时,不可修改时间;否则可以修改时间; if(jdpos==0) sql+="***update dindan set [status]='"+status2+"',[waiter1]='"+waiter1+"',[waiter2]='"+waiter2+"',[curno]='"+sbeginno+ "', [time2]=case when [status]<>'OK' then '" +g_date+"' else [time2] end" + " where [id]='"+id+"'"; else if(jdpos==1) sql+="***update dindan set [status]='"+status2+"',[waiter12]='"+waiter1+"',[waiter22]='"+waiter2+"',[curno]='"+sbeginno+ "', [time2]=case when [status]<>'OK' then '" +g_date+"' else [time2] end" +" where [id]='"+id+"'"; else if(jdpos==2) sql+="***update dindan set [status]='"+status2+"',[waiter13]='"+waiter1+"',[waiter23]='"+waiter2+"',[curno]='"+sbeginno+ "', [time2]=case when [status]<>'OK' then '" +g_date+"' else [time2] end" + " where [id]='"+id+"'"; else if(jdpos==3) sql+="***update dindan set [status]='"+status2+"',[waiter14]='"+waiter1+"',[waiter24]='"+waiter2+"',[curno]='"+sbeginno+ "', [time2]=case when [status]<>'OK' then '" +g_date+"' else [time2] end" + " where [id]='"+id+"'"; else sql+="***update dindan set [status]='"+status2+"',[curno]='"+sbeginno+ "', [time2]=case when isnull([time2],'')='' then '" +g_date+"' else [time2] end" + " where [id]='"+id+"'"; // printf("Jeff:拍照OK,SQL=%s\n\n",sql); } #endif #endif ///////////////////////// CString m_name1=m_List1.GetItemText (iItem, 1+m_nAdd); CString m_name2=m_List1.GetItemText (iItem, 2+m_nAdd); CString m_phone1=m_List1.GetItemText (iItem, 14+m_nAdd); CString m_phone2=m_List1.GetItemText (iItem, 15+m_nAdd); if(g_bAllBranch) { for(int i=0; iOnDisconnect(); g_branchname=branch; g_bBranchModify=1; g_pMainWnd->ProcessChatMessageRequest2(sql); g_pMainWnd->OnDisconnect(); g_bBranchModify=0; g_branchip=g_branchname=""; } else g_pMainWnd->ProcessChatMessageRequest2(sql); if(g_bSendOK==0)return; AfxMessageBox("导入客照成功!", MB_ICONINFORMATION); if(g_bAllBranch==0) { GetData(); } else { BOOL bFind=0; for(int i=0; iIsCtrlDown ()==0 && g_pMainWnd->IsShiftDown ()==0 && dindanjd!="") { if(AfxMessageBox("是否查看全部景点?", MB_YESNO|MB_ICONINFORMATION)!=IDYES) { if(dindanjd=="系统默认景点") { if(::PathFileExists (dlg.m_path+dindanjd)) { dlg.m_path+=dindanjd; dlg.m_path +="\\"; } } else { dlg.m_path+=dindanjd; dlg.m_path +="\\"; } } } else if(g_pMainWnd->IsCtrlDown ()) { if(dindanjd=="系统默认景点") { if(::PathFileExists (dlg.m_path+dindanjd)) { dlg.m_path+=dindanjd; dlg.m_path +="\\"; } } else { dlg.m_path+=dindanjd; dlg.m_path +="\\"; } } dlg.DoModal (); if(dlg.m_bdelall) { for(int i=0; iEnableWindow(1); } else GetDlgItem(IDC_BUTimportphoto)->EnableWindow(0); *pResult = 0; } void TakeFrom::OnButton1() { // TODO: Add your control notification handler code here UpdateData(); m_filter.TrimLeft (); m_filter.TrimRight (); FillGrid(); } void TakeFrom::OnClickList2(NMHDR* pNMHDR, LRESULT* pResult) { // TODO: Add your control notification handler code here POSITION pos; pos=m_List1.GetFirstSelectedItemPosition(); if(pos==NULL)return; int iItem=m_List1.GetNextSelectedItem(pos); g_id = m_List1.GetItemText (iItem, 0+m_nAdd); while(g_id=="") { iItem--; g_id=m_List1.GetItemText (iItem, 0+m_nAdd); } *pResult = 0; } void TakeFrom::OnDblclkList2(NMHDR* pNMHDR, LRESULT* pResult) { // TODO: Add your control notification handler code here OnBUTshowphoto(); *pResult = 0; } void TakeFrom::HidePrice() { int i = 0; m_List1arrayBak.RemoveAll (); m_List1arrayBak.SetSize(m_List1array.GetSize ()); for(i=0; i< m_List1array.GetSize (); i++) { m_List1arrayBak.ElementAt (i).Copy (m_List1array.ElementAt (i)); } #ifdef LKAY_VERSION if(IsHasRights2new(31))return; for( i=0; iProcessChatMessageRequest2(filter); if(g_bSendOK==0)return; } else { g_sendhead.bsql=0; g_sendhead.code[0]=25; // Jeff.case 25对应的表为takeview视图:订单景点表; g_sendhead.tabcount=1; #ifdef LKAY_VERSION CString filter="dindantype<>'意向客户' or dindantype is null"; g_pMainWnd->ProcessChatMessageRequest2(filter); #else g_pMainWnd->ProcessChatMessageRequest2(1); #endif if(g_bSendOK==0)return; } DataToArray(&m_List1array); } else { //////////////数据汇总 m_List1array.RemoveAll(); CString branch; for(int i=-1; iOnDisconnect(); g_branchname=branch; g_bBranchModify=1; } else branch=g_brancharray.ElementAt(g_brancharray.GetSize()-1).ElementAt(0); if(g_bShowOK==0) { CString filter="status3='未取'"; g_sendhead.bsql=0; g_sendhead.code[0]=25; // Jeff.case 25对应的表为takeview视图:订单景点表; g_sendhead.tabcount=1; g_pMainWnd->ProcessChatMessageRequest2(filter); if(g_bSendOK==0) continue; } else { g_sendhead.bsql=0; g_sendhead.code[0]=25; // Jeff.case 25对应的表为takeview视图:订单景点表; g_sendhead.tabcount=1; g_pMainWnd->ProcessChatMessageRequest2(1); if(g_bSendOK==0) continue; } CArrayList1array; DataToArray(&List1array); int size=m_List1array.GetSize (); for(int j=0; jOnDisconnect(); g_bBranchModify=0; g_branchip=g_branchname=""; } HidePrice(); FillGrid(); }