StaffInfo.cpp 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032
  1. // StaffInfo.cpp : 实现文件
  2. //
  3. #include "stdafx.h"
  4. #include "YLGL.h"
  5. #include "StaffInfo.h"
  6. #include "DlgAnnex.h"
  7. // 生成表对应的Insert宏;
  8. #define INSERT_renyuan _T("INSERT INTO [renyuan](\
  9. id,\
  10. staff_department,\
  11. staff_name,\
  12. staff_gender,\
  13. staff_phone,\
  14. staff_family_address,\
  15. staff_base_pay,\
  16. staff_citizen_id_number,\
  17. staff_married,\
  18. staff_dimission,\
  19. staff_fingerprinted1,\
  20. staff_fingerprinted2,\
  21. staff_self_phone,\
  22. staff_father,\
  23. staff_mother,\
  24. staff_father_phone,\
  25. staff_mother_phone,\
  26. staff_emergency_name,\
  27. staff_emergency_phone,\
  28. staff_emergency_relationship,\
  29. staff_hire_date,\
  30. staff_leave_date,\
  31. staff_self_qq,\
  32. staff_self_weixin,\
  33. staff_self_email,\
  34. staff_educational,\
  35. staff_native_place,\
  36. staff_birthday,\
  37. staff_graduate_institutions,\
  38. staff_note,\
  39. staff_qq,\
  40. staff_trial_work_date,\
  41. staff_position\
  42. )VALUES(\
  43. '%s',\
  44. '%s',\
  45. '%s',\
  46. '%s',\
  47. '%s',\
  48. '%s',\
  49. '%s',\
  50. '%s',\
  51. '%s',\
  52. '%s',\
  53. '%s',\
  54. '%s',\
  55. '%s',\
  56. '%s',\
  57. '%s',\
  58. '%s',\
  59. '%s',\
  60. '%s',\
  61. '%s',\
  62. '%s',\
  63. '%s',\
  64. '%s',\
  65. '%s',\
  66. '%s',\
  67. '%s',\
  68. '%s',\
  69. '%s',\
  70. '%s',\
  71. '%s',\
  72. '%s',\
  73. '%s',\
  74. '%s',\
  75. '%s'\
  76. )")
  77. #define UPDATE_renyuan _T("UPDATE [renyuan]\
  78. SET [staff_department] = '%s'\
  79. ,[staff_name] = '%s'\
  80. ,[staff_gender] = '%s'\
  81. ,[staff_phone] = '%s'\
  82. ,[staff_family_address] = '%s'\
  83. ,[staff_base_pay] = '%s'\
  84. ,[staff_citizen_id_number] = '%s'\
  85. ,[staff_married] = '%s'\
  86. ,[staff_dimission] = '%s'\
  87. ,[staff_fingerprinted1] = '%s'\
  88. ,[staff_fingerprinted2] = '%s'\
  89. ,[staff_self_phone] = '%s'\
  90. ,[staff_father] = '%s'\
  91. ,[staff_mother] = '%s'\
  92. ,[staff_father_phone] = '%s'\
  93. ,[staff_mother_phone] = '%s'\
  94. ,[staff_emergency_name] = '%s'\
  95. ,[staff_emergency_phone] = '%s'\
  96. ,[staff_emergency_relationship] = '%s'\
  97. ,[staff_hire_date] = '%s'\
  98. ,[staff_leave_date] = '%s'\
  99. ,[staff_self_qq] = '%s'\
  100. ,[staff_self_weixin] = '%s'\
  101. ,[staff_self_email] = '%s'\
  102. ,[staff_educational] = '%s'\
  103. ,[staff_native_place] = '%s'\
  104. ,[staff_birthday] = '%s'\
  105. ,[staff_graduate_institutions] = '%s'\
  106. ,[staff_note] = '%s' \
  107. ,[staff_qq] ='%s'\
  108. ,[staff_trial_work_date] ='%s' \
  109. ,[staff_position] = '%s'\
  110. WHERE id='%s'\
  111. ")
  112. // CStaffInfo 对话框
  113. IMPLEMENT_DYNAMIC(CStaffInfo, CDialog)
  114. CStaffInfo::CStaffInfo(CWnd* pParent /*=NULL*/)
  115. : CDialog(CStaffInfo::IDD, pParent)
  116. , m_staff_id(_T(""))
  117. , m_staff_name(_T(""))
  118. , m_staff_native_place(_T(""))
  119. , m_staff_self_phone(_T(""))
  120. , m_staff_phone(_T(""))
  121. , m_staff_self_qq(_T(""))
  122. , m_staff_self_wx(_T(""))
  123. , m_staff_self_email(_T(""))
  124. , m_staff_father(_T(""))
  125. , m_staff_mother(_T(""))
  126. , m_staff_mother_phone(_T(""))
  127. , m_staff_family_address(_T(""))
  128. , m_staff_emer_name(_T(""))
  129. , m_staff_emer_phone(_T(""))
  130. , m_staff_emer_relationship(_T(""))
  131. , m_staff_educational(_T(""))
  132. , m_staff_graduate_institutions(_T(""))
  133. , m_staff_citizen_id_number(_T(""))
  134. , m_staff_hire_date(_T(""))
  135. , m_staff_leave_date(_T(""))
  136. , m_staff_fingerprinted1(_T(""))
  137. , m_staff_fingerprinted2(_T(""))
  138. , m_staff_note(_T(""))
  139. , m_staff_birthday(_T(""))
  140. , m_staff_qq(_T(""))
  141. , m_staff_trial_work_date(_T(""))
  142. , m_staff_position(_T(""))
  143. {
  144. }
  145. CStaffInfo::~CStaffInfo()
  146. {
  147. }
  148. void CStaffInfo::DoDataExchange(CDataExchange* pDX)
  149. {
  150. CDialog::DoDataExchange(pDX);
  151. DDX_Control(pDX, LIST_STAFF, m_list);
  152. DDX_Control(pDX, CBOX_DEPT, m_cbox_dept);
  153. DDX_Control(pDX, CBOX_CREDENTIALS, m_cbox_credentials);
  154. DDX_Text(pDX, TX_STAFF_ID, m_staff_id);
  155. DDX_Text(pDX, TX_STAFF_NAME, m_staff_name);
  156. DDX_Text(pDX, TX_NATIVE_PLACE, m_staff_native_place);
  157. DDX_Text(pDX, TX_SELF_PHONE, m_staff_self_phone);
  158. DDX_Text(pDX, TX_STAFF_PHONE, m_staff_phone);
  159. DDX_Text(pDX, TX_SELF_QQ, m_staff_self_qq);
  160. DDX_Text(pDX, TX_SELF_WX, m_staff_self_wx);
  161. DDX_Text(pDX, TX_SELF_EMAIL, m_staff_self_email);
  162. DDX_Text(pDX, TX_FATHER_NAME, m_staff_father);
  163. DDX_Text(pDX, TX_FATHER_PHONE, m_staff_father_phone);
  164. DDX_Text(pDX, TX_MOTHER_NAME, m_staff_mother);
  165. DDX_Text(pDX, TX_MOTHER_PHONE, m_staff_mother_phone);
  166. DDX_Text(pDX, TX_FAMILY_ADDRESS, m_staff_family_address);
  167. DDX_Text(pDX, TX_EMER_NAME, m_staff_emer_name);
  168. DDX_Text(pDX, TX_EMER_PHONE, m_staff_emer_phone);
  169. DDX_Text(pDX, TX_EMER_RELATIONSHIP, m_staff_emer_relationship);
  170. DDX_Text(pDX, TX_EDUCATIONAL, m_staff_educational);
  171. DDX_Text(pDX, TX_GRADUATE_INSTITUTIONS, m_staff_graduate_institutions);
  172. DDX_Text(pDX, TX_CITIZEN_ID_NUMBER, m_staff_citizen_id_number);
  173. DDX_Text(pDX, TX_HIRE_DATE, m_staff_hire_date);
  174. DDX_Text(pDX, TX_LEAVE_DATE, m_staff_leave_date);
  175. DDX_Text(pDX, TX_FINGERPRINTED1, m_staff_fingerprinted1);
  176. DDX_Text(pDX, TX_FINGERPRINTED2, m_staff_fingerprinted2);
  177. DDX_Text(pDX, TX_NOTE, m_staff_note);
  178. DDX_Control(pDX, CBOX_GENDER, m_cbox_gender);
  179. DDX_Control(pDX, CBOX_MARRIED, m_cbox_married);
  180. DDX_Control(pDX, CBOX_DIMISSION, m_cbox_dimisson);
  181. DDX_Control(pDX, BTN_ADD_STAFF, m_btn_add_staff);
  182. DDX_Control(pDX, BTN_UPLOAD_IMAGE, m_btn_upload_image);
  183. //DDX_Control(pDX, BTN_DELETE_IMAGE, m_btn_delete_image);
  184. DDX_Text(pDX, TX_BIRTHDAY, m_staff_birthday);
  185. DDX_Text(pDX, TX_QQ, m_staff_qq);
  186. DDX_Text(pDX, TX_TRIAL_WORK, m_staff_trial_work_date);
  187. DDX_Text(pDX, TX_POSITION, m_staff_position);
  188. }
  189. BEGIN_MESSAGE_MAP(CStaffInfo, CDialog)
  190. ON_WM_CTLCOLOR()
  191. ON_NOTIFY(NM_CLICK, LIST_STAFF, &CStaffInfo::OnNMClickStaff)
  192. ON_BN_CLICKED(BTN_DELETE_STAFF, &CStaffInfo::OnBnClickedDeleteStaff)
  193. ON_BN_CLICKED(BTN_UPLOAD_IMAGE, &CStaffInfo::OnBnClickedUploadImage)
  194. //ON_BN_CLICKED(BTN_DELETE_IMAGE, &CStaffInfo::OnBnClickedDeleteImage)
  195. ON_BN_CLICKED(BTN_ADD_STAFF, &CStaffInfo::OnBnClickedAddStaff)
  196. ON_CBN_SELCHANGE(CBOX_CREDENTIALS, &CStaffInfo::OnCbnSelchangeCredentials)
  197. ON_WM_SYSCOMMAND()
  198. ON_BN_CLICKED(BTN_LOOK_IMAGE, &CStaffInfo::OnBnClickedLookImage)
  199. END_MESSAGE_MAP()
  200. // CStaffInfo 消息处理程序
  201. BOOL CStaffInfo::OnInitDialog()
  202. {
  203. CDialog::OnInitDialog();
  204. // 将对话框移动到指定显示位置;
  205. MoveWindow(&g_rc);
  206. CRect rcWnd;
  207. GetWindowRect(rcWnd);
  208. CRect rcList;
  209. m_list.GetWindowRect(rcList);
  210. rcList.right = rcWnd.right - 20;
  211. rcList.bottom = rcWnd.bottom - 15;
  212. ScreenToClient(rcList);
  213. m_list.MoveWindow(rcList);
  214. // 初始化其他控件列表;
  215. m_cbox_credentials.AddString(_T("身份证照"));
  216. m_cbox_credentials.AddString(_T("毕业证照"));
  217. m_cbox_credentials.AddString(_T("用工合同照"));
  218. m_cbox_credentials.AddString(_T("其他证件照"));
  219. m_list.SetHeadings(
  220. _T("编号, 60"),
  221. _T("姓名, 60"),
  222. _T("部门, 60"),
  223. _T("性别, 60"),
  224. _T("个人电话, 60"),
  225. _T("分配电话, 60"),
  226. _T("籍贯,60"),
  227. _T("学历,60"),
  228. _T("紧急联系人,60"),
  229. _T("紧急联系电话,60"),
  230. NULL);
  231. GetDepartment();
  232. GetStaffInfo();
  233. return TRUE; // return TRUE unless you set the focus to a control
  234. // 异常: OCX 属性页应返回 FALSE
  235. }
  236. void CStaffInfo::OnOK()
  237. {
  238. // 判断必填属性;
  239. if ( m_cbox_dept.GetCurSel() == -1 ) {
  240. MessageBox(_T("未选择部门"));
  241. return;
  242. }
  243. if ( m_cbox_gender.GetCurSel() == -1 ) {
  244. MessageBox(_T("未选择性别"));
  245. return;
  246. }
  247. if ( m_cbox_gender.GetCurSel() == -1 ) {
  248. MessageBox(_T("未选择婚否"));
  249. return;
  250. }
  251. if ( m_cbox_gender.GetCurSel() == -1 ) {
  252. MessageBox(_T("未选择是否在职"));
  253. return;
  254. }
  255. UpdateData(TRUE);
  256. if ( m_staff_id.IsEmpty() ) {
  257. MessageBox(_T("员工编号必填!"));
  258. return;
  259. }
  260. if ( m_staff_name.IsEmpty() ) {
  261. MessageBox(_T("员工姓名必填!"));
  262. return;
  263. }
  264. if ( m_staff_native_place.IsEmpty() ) {
  265. MessageBox(_T("员工籍贯必填!"));
  266. return;
  267. }
  268. if ( m_staff_self_phone.IsEmpty() ) {
  269. MessageBox(_T("员工个人电话必填!"));
  270. return;
  271. }
  272. if ( m_staff_self_qq.IsEmpty() ) {
  273. MessageBox(_T("员工个人QQ必填!"));
  274. return;
  275. }
  276. /*if ( m_staff_self_email.IsEmpty() ) {
  277. MessageBox(_T("员工个人邮箱必填!"));
  278. return;
  279. }*/
  280. if ( m_staff_family_address.IsEmpty() ) {
  281. MessageBox(_T("员工家庭住址必填!"));
  282. return;
  283. }
  284. if ( m_staff_emer_name.IsEmpty() ) {
  285. MessageBox(_T("员工紧急联系人姓名必填!"));
  286. return;
  287. }
  288. if ( m_staff_emer_phone.IsEmpty() ) {
  289. MessageBox(_T("员工紧急联系人电话必填!"));
  290. return;
  291. }
  292. if ( m_staff_emer_relationship.IsEmpty() ) {
  293. MessageBox(_T("员工紧急联系人关系必填!"));
  294. return;
  295. }
  296. if ( m_staff_educational.IsEmpty() ) {
  297. MessageBox(_T("员工学历必填!"));
  298. return;
  299. }
  300. if ( m_staff_graduate_institutions.IsEmpty() ) {
  301. MessageBox(_T("员工毕业院校必填!"));
  302. return;
  303. }
  304. if ( m_staff_trial_work_date.IsEmpty() ) {
  305. MessageBox(_T("员工试工日期必填!"));
  306. return;
  307. }
  308. if ( m_staff_citizen_id_number.IsEmpty() ) {
  309. MessageBox(_T("员工身份证号必填!"));
  310. return;
  311. }
  312. if ( m_staff_hire_date.IsEmpty() ) {
  313. MessageBox(_T("员工入职时间必填!"));
  314. return;
  315. }
  316. if ( m_staff_birthday.IsEmpty() ) {
  317. MessageBox(_T("员工生日必填!"));
  318. return;
  319. }
  320. if ( m_staff_fingerprinted1.IsEmpty() && m_staff_fingerprinted2.IsEmpty()) {
  321. MessageBox(_T("员工指纹必填,请录入其中一个!"));
  322. return;
  323. }
  324. //////////////////////////////////////////////////////////////////////////
  325. // 新增或修改;
  326. CString strSQL;
  327. CString staff_department;
  328. m_cbox_dept.GetLBText(m_cbox_dept.GetCurSel(), staff_department);
  329. CString staff_gender;
  330. m_cbox_gender.GetLBText(m_cbox_gender.GetCurSel(), staff_gender);
  331. CString staff_married;
  332. m_cbox_married.GetLBText(m_cbox_married.GetCurSel(), staff_married);
  333. CString staff_dimission;
  334. m_cbox_dimisson.GetLBText(m_cbox_dimisson.GetCurSel(), staff_dimission);
  335. if ( m_staff_old_id.IsEmpty() )
  336. {// 未单击过列表, 新增员工信息;
  337. if ( IsExistStaff(strSQL) ) {// 存在唯一信息;
  338. MessageBox(strSQL);
  339. return;
  340. }
  341. // 消除空格;
  342. m_staff_phone.Trim();
  343. m_staff_self_phone.Trim();
  344. m_staff_citizen_id_number.Trim();
  345. strSQL.Format(INSERT_renyuan,
  346. m_staff_id,
  347. staff_department,
  348. m_staff_name,
  349. staff_gender,
  350. m_staff_phone,
  351. m_staff_family_address,
  352. _T(""),
  353. m_staff_citizen_id_number,
  354. staff_married,
  355. staff_dimission,
  356. m_staff_fingerprinted1,
  357. m_staff_fingerprinted2,
  358. m_staff_self_phone,
  359. m_staff_father,
  360. m_staff_mother,
  361. m_staff_father_phone,
  362. m_staff_mother_phone,
  363. m_staff_emer_name,
  364. m_staff_emer_phone,
  365. m_staff_emer_relationship,
  366. m_staff_hire_date,
  367. m_staff_leave_date,
  368. m_staff_self_qq,
  369. m_staff_self_wx,
  370. m_staff_self_email,
  371. m_staff_educational,
  372. m_staff_native_place,
  373. m_staff_birthday,
  374. m_staff_graduate_institutions,
  375. m_staff_note ,
  376. m_staff_qq,
  377. m_staff_trial_work_date,
  378. m_staff_position
  379. );
  380. }
  381. else
  382. {// 修改员工信息 ;
  383. if (IsExistStaffInfo(m_staff_id, strSQL) ) {
  384. MessageBox(strSQL);
  385. return;
  386. }
  387. strSQL.Format(UPDATE_renyuan,
  388. staff_department,
  389. m_staff_name,
  390. staff_gender,
  391. m_staff_phone,
  392. m_staff_family_address,
  393. _T(""),
  394. m_staff_citizen_id_number,
  395. staff_married,
  396. staff_dimission,
  397. m_staff_fingerprinted1,
  398. m_staff_fingerprinted2,
  399. m_staff_self_phone,
  400. m_staff_father,
  401. m_staff_mother,
  402. m_staff_father_phone,
  403. m_staff_mother_phone,
  404. m_staff_emer_name,
  405. m_staff_emer_phone,
  406. m_staff_emer_relationship,
  407. m_staff_hire_date,
  408. m_staff_leave_date,
  409. m_staff_self_qq,
  410. m_staff_self_wx,
  411. m_staff_self_email,
  412. m_staff_educational,
  413. m_staff_native_place,
  414. m_staff_birthday,
  415. m_staff_graduate_institutions,
  416. m_staff_note ,
  417. m_staff_qq,
  418. m_staff_trial_work_date,
  419. m_staff_position,
  420. m_staff_id
  421. );
  422. }
  423. g_sendhead.bsql = 1;
  424. g_pMainWnd->ProcessChatMessageRequest2(strSQL);
  425. if (g_bSendOK == 0)
  426. return;
  427. // 刷新列表;
  428. GetStaffInfo();
  429. }
  430. void CStaffInfo::OnCancel()
  431. {
  432. // TODO: 在此添加专用代码和/或调用基类
  433. CDialog::OnCancel();
  434. }
  435. void CStaffInfo::GetDepartment()
  436. {
  437. // 从服务器获取部门信息;
  438. g_sendhead.bsql = 0;
  439. g_sendhead.code[0] = 3;
  440. g_sendhead.tabcount = 1;
  441. g_pMainWnd->ProcessChatMessageRequest2(3);
  442. if (g_bSendOK == 0)return;
  443. CArray<CStringArray, CStringArray> AryDepartment;
  444. DataToArray(&AryDepartment);
  445. // 初始化CBOX_DEPT控件;
  446. for (int i = 0; i < AryDepartment.GetSize(); i++ )
  447. {
  448. m_cbox_dept.AddString(DAL::Case_3_GetDepartment(AryDepartment,i));
  449. }
  450. }
  451. void CStaffInfo::GetStaffInfo()
  452. {
  453. g_sendhead.bsql = 0;
  454. g_sendhead.code[0] = 234;
  455. g_sendhead.tabcount = 1;
  456. g_pMainWnd->ProcessChatMessageRequest2(1);
  457. if (g_bSendOK == 0)
  458. return;
  459. DataToArray(&m_AryStaff);
  460. m_list.m_AryList.RemoveAll();
  461. m_list.DeleteAllItems();
  462. m_list.m_AryList.SetSize(m_AryStaff.GetSize());
  463. for (int i = 0; i < m_AryStaff.GetSize(); i++)
  464. {
  465. m_list.m_AryList.ElementAt(i).RemoveAll();
  466. m_list.m_AryList.ElementAt(i).Add(DAL::Case_234_GetStaffId(m_AryStaff,i));
  467. m_list.m_AryList.ElementAt(i).Add(DAL::Case_234_GetStaffName(m_AryStaff,i));
  468. m_list.m_AryList.ElementAt(i).Add(DAL::Case_234_GetStaffDept(m_AryStaff,i));
  469. m_list.m_AryList.ElementAt(i).Add(DAL::Case_234_GetStaffGender(m_AryStaff,i));
  470. m_list.m_AryList.ElementAt(i).Add(DAL::Case_234_GetStaffSelfPhone(m_AryStaff,i));
  471. m_list.m_AryList.ElementAt(i).Add(DAL::Case_234_GetStaffPhone(m_AryStaff,i));
  472. m_list.m_AryList.ElementAt(i).Add(DAL::Case_234_GetStaffNativePlace(m_AryStaff,i));
  473. m_list.m_AryList.ElementAt(i).Add(DAL::Case_234_GetStaffEducational(m_AryStaff,i));
  474. m_list.m_AryList.ElementAt(i).Add(DAL::Case_234_GetStaffEmerName(m_AryStaff,i));
  475. m_list.m_AryList.ElementAt(i).Add(DAL::Case_234_GetStaffEmerPone(m_AryStaff,i));
  476. }
  477. m_list.SetItemCountEx(m_list.m_AryList.GetSize());
  478. }
  479. void CStaffInfo::FillList()
  480. {
  481. }
  482. HBRUSH CStaffInfo::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor)
  483. {
  484. HBRUSH hbr = CDialog::OnCtlColor(pDC, pWnd, nCtlColor);
  485. // TODO: 在此更改 DC 的任何属性
  486. switch(nCtlColor)
  487. {
  488. case CTLCOLOR_DLG:
  489. {
  490. return CreateSolidBrush(g_clr_dlg);
  491. }
  492. break;
  493. case CTLCOLOR_BTN:
  494. break;
  495. case CTLCOLOR_STATIC:
  496. {
  497. pDC->SetBkMode(TRANSPARENT);
  498. return CreateSolidBrush(g_clr_dlg);
  499. }
  500. break;
  501. }
  502. // TODO: 如果默认的不是所需画笔,则返回另一个画笔
  503. return hbr;
  504. }
  505. void CStaffInfo::ReSetCtrl()
  506. {
  507. m_staff_id = _T("");
  508. m_staff_old_id = _T("");
  509. m_staff_name = _T("");
  510. m_staff_old_name = _T("");
  511. m_staff_native_place = _T("");
  512. m_staff_self_phone = _T("");
  513. m_staff_phone = _T("");
  514. m_staff_self_qq = _T("");
  515. m_staff_self_wx = _T("");
  516. m_staff_self_email = _T("");
  517. m_staff_father = _T("");
  518. m_staff_father_phone = _T("");
  519. m_staff_mother = _T("");
  520. m_staff_mother_phone = _T("");
  521. m_staff_family_address = _T("");
  522. m_staff_emer_name = _T("");
  523. m_staff_emer_phone = _T("");
  524. m_staff_emer_relationship = _T("");
  525. m_staff_educational = _T("");
  526. m_staff_graduate_institutions = _T("");
  527. m_staff_citizen_id_number = _T("");
  528. m_staff_hire_date = _T("");
  529. m_staff_leave_date = _T("");
  530. m_staff_fingerprinted1 = _T("");
  531. m_staff_fingerprinted2 = _T("");
  532. m_staff_note = _T("");
  533. m_staff_position = _T("");
  534. UpdateData(FALSE);
  535. // 清除相片;
  536. // 清除下拉框选择;
  537. m_cbox_dept.SetCurSel(-1);
  538. m_cbox_gender.SetCurSel(-1);
  539. m_cbox_married.SetCurSel(-1);
  540. m_cbox_dimisson.SetCurSel(-1);
  541. m_cbox_credentials.SetCurSel(-1);
  542. // 禁用上传,下载相片;
  543. GetDlgItem(BTN_UPLOAD_IMAGE)->EnableWindow(FALSE);
  544. //GetDlgItem(BTN_DELETE_IMAGE)->EnableWindow(FALSE);
  545. ((CEdit*)GetDlgItem(TX_STAFF_ID))->SetReadOnly(FALSE);
  546. }
  547. void CStaffInfo::OnNMClickStaff(NMHDR *pNMHDR, LRESULT *pResult)
  548. {
  549. LPNMITEMACTIVATE pNMItemActivate = reinterpret_cast<LPNMITEMACTIVATE>(pNMHDR);
  550. // TODO: 在此添加控件通知处理程序代码
  551. if ( pNMItemActivate->iItem == -1 )
  552. {
  553. ReSetCtrl();
  554. return;
  555. }
  556. m_staff_old_id = m_list.GetItemText(pNMItemActivate->iItem, 0);
  557. m_staff_old_name = m_list.GetItemText(pNMItemActivate->iItem, 1);
  558. for (int i = 0; i < m_AryStaff.GetSize(); i++ )
  559. {
  560. if ( DAL::Case_234_GetStaffId(m_AryStaff, i) == m_staff_old_id )
  561. {
  562. // 启用上传,下载按钮;
  563. GetDlgItem(BTN_UPLOAD_IMAGE)->EnableWindow(TRUE);
  564. //GetDlgItem(BTN_DELETE_IMAGE)->EnableWindow(TRUE);
  565. m_staff_id = m_staff_old_id;
  566. m_staff_name = m_staff_old_name;
  567. m_cbox_gender.SelectString(0,DAL::Case_234_GetStaffGender(m_AryStaff,i));
  568. m_cbox_dept.SelectString(0,DAL::Case_234_GetStaffDept(m_AryStaff,i));
  569. m_staff_native_place = DAL::Case_234_GetStaffNativePlace(m_AryStaff,i);
  570. m_staff_self_phone = DAL::Case_234_GetStaffSelfPhone(m_AryStaff,i);
  571. m_staff_phone = DAL::Case_234_GetStaffPhone(m_AryStaff,i);
  572. m_staff_self_qq = DAL::Case_234_GetStaffSelfQQ(m_AryStaff,i);
  573. m_staff_self_wx = DAL::Case_234_GetStaffSelfWX(m_AryStaff,i);
  574. m_staff_self_email = DAL::Case_234_GetStaffSelfEmail(m_AryStaff,i);
  575. m_staff_father = DAL::Case_234_GetStaffFather(m_AryStaff,i);
  576. m_staff_father_phone= DAL::Case_234_GetStaffFatherPhone(m_AryStaff,i);
  577. m_staff_mother = DAL::Case_234_GetStaffMother(m_AryStaff,i);
  578. m_staff_mother_phone= DAL::Case_234_GetStaffMotherPhone(m_AryStaff,i);
  579. m_staff_family_address= DAL::Case_234_GetStaffFamilyAddress(m_AryStaff,i);
  580. m_staff_emer_name= DAL::Case_234_GetStaffEmerName(m_AryStaff,i);
  581. m_staff_emer_phone= DAL::Case_234_GetStaffEmerPone(m_AryStaff,i);
  582. m_staff_emer_relationship= DAL::Case_234_GetStaffEmerRelationShip(m_AryStaff,i);
  583. m_staff_educational = DAL::Case_234_GetStaffEducational(m_AryStaff,i);
  584. m_staff_graduate_institutions= DAL::Case_234_GetStaffGraduateInstitutions(m_AryStaff,i);
  585. m_staff_citizen_id_number = DAL::Case_234_GetStaffCitizenIdNumber(m_AryStaff,i);
  586. m_staff_hire_date= DAL::Case_234_GetStaffHireDate(m_AryStaff,i);
  587. m_staff_leave_date= DAL::Case_234_GetStaffLeaveDate(m_AryStaff,i);
  588. m_staff_birthday= DAL::Case_234_GetStaffBirthday(m_AryStaff,i);
  589. m_cbox_married.SelectString(0,DAL::Case_234_GetStaffMarried(m_AryStaff,i));
  590. m_staff_fingerprinted1= DAL::Case_234_GetStaffFingerprinted1(m_AryStaff,i);
  591. m_staff_fingerprinted2= DAL::Case_234_GetStaffFingerprinted2(m_AryStaff,i);
  592. m_cbox_dimisson.SelectString(0, DAL::Case_234_GetStaffDimission(m_AryStaff,i));
  593. m_staff_note = DAL::Case_234_GetStaffNote(m_AryStaff,i);
  594. m_staff_position = DAL::Case_234_GetStaffPosition(m_AryStaff,i);
  595. m_staff_trial_work_date = DAL::Case_234_GetStaffTrialWorkDate(m_AryStaff,i);
  596. ((CEdit*)GetDlgItem(TX_STAFF_ID))->SetReadOnly(TRUE);
  597. UpdateData(false);
  598. }
  599. }
  600. *pResult = 0;
  601. }
  602. void CStaffInfo::OnBnClickedDeleteStaff() // 删除员工;
  603. {
  604. POSITION pos = m_list.GetFirstSelectedItemPosition();
  605. if ( pos == NULL )
  606. {
  607. return;
  608. }
  609. if ( MessageBox(_T("确认删除该员工资料吗?"),_T("删除员工"), MB_YESNO | MB_ICONWARNING ) != IDYES )
  610. return;
  611. if ( m_staff_id.IsEmpty() )
  612. {
  613. MessageBox(_T("员工id空"));
  614. return;
  615. }
  616. CString strSQL;
  617. strSQL.Format(_T("delete from renyuan where id = '%s'"), m_staff_id);
  618. g_sendhead.bsql = true;
  619. g_pMainWnd->ProcessChatMessageRequest2(strSQL);
  620. if (g_bSendOK == 0)
  621. return;
  622. // 重新获取员工信息;
  623. GetStaffInfo();
  624. }
  625. void CStaffInfo::OnBnClickedUploadImage() // 上传相片;
  626. {
  627. if ( m_cbox_credentials.GetCurSel() == CB_ERR)
  628. {
  629. MessageBox(_T("请选择要上传的相片类型"));
  630. return;
  631. }
  632. // 相片名称;
  633. CString strImageName;
  634. // 相片类型;
  635. CString strImageType ;
  636. m_cbox_credentials.GetLBText(m_cbox_credentials.GetCurSel(), strImageType);
  637. UpdateData();
  638. CFileDialog fdlg(true, NULL, "", OFN_HIDEREADONLY, "jpg files(*jpg)|*.jpg||");
  639. if (fdlg.DoModal() != IDOK)
  640. return;
  641. // 相片名称:带后缀;
  642. strImageName = fdlg.GetFileName();
  643. CString path = fdlg.GetPathName();
  644. CFile fp;
  645. if (!fp.Open(path, CFile::modeRead))
  646. {
  647. AfxMessageBox(_T("文件打开失败!"));
  648. return;
  649. }
  650. DWORD length = fp.GetLength();
  651. if (length > 1024 * 200)
  652. {
  653. AfxMessageBox(_T("文件太大,请上传小于200K的图片!"));
  654. fp.Close();
  655. return;
  656. }
  657. DWORD dwSendLen = length + m_staff_id.GetLength() + m_staff_citizen_id_number.GetLength() + strImageType.GetLength() + strImageName.GetLength() +5*sizeof(DWORD);
  658. BYTE *pSendData = new BYTE[dwSendLen];
  659. // 相片大小;
  660. memcpy(pSendData, &length, sizeof(DWORD));
  661. // 相片内容;
  662. fp.Read(pSendData + sizeof(DWORD), length);
  663. fp.Close();
  664. // 员工编号;
  665. DWORD dwLen = m_staff_id.GetLength();
  666. memcpy(pSendData + length + sizeof(DWORD), &dwLen, sizeof(DWORD));
  667. memcpy(pSendData + length + 2*sizeof(DWORD), m_staff_id.GetString(), dwLen);
  668. // 员工身份证号;
  669. DWORD dwLen1 = m_staff_citizen_id_number.GetLength();
  670. memcpy(pSendData + length + 2*sizeof(DWORD) + dwLen, &dwLen1, sizeof(DWORD));
  671. memcpy(pSendData + length + 3*sizeof(DWORD) + dwLen, m_staff_citizen_id_number.GetString(), dwLen1);
  672. // 相片类型;
  673. DWORD dwLen2 = strImageType.GetLength();
  674. memcpy(pSendData + length + 3*sizeof(DWORD) + dwLen + dwLen1, &dwLen2, sizeof(DWORD));
  675. memcpy(pSendData + length + 4*sizeof(DWORD) + dwLen + dwLen1, strImageType.GetString(), dwLen2);
  676. // 相片名称;
  677. DWORD dwLen3 = strImageName.GetLength();
  678. memcpy(pSendData + length + 4*sizeof(DWORD) + dwLen + dwLen1 + dwLen2, &dwLen3, sizeof(DWORD));
  679. memcpy(pSendData + length + 5*sizeof(DWORD) + dwLen + dwLen1 + dwLen2, strImageName.GetString(), dwLen3);
  680. g_nSendCode = 26;
  681. g_pMainWnd->ProcessChatMessageRequest2(pSendData, dwSendLen);
  682. g_nSendCode = 0;
  683. delete[]pSendData;
  684. if (g_bSendOK == 0)
  685. {
  686. return;
  687. }
  688. AfxMessageBox("上传成功!");
  689. }
  690. void CStaffInfo::OnBnClickedDeleteImage() // 删除相片;
  691. {
  692. }
  693. void CStaffInfo::OnBnClickedAddStaff() // 添加员工;
  694. {
  695. ReSetCtrl();
  696. // 自动生成id;
  697. int nIndex = 0;
  698. int nMaxId = 0;
  699. for (int i = 0; i < m_AryStaff.GetSize(); i++)
  700. {
  701. nIndex = _tstoi(DAL::Case_234_GetStaffId(m_AryStaff, i));
  702. if ( nMaxId < nIndex)
  703. nMaxId = nIndex;
  704. }
  705. m_staff_id.Format(_T("%03d"), ++nMaxId);
  706. UpdateData(FALSE);
  707. }
  708. void CStaffInfo::OnCbnSelchangeCredentials() // 选择要显示或上传,下载的证件照;
  709. {
  710. // TODO: 在此添加控件通知处理程序代码
  711. }
  712. BOOL CStaffInfo::IsExistStaff(CString &strMsg)
  713. {
  714. // 员工id, 员工身份证号, 员工个人电话, 员工个人QQ, 员工个人邮箱是否有相同的;
  715. // CString strStaffId, strStaffCitizenIdNumber, strStaffSelfPhone, strStaffSelfQQ, strStaffSelfEmail;
  716. UpdateData(TRUE);
  717. BOOL bExist = FALSE;
  718. for ( int i = 0; i < m_AryStaff.GetSize(); i++ )
  719. {
  720. if ( DAL::Case_234_GetStaffId(m_AryStaff, i) == m_staff_id )
  721. {
  722. bExist = TRUE;
  723. strMsg = _T("员工编号存在");
  724. break;
  725. }
  726. if ( DAL::Case_234_GetStaffCitizenIdNumber(m_AryStaff, i) == m_staff_citizen_id_number )
  727. {
  728. bExist = TRUE;
  729. strMsg = _T("员工身份证号存在");
  730. break;
  731. }
  732. if ( DAL::Case_234_GetStaffSelfPhone(m_AryStaff, i) == m_staff_self_phone )
  733. {
  734. bExist = TRUE;
  735. strMsg = _T("员工个人电话存在");
  736. break;
  737. }
  738. if ( DAL::Case_234_GetStaffSelfQQ(m_AryStaff, i) == m_staff_self_qq )
  739. {
  740. bExist = TRUE;
  741. strMsg = _T("员工个人QQ存在");
  742. break;
  743. }
  744. /*if ( DAL::Case_234_GetStaffSelfEmail(m_AryStaff, i) == m_staff_self_email )
  745. {
  746. bExist = TRUE;
  747. strMsg = _T("员工个人邮箱存在");
  748. break;
  749. }*/
  750. }
  751. return bExist;
  752. }
  753. BOOL CStaffInfo::IsExistStaffInfo(CString staff_id, CString &strMsg)
  754. {
  755. UpdateData(TRUE);
  756. BOOL bExist = FALSE;
  757. for ( int i = 0; i < m_AryStaff.GetSize(); i++ )
  758. {
  759. if ( DAL::Case_234_GetStaffId(m_AryStaff, i) == staff_id )
  760. {
  761. //bExist = TRUE;
  762. //strMsg = _T("员工编号存在");
  763. continue;;
  764. }
  765. if ( DAL::Case_234_GetStaffCitizenIdNumber(m_AryStaff, i) == m_staff_citizen_id_number )
  766. {
  767. bExist = TRUE;
  768. strMsg = _T("员工身份证号存在");
  769. break;
  770. }
  771. if ( DAL::Case_234_GetStaffSelfPhone(m_AryStaff, i) == m_staff_self_phone )
  772. {
  773. bExist = TRUE;
  774. strMsg = _T("员工个人电话存在");
  775. break;
  776. }
  777. if ( DAL::Case_234_GetStaffSelfQQ(m_AryStaff, i) == m_staff_self_qq )
  778. {
  779. bExist = TRUE;
  780. strMsg = _T("员工个人QQ存在");
  781. break;
  782. }
  783. /*if ( DAL::Case_234_GetStaffSelfEmail(m_AryStaff, i) == m_staff_self_email )
  784. {
  785. bExist = TRUE;
  786. strMsg = _T("员工个人邮箱存在");
  787. break;
  788. }*/
  789. }
  790. return bExist;
  791. }
  792. void CStaffInfo::OnSysCommand(UINT nID, LPARAM lParam)
  793. {
  794. // 禁止移动窗口;
  795. if (nID == SC_MOVE || nID == 0xF012)
  796. return;
  797. CDialog::OnSysCommand(nID, lParam);
  798. }
  799. void CStaffInfo::OnBnClickedLookImage() // 查看相片;
  800. {
  801. // 移除之前的相片资源;
  802. for (vector<Annex>::iterator it = m_vtAnnex.begin(); it != m_vtAnnex.end(); it++)
  803. {
  804. if ( it->pImage )
  805. delete it->pImage;
  806. }
  807. m_vtAnnex.clear();
  808. // 获取相片类型;
  809. if ( m_cbox_credentials.GetCurSel() == CB_ERR) {
  810. MessageBox(_T("请选择要上传的相片类型"));
  811. return;
  812. }
  813. // 相片类型;
  814. CString strImageType ;
  815. m_cbox_credentials.GetLBText(m_cbox_credentials.GetCurSel(), strImageType);
  816. DWORD dwIndexCount = 0;
  817. DWORD dwSendLen = strImageType.GetLength() + m_staff_id.GetLength() + m_staff_citizen_id_number.GetLength() + 3*sizeof(DWORD);
  818. BYTE *pSendData = new BYTE[dwSendLen];
  819. memset(pSendData, 0, dwSendLen);
  820. DWORD dwLen = strImageType.GetLength();
  821. // 请求的相片类型;
  822. memcpy(pSendData, &dwLen, sizeof(DWORD));
  823. dwIndexCount += sizeof(DWORD);
  824. memcpy(pSendData + dwIndexCount, strImageType.GetString(), strImageType.GetLength());
  825. // 请求的员工id;
  826. dwLen = m_staff_id.GetLength();
  827. dwIndexCount += strImageType.GetLength();
  828. memcpy(pSendData + dwIndexCount, &dwLen, sizeof(DWORD));
  829. dwIndexCount += sizeof(DWORD);
  830. memcpy(pSendData + dwIndexCount, m_staff_id.GetString(), m_staff_id.GetLength());
  831. // 请求的员工身份证号;
  832. dwLen = m_staff_citizen_id_number.GetLength();
  833. dwIndexCount += m_staff_id.GetLength();
  834. memcpy(pSendData + dwIndexCount, &dwLen, sizeof(DWORD));
  835. dwIndexCount += sizeof(DWORD);
  836. memcpy(pSendData + dwIndexCount, m_staff_citizen_id_number.GetString(), m_staff_citizen_id_number.GetLength());
  837. // 向服务器请求;
  838. g_nSendCode = 27;
  839. g_pMainWnd->ProcessChatMessageRequest2(pSendData, dwSendLen);
  840. if ( pSendData )delete []pSendData;
  841. g_nSendCode = 0;
  842. if (g_bSendOK == 0)
  843. {
  844. return;
  845. }
  846. // 获取返回的相片数据;
  847. // 返回的数据结构: 相片数量->数据大小->相片名+名字长度->相片内容->数据大小->相片名+名字长度->相片内容->....;
  848. dwIndexCount = sizeof(DWORD);
  849. DWORD dwImageCount = 0;
  850. DWORD dwImageSize = 0;
  851. BYTE *pImageData = NULL;
  852. DWORD dwNameLen = 0;
  853. TCHAR szImageName[MAX_PATH] = {0};
  854. memcpy(&dwImageCount, g_pData, sizeof(DWORD));
  855. for ( DWORD i = 0; i < dwImageCount; i++ )
  856. {// 轮询相片;
  857. // 相片名称 ;
  858. memset(szImageName, 0, MAX_PATH);
  859. memcpy(&dwNameLen, g_pData + dwIndexCount, sizeof(DWORD));
  860. dwIndexCount += sizeof(DWORD);
  861. memcpy(szImageName, g_pData + dwIndexCount, dwNameLen);
  862. dwIndexCount += dwNameLen;
  863. // 相片大小;
  864. memcpy(&dwImageSize, g_pData + dwIndexCount, sizeof(DWORD));
  865. dwIndexCount += sizeof(DWORD);
  866. // 相片内容;
  867. pImageData = g_pData + dwIndexCount;
  868. dwIndexCount += dwImageSize;
  869. // 保存图片到内存中, 不存储成文件;
  870. Image *pImage = NULL;
  871. LoadImageFromBuf(&pImage, pImageData, dwImageSize);
  872. Annex annex;
  873. annex.strMD5 = szImageName;
  874. annex.pImage = pImage;
  875. m_vtAnnex.push_back(annex);
  876. #ifdef _DEBUG // 正式使用时,不要保存文件;
  877. if ( pImage )
  878. {
  879. CFile cf;
  880. CString strSave;
  881. strSave.Format(_T("%s\\staff\\%s\\%s\\"), g_szModulePath, m_staff_citizen_id_number, strImageType);
  882. SHCreateDirectoryEx(NULL, strSave, NULL);
  883. CMD5 md5;
  884. md5.SetBYTEText(pImageData, dwImageSize);
  885. strSave += md5.GetMD5Digest();
  886. strSave += _T(".jpg");
  887. if ( cf.Open(strSave, CFile::modeCreate|CFile::modeWrite) )
  888. {
  889. cf.Write(pImageData, dwImageSize);
  890. cf.Close();
  891. }
  892. }
  893. #endif
  894. }
  895. if ( m_vtAnnex.size() == 0 )
  896. {
  897. MessageBox(_T("没有该类型的相片"));
  898. return;
  899. }
  900. CDlgAnnex dlg;
  901. dlg.m_pvtAnnex = &m_vtAnnex;
  902. dlg.m_staff_id = m_staff_id;
  903. dlg.m_strImageType = strImageType;
  904. dlg.m_staff_citizen_id_number = m_staff_citizen_id_number;
  905. dlg.DoModal();
  906. }