FinanceDayReportSmallForm.cs 60 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172
  1. using LYFZ.ComponentLibrary;
  2. using LYFZ.Software.MainBusiness.DoorCityProcess;
  3. using System;
  4. using System.Collections;
  5. using System.Collections.Generic;
  6. using System.ComponentModel;
  7. using System.Data;
  8. using System.Drawing;
  9. using System.Linq;
  10. using System.Text;
  11. using System.Windows.Forms;
  12. namespace LYFZ.Software.MainBusiness.StatisticalInquiry
  13. {
  14. public partial class FinanceDayReportSmallForm : LYFZ.Software.UI.StatisticalInquiry.FinanceDayReportSmallForm
  15. {
  16. // 是否只显示未审核通过的数据;
  17. private bool OnlyShowUnAudited = false;
  18. LYFZ.BLL.BLL_ErpOrder orbll = new BLL.BLL_ErpOrder();
  19. LYFZ.BLL.BLL_ErpPayment ptbll = new BLL.BLL_ErpPayment();
  20. LYFZ.BLL.BLL_ErpDressRefundRecord drrbll = new BLL.BLL_ErpDressRefundRecord();
  21. LYFZ.BLL.BLL_ErpMemberCardPayment mcptbll = new BLL.BLL_ErpMemberCardPayment();
  22. LYFZ.BLL.BLL_ErpMemberCardTakeCash mctkcbll = new BLL.BLL_ErpMemberCardTakeCash();
  23. LYFZ.BLL.BLL_ErpOtherIncomeAndExpenses oiebll = new BLL.BLL_ErpOtherIncomeAndExpenses();
  24. LYFZ.BLL.BLL_ErpDressDepositReceivables ddrbll = new BLL.BLL_ErpDressDepositReceivables();
  25. LYFZ.BLL.BLL_ErpMemberCardRechargeRecord mcrrbll = new BLL.BLL_ErpMemberCardRechargeRecord();
  26. LYFZ.BLL.BLL_ErpMemberCardBackCashTakeCash bctcbll = new BLL.BLL_ErpMemberCardBackCashTakeCash();
  27. LYFZ.BLL.BLL_ErpMemberCardPhotographerMain mcpmbll = new BLL.BLL_ErpMemberCardPhotographerMain();
  28. ToolTip totip = new ToolTip();
  29. public FinanceDayReportSmallForm()
  30. {
  31. this.Load += FinanceDayReportSmallForm_Load;
  32. this.Shown += FinanceDayReportSmallForm_Shown;
  33. this.cmbtreevQueryItem.ComboBoxTree_NodeMouseClick += cmbtreevQueryItem_ComboBoxTree_NodeMouseClick;
  34. this.cmbtreevSecondOption.ComboBoxTree_NodeMouseClick += cmbtreevSecondOption_ComboBoxTree_NodeMouseClick;
  35. this.cmbtreevPaymentMethod.ComboBoxTree_NodeMouseClick += cmbtreevPaymentMethod_ComboBoxTree_NodeMouseClick;
  36. this.cmbtreevStoreName.ComboBoxTree_NodeMouseClick += cmbtreevStoreName_ComboBoxTree_NodeMouseClick;
  37. this.cmbtreevOrderType.ComboBoxTree_NodeMouseClick += cmbtreevOrderType_ComboBoxTree_NodeMouseClick;
  38. this.numYear.ValueChanged += numYear_ValueChanged;
  39. this.numMonth.ValueChanged += numMonth_ValueChanged;
  40. this.numDay.ValueChanged += numDay_ValueChanged;
  41. this.numYear.KeyDown += numYear_KeyDown;
  42. this.numMonth.KeyDown += numMonth_KeyDown;
  43. this.numDay.KeyDown += numDay_KeyDown;
  44. this.btnAudit.Click += btnAudit_Click;
  45. this.btnExport.Click += btnExport_Click;
  46. this.btnPrint.Click += btnPrint_Click;
  47. this.btnClose.Click += btnClose_Click;
  48. this.Resize += FinanceDayReportSmallForm_Resize;
  49. this.lblCount.MouseDown += lblCount_MouseDown;
  50. this.lblFinancialSMS.MouseDown += lblFinancialSMS_MouseDown;
  51. this.lblPaymentMethodStatistics.MouseDown += lblPaymentMethodStatistics_MouseDown;
  52. this.lblTotalIncome.MouseClick += lblTotalIncome_MouseClick;
  53. this.lblOperatingIncome.MouseClick += lblOperatingIncome_MouseClick;
  54. this.lblTotalPerformance.MouseClick += lblTotalPerformance_MouseClick;
  55. //this.dgvData.RowsAdded += dgvData_RowsAdded;
  56. this.dgvData.CellMouseDoubleClick += dgvData_CellMouseDoubleClick;
  57. DataTable tb_User = LYFZ.Software.MainBusiness.DoorCityProcess.PublicGetVersionDataTable.GetUserTable();
  58. LYFZ.Software.MainBusiness.DoorCityProcess.PublicCodeClasses.BindComboBoxTreeView_DepartmentAndEmployee( this.comboxEmployeeList, tb_User: tb_User, IsHaveAllTreeNode: true );
  59. this.comboxEmployeeList.ComboBoxTree_NodeMouseClick += comboxEmployeeList_ComboBoxTree_NodeMouseClick;
  60. this.btn_ArrearsOfDay.Click += btn_ArrearsOfDay_Click;
  61. this.cmbtreevOrderClass.ComboBoxTree_NodeMouseClick += cmbtreevOrderType_ComboBoxTree_NodeMouseClick;
  62. // 是否只显示未审核通过的数据;
  63. this.ckb_UnAudited.Click += Ckb_UnAudited_Click;
  64. }
  65. private void Ckb_UnAudited_Click( object sender, EventArgs e )
  66. {
  67. this.OnlyShowUnAudited = ckb_UnAudited.Checked;
  68. this.cmbtreevSecondOption_ComboBoxTree_NodeMouseClick( this, null );
  69. }
  70. /// <summary>
  71. /// 绑定订单类别数据
  72. /// </summary>
  73. void BindOrderClassData()
  74. {
  75. LYFZ.Software.MainBusiness.DoorCityProcess.PublicCodeClasses.BindComboBoxTreeView_SystemCategory( "BFAGAHBFDGCABAJIH", this.cmbtreevOrderClass, true );
  76. }
  77. void btn_ArrearsOfDay_Click( object sender, EventArgs e )
  78. {
  79. FrmArrearsOfDayReport dayReportDialog = new FrmArrearsOfDayReport();
  80. List<string> numberList = new List<string>();
  81. //for(int i=0;i < this.dgvData.Rows.Count;i++)
  82. //{
  83. // numberList.Add(this.dgvData.Rows[i].Cells["项目名称"].Value.ToString());
  84. //}
  85. //numberList
  86. dayReportDialog.BindDataRow();
  87. dayReportDialog.ShowDialog();
  88. }
  89. /// <summary>
  90. /// 当前日期,用于月报跳转过来的
  91. /// </summary>
  92. public string DateTimeDay = "";
  93. /// <summary>
  94. /// 日期段(开始日期)
  95. /// </summary>
  96. public string DateTimeStart = "";
  97. /// <summary>
  98. /// 日期段(结束日期)
  99. /// </summary>
  100. public string DateTimeEnd = "";
  101. /// <summary>
  102. /// 需要的分店编号(用于月报跳转过来)
  103. /// </summary>
  104. public string DataTimeStoreName = "";
  105. /// <summary>
  106. /// 是否首次运行
  107. /// </summary>
  108. private bool IsFirst = true;
  109. /// <summary>
  110. /// 是否有财务支出权限
  111. /// </summary>
  112. private bool IsFinancialOutlay = false;
  113. /// <summary>
  114. /// 分店编号
  115. /// </summary>
  116. private string _StrStoreWhere;
  117. /// <summary>
  118. /// 分店编号
  119. /// </summary>
  120. public string StrStoreWhere
  121. {
  122. get
  123. {
  124. this.Invoke( new LYFZ.Software.MainBusiness.DoorCityProcess.PublicCodeClasses.UpdateControl( delegate ()
  125. {
  126. _StrStoreWhere = LYFZ.Software.MainBusiness.DoorCityProcess.PublicCodeClasses.GetGroupQueryWhere( this.cmbtreevStoreName, "分店编号", ConnectWord: "" );
  127. } ) );
  128. return _StrStoreWhere;
  129. }
  130. set
  131. {
  132. _StrStoreWhere = value;
  133. }
  134. }
  135. /// <summary>
  136. /// 窗体加载事件
  137. /// </summary>
  138. /// <param name="sender"></param>
  139. /// <param name="e"></param>
  140. void FinanceDayReportSmallForm_Load( object sender, EventArgs e )
  141. {
  142. string StrColumns = "编号,Pay_Type,项目名称,开单人,客户姓名,金额,优惠金额,项目类别,收入/支出,日期,支付方式,收银,财务审核,项目备注";
  143. this.dgvData.DataColumns( StrColumns, "编号,Pay_Type" );
  144. this.dgvData.Columns["项目名称"].Width = 150;
  145. this.dgvData.Columns["日期"].Width = 110;
  146. this.dgvData.Columns["客户姓名"].Width = 150;
  147. this.dgvData.Columns["支付方式"].Width = 150;
  148. this.dgvData.Columns["财务审核"].Width = 120;
  149. }
  150. /// <summary>
  151. /// 窗体加载事件
  152. /// </summary>
  153. /// <param name="sender"></param>
  154. /// <param name="e"></param>
  155. void FinanceDayReportSmallForm_Shown( object sender, EventArgs e )
  156. {
  157. LYFZ.Software.MainBusiness.DoorCityProcess.PublicCodeClasses.BindGroupStoreName( this.cmbtreevStoreName, StrGroupKeyCode: "st0240", StrKeyCode: "st025", StrDefaultStoreText: DataTimeStoreName );
  158. LYFZ.Software.MainBusiness.DoorCityProcess.PublicCodeClasses.BindFinanceOrderType( this.cmbtreevOrderType );
  159. //this.cmbtreevSecondOption.Visible = false;
  160. this.FinanceDayReportSmallForm_Resize( this, null );
  161. this.lblTotalIncome.ForeColor = Color.DarkCyan;
  162. this.totip.SetToolTip( this.lblTotalIncome, "点我查看总收入详情" );
  163. this.lblOperatingIncome.ForeColor = Color.DarkCyan;
  164. this.totip.SetToolTip( this.lblOperatingIncome, "点我查看营业收入详情" );
  165. this.lblTotalPerformance.ForeColor = Color.DarkCyan;
  166. this.totip.SetToolTip( this.lblTotalPerformance, "点我查看总业绩详情" );
  167. if ( !string.IsNullOrEmpty( this.DateTimeDay ) )
  168. {
  169. this.numYear.Value = Convert.ToDateTime( DateTimeDay ).Year;
  170. this.numMonth.Value = Convert.ToDateTime( DateTimeDay ).Month;
  171. this.numDay.Value = Convert.ToDateTime( DateTimeDay ).Day;
  172. this.panelDay.Visible = true;
  173. this.panelParagraph.Visible = false;
  174. }
  175. else
  176. {
  177. if ( !string.IsNullOrEmpty( this.DateTimeStart ) && !string.IsNullOrEmpty( this.DateTimeEnd ) )
  178. {
  179. this.Text = "月报详情";
  180. this.UcNavigationTool.LabTitle = "月报详情";
  181. this.lblDateTime.Text = this.DateTimeStart + "—" + this.DateTimeEnd;
  182. this.panelParagraph.Visible = true;
  183. this.panelDay.Visible = false;
  184. // 只有在月报详情才显示;
  185. this.ckb_UnAudited.Visible = true;
  186. }
  187. else
  188. {
  189. this.numYear.Value = SDateTime.Now.Year;
  190. this.numMonth.Value = SDateTime.Now.Month;
  191. this.numDay.Value = SDateTime.Now.Day;
  192. this.panelDay.Visible = true;
  193. this.panelParagraph.Visible = false;
  194. }
  195. }
  196. this.numDay.Maximum = System.Threading.Thread.CurrentThread.CurrentUICulture.Calendar.GetDaysInMonth( Convert.ToInt32( this.numYear.Value ), Convert.ToInt32( this.numMonth.Value ) );
  197. this.IsFirst = false;
  198. LYFZ.Software.MainBusiness.DoorCityProcess.PublicCodeClasses.BindComboxTreeView( this.cmbtreevSecondOption, "全部,收入,支出,押金,退押金,报损" );
  199. this.cmbtreevSecondOption.TextFindTag( "全部" );
  200. LYFZ.Software.MainBusiness.DoorCityProcess.PublicCodeClasses.BindComboBoxTreeView_PaymentMethod( this.cmbtreevPaymentMethod, IsShowAll: true, IsFirstNodeNull: true, IsFirstNodeName: "全部" );
  201. this.cmbtreevPaymentMethod.TextFindTag( "全部" );
  202. this.PublicFunctionRights();
  203. this.numYear_ValueChanged( this, null );
  204. BindOrderClassData();
  205. }
  206. void comboxEmployeeList_ComboBoxTree_NodeMouseClick( object sender, TreeNodeMouseClickEventArgs e )
  207. {
  208. this.cmbtreevSecondOption_ComboBoxTree_NodeMouseClick( this, null );
  209. }
  210. /// <summary>
  211. /// 项目查询选择事件
  212. /// </summary>
  213. /// <param name="sender"></param>
  214. /// <param name="e"></param>
  215. void cmbtreevQueryItem_ComboBoxTree_NodeMouseClick( object sender, TreeNodeMouseClickEventArgs e )
  216. {
  217. this.cmbtreevSecondOption.Nodes.Clear();
  218. this.cmbtreevSecondOption.Visible = false;
  219. if ( this.cmbtreevQueryItem.Text == "全部" )
  220. {
  221. this.cmbtreevSecondOption.Visible = true;
  222. LYFZ.Software.MainBusiness.DoorCityProcess.PublicCodeClasses.BindComboxTreeView( this.cmbtreevSecondOption, "全部,收入,支出,押金,退押金,报损" );
  223. }
  224. else if ( this.cmbtreevQueryItem.Text == "订单前期收入" )
  225. {
  226. this.cmbtreevSecondOption.Visible = true;
  227. LYFZ.Software.MainBusiness.DoorCityProcess.PublicCodeClasses.BindComboxTreeView( this.cmbtreevSecondOption, "全部,预约收款,预约补款,全款" );
  228. }
  229. else if ( this.cmbtreevQueryItem.Text == "订单后期收入" || this.cmbtreevQueryItem.Text == "散客消费收入" )
  230. {
  231. this.cmbtreevSecondOption.Visible = true;
  232. LYFZ.Software.MainBusiness.DoorCityProcess.PublicCodeClasses.BindComboBoxTreeView_SystemCategory( "BEBACDAJDFDDEACGJ", this.cmbtreevSecondOption, IsFirstNodeNull: true, IsFirstNodeName: "全部" );
  233. }
  234. else if ( this.cmbtreevQueryItem.Text == "其它收入" )
  235. {
  236. }
  237. else if ( this.cmbtreevQueryItem.Text == "会员充值" )
  238. {
  239. }
  240. else if ( this.cmbtreevQueryItem.Text == "服务卡消费" )
  241. {
  242. }
  243. else if ( this.cmbtreevQueryItem.Text == "摄友会收款" )
  244. {
  245. this.cmbtreevSecondOption.Visible = true;
  246. LYFZ.Software.MainBusiness.DoorCityProcess.PublicCodeClasses.BindComboxTreeView( this.cmbtreevSecondOption, "全部,摄友会升级,摄友会返还款" );
  247. }
  248. else if ( this.cmbtreevQueryItem.Text == "礼服租售收入" )
  249. {
  250. this.cmbtreevSecondOption.Visible = true;
  251. LYFZ.Software.MainBusiness.DoorCityProcess.PublicCodeClasses.BindComboxTreeView( this.cmbtreevSecondOption, "全部,礼服出租,礼服出售,礼服押金,退押金,报损" );
  252. }
  253. else if ( this.cmbtreevQueryItem.Text == "会员返现" )
  254. {
  255. }
  256. else if ( this.cmbtreevQueryItem.Text == "店面支出" )
  257. {
  258. this.cmbtreevSecondOption.Visible = true;
  259. LYFZ.Software.MainBusiness.DoorCityProcess.PublicCodeClasses.BindComboBoxTreeView_SystemCategory( "BEBACIAFBEDIGJJFE", this.cmbtreevSecondOption, IsFirstNodeNull: true, IsFirstNodeName: "全部" );
  260. }
  261. else if ( this.cmbtreevQueryItem.Text == "财务支出" )
  262. {
  263. this.cmbtreevSecondOption.Visible = true;
  264. LYFZ.Software.MainBusiness.DoorCityProcess.PublicCodeClasses.BindComboBoxTreeView_SystemCategory( "BFAGBGBAEJBACEEHJ", this.cmbtreevSecondOption, IsFirstNodeNull: true, IsFirstNodeName: "全部" );
  265. }
  266. //else if (this.cmbtreevQueryItem.Text == "押金")
  267. //{ }
  268. if ( this.cmbtreevSecondOption.Visible )
  269. {
  270. this.cmbtreevSecondOption.TextFindTag( "全部" );
  271. }
  272. if ( !this.cmbtreevSecondOption.Visible )
  273. {
  274. this.panelQueryItem.Width = 240;
  275. }
  276. else
  277. {
  278. this.panelQueryItem.Width = 370;
  279. }
  280. this.cmbtreevSecondOption_ComboBoxTree_NodeMouseClick( this, null );
  281. }
  282. /// <summary>
  283. /// 第二选项选择事件
  284. /// </summary>
  285. /// <param name="sender"></param>
  286. /// <param name="e"></param>
  287. void cmbtreevSecondOption_ComboBoxTree_NodeMouseClick( object sender, TreeNodeMouseClickEventArgs e )
  288. {
  289. this.dgvData.Rows.Clear();
  290. this.FinanceDayReportSmallForm_Load( this, null );
  291. this.IsCurrentShowTotalIncome = false;
  292. this.IsCurrentShowOperatingIncome = false;
  293. this.lblTotalIncome.ForeColor = Color.DarkCyan;
  294. this.lblOperatingIncome.ForeColor = Color.DarkCyan;
  295. string StrItemQueryText = this.cmbtreevQueryItem.Text.Trim();
  296. string StrSecondOption = this.cmbtreevSecondOption.Text.Trim();
  297. string StrPaymentMethod = this.cmbtreevPaymentMethod.Text.Trim();
  298. string StrOrderType = this.cmbtreevOrderType.Text.Trim();
  299. string StrOrderClass = this.cmbtreevOrderClass.Text.Trim();
  300. string strCashier = this.comboxEmployeeList.Text.Trim();
  301. if ( strCashier.Equals( "全部" ) )
  302. {
  303. strCashier = "";
  304. }
  305. if ( this.panelDay.Visible )
  306. {
  307. this.DateTimeStart = this.numYear.Value + "-" + this.numMonth.Value + "-" + this.numDay.Value;
  308. this.DateTimeEnd = this.DateTimeStart;
  309. }
  310. LYFZ.ComponentLibrary.FrmLoadHandling.LoadDoWorkMethod( delegate ( object obj, BackgroundWorker backgroundWorker )
  311. {
  312. this.dgvData.VirtualMode = false;
  313. this.dgvData.Rows.Clear();
  314. LYFZ.BLL.GetFinancialReportModel frmodel = orbll.Funt_GetFinanceDayReport(
  315. StrItemQueryText: StrItemQueryText,
  316. StrSecondOption: StrSecondOption,
  317. StrPaymentMethod: StrPaymentMethod,
  318. StrOrderType: StrOrderType,
  319. StrDateTimeStart: this.DateTimeStart,
  320. StrDateTimeEnd: this.DateTimeEnd, IsFinancialOutlay: this.IsFinancialOutlay, IsGetArrearsOrDeposits: true, StrStoreWhere: this.StrStoreWhere, strCashier: strCashier, StrOrderClass: StrOrderClass );
  321. DataTable dt = frmodel.dtFinance_Statistic;
  322. DataTable dt2 = frmodel.dtFinance_DataList;
  323. this.Invoke( new LYFZ.Software.MainBusiness.DoorCityProcess.PublicCodeClasses.UpdateControl( delegate ()
  324. {
  325. if ( dt != null )
  326. {
  327. for ( int i = 0; i < dt.Rows.Count; i++ )
  328. {
  329. this.txtTotalIncome.Text = dt.Rows[i]["总收入"].ToString().Trim();
  330. this.txtOperatingIncome.Text = dt.Rows[i]["营业收入"].ToString().Trim();
  331. this.txtNetIncome.Text = dt.Rows[i]["净收入"].ToString().Trim();
  332. this.txtOrderEarly.Text = dt.Rows[i]["订单前期"].ToString().Trim();
  333. this.txtOrderLate.Text = dt.Rows[i]["订单后期"].ToString().Trim();
  334. this.txtTotalArrears.Text = dt.Rows[i]["总欠款"].ToString().Trim();
  335. this.txtTotalDeposit.Text = dt.Rows[i]["总押金"].ToString().Trim();
  336. this.txtTotalOutlay.Text = dt.Rows[i]["支出"].ToString().Trim();
  337. this.txtVoucher.Text = dt.Rows[i]["代金券"].ToString().Trim();
  338. this.txtTotalPerformance.Text = dt.Rows[i]["总业绩"].ToString().Trim();
  339. }
  340. this.txtTotalDeposit_OK.Text = frmodel.DecTotalDeposits_OK.ToString("n2");
  341. }
  342. if ( dt2 != null )
  343. {
  344. for ( int i = 0; i < dt2.Rows.Count; i++ )
  345. {
  346. DataGridViewRow dgvr = new DataGridViewRow();
  347. DataGridViewCell cell = null;
  348. switch ( dt2.Rows[i]["Pay_Type"].ToString().Trim() )
  349. {
  350. case "0":
  351. case "1":
  352. case "2":
  353. dgvr.DefaultCellStyle.ForeColor = Color.Red;
  354. break;
  355. case "-1":
  356. if ( dt2.Rows[i]["项目名称"].ToString().Trim() == "储值取现" )
  357. {
  358. dgvr.DefaultCellStyle.ForeColor = Color.Red;
  359. }
  360. else
  361. {
  362. switch ( dt2.Rows[i]["项目类别"].ToString().Trim() )
  363. {
  364. case "其它收入":
  365. case "店面支出":
  366. case "财务支出":
  367. case "会员充值":
  368. case "服务消费":
  369. case "会员返现":
  370. case "礼服退押金":
  371. case "礼服押金":
  372. case "摄友会返还款":
  373. case "摄友会升级":
  374. dgvr.DefaultCellStyle.ForeColor = Color.Red;
  375. break;
  376. }
  377. }
  378. break;
  379. }
  380. // 是否审核过;
  381. bool IsAudited = false;
  382. // 是否包含有审核数据;
  383. bool IsContainAudited = false;
  384. for ( int j = 0; j < dt2.Columns.Count; j++ )
  385. {
  386. if ( dt2.Columns[j].ColumnName.Trim() == "审核" )
  387. {
  388. IsContainAudited = true;
  389. if ( !string.IsNullOrEmpty( dt2.Rows[i][j].ToString().Trim() ) && dt2.Rows[i][j].ToString().Trim().IndexOf( "已审核/" ) != -1 )
  390. {
  391. IsAudited = true; // 已审核;
  392. dgvr.DefaultCellStyle.ForeColor = Color.Blue;
  393. }
  394. else if ( !string.IsNullOrEmpty( dt2.Rows[i][j].ToString().Trim() ) )
  395. {
  396. dgvr.DefaultCellStyle.ForeColor = Color.Red;
  397. }
  398. }
  399. cell = new DataGridViewTextBoxCell();
  400. cell.Value = dt2.Rows[i][j].ToString().Trim();
  401. dgvr.Cells.Add( cell );
  402. }
  403. if ( (i % 2) > 0 )
  404. {
  405. dgvr.DefaultCellStyle.BackColor = this.dgvData.DataGridViewRowsBackColor_Double();
  406. }
  407. else
  408. {
  409. dgvr.DefaultCellStyle.BackColor = this.dgvData.DataGridViewRowsBackColor_Single();
  410. }
  411. // 只显示未审核的数据;
  412. if ( OnlyShowUnAudited == true && IsContainAudited && IsAudited )
  413. continue;
  414. this.dgvData.Rows.Add( dgvr );
  415. }
  416. }
  417. } ) );
  418. } );
  419. if ( this.dgvData.Columns.Contains( "项目备注" ) )
  420. {
  421. this.dgvData.Columns["项目备注"].Width = 250;
  422. }
  423. }
  424. /// <summary>
  425. /// 付款方式选择事件
  426. /// </summary>
  427. /// <param name="sender"></param>
  428. /// <param name="e"></param>
  429. void cmbtreevPaymentMethod_ComboBoxTree_NodeMouseClick( object sender, TreeNodeMouseClickEventArgs e )
  430. {
  431. this.cmbtreevSecondOption_ComboBoxTree_NodeMouseClick( this, null );
  432. }
  433. /// <summary>
  434. /// 选择分店
  435. /// </summary>
  436. /// <param name="sender"></param>
  437. /// <param name="e"></param>
  438. void cmbtreevStoreName_ComboBoxTree_NodeMouseClick( object sender, TreeNodeMouseClickEventArgs e )
  439. {
  440. if ( string.IsNullOrEmpty( this.cmbtreevStoreName.Tag.ToString().Trim() ) )
  441. {
  442. this.cmbtreevOrderType.SetTextAndTag_ValueNull();
  443. this.panelOrderType.Visible = false;
  444. }
  445. else
  446. {
  447. this.panelOrderType.Visible = true;
  448. }
  449. this.PublicFunctionRights();
  450. this.numDay_ValueChanged( this, null );
  451. }
  452. /// <summary>
  453. /// 选择订单类型
  454. /// </summary>
  455. /// <param name="sender"></param>
  456. /// <param name="e"></param>
  457. void cmbtreevOrderType_ComboBoxTree_NodeMouseClick( object sender, TreeNodeMouseClickEventArgs e )
  458. {
  459. this.cmbtreevSecondOption_ComboBoxTree_NodeMouseClick( this, null );
  460. }
  461. /// <summary>
  462. /// 选择分店获取权限
  463. /// </summary>
  464. void PublicFunctionRights()
  465. {
  466. LYFZ.Software.MainBusiness.DoorCityProcess.PublicCodeClasses.BindComboxTreeView( this.cmbtreevQueryItem, "全部,订单前期收入,订单后期收入,散客消费收入,其它收入,礼服租售收入,会员充值,服务卡消费,摄友会收款,会员返现,店面支出,财务支出" );//,押金
  467. this.cmbtreevQueryItem.TextFindTag( "全部" );
  468. this.numDay.Enabled = LYFZ.Software.MainBusiness.DoorCityProcess.PublicCodeClasses.GetGroupStoreRights( this.cmbtreevStoreName, "DayFinanceCompetence", CustomAttributes.OperatingAuthority.FinancialDayReport_CurrentDay );
  469. this.numMonth.Enabled = this.numDay.Enabled;
  470. this.numYear.Enabled = this.numDay.Enabled;
  471. this.btnAudit.Enabled = LYFZ.Software.MainBusiness.DoorCityProcess.PublicCodeClasses.GetGroupStoreRights( this.cmbtreevStoreName, "DayFinanceCompetence", CustomAttributes.OperatingAuthority.FinancialAudit );
  472. this.btnExport.Enabled = LYFZ.Software.MainBusiness.DoorCityProcess.PublicCodeClasses.GetGroupStoreRights( this.cmbtreevStoreName, "DayFinanceCompetence", CustomAttributes.OperatingAuthority.DataExport );
  473. this.btnPrint.Enabled = LYFZ.Software.MainBusiness.DoorCityProcess.PublicCodeClasses.GetGroupStoreRights( this.cmbtreevStoreName, "DayFinanceCompetence", CustomAttributes.OperatingAuthority.Print );
  474. this.IsFinancialOutlay = LYFZ.Software.MainBusiness.DoorCityProcess.PublicCodeClasses.GetGroupStoreRights( this.cmbtreevStoreName, "DayFinanceCompetence", CustomAttributes.OperatingAuthority.FinancialExpenses );
  475. if ( !this.IsFinancialOutlay )
  476. {
  477. this.cmbtreevQueryItem.Nodes.Remove( this.cmbtreevQueryItem.GetNodeItem_TextToTag( "财务支出" ) );
  478. }
  479. this.panelNetIncome.Visible = this.IsFinancialOutlay;
  480. }
  481. /// <summary>
  482. /// 年
  483. /// </summary>
  484. /// <param name="sender"></param>
  485. /// <param name="e"></param>
  486. void numYear_ValueChanged( object sender, EventArgs e )
  487. {
  488. if ( !this.IsFirst )
  489. {
  490. this.numDay_ValueChanged( this, null );
  491. }
  492. }
  493. /// <summary>
  494. /// 月
  495. /// </summary>
  496. /// <param name="sender"></param>
  497. /// <param name="e"></param>
  498. void numMonth_ValueChanged( object sender, EventArgs e )
  499. {
  500. if ( !this.IsFirst )
  501. {
  502. this.numDay.Maximum = System.Threading.Thread.CurrentThread.CurrentUICulture.Calendar.GetDaysInMonth( Convert.ToInt32( this.numYear.Value ), Convert.ToInt32( this.numMonth.Value ) );
  503. this.numDay_ValueChanged( this, null );
  504. }
  505. }
  506. bool IsRun = false;
  507. /// <summary>
  508. /// 日
  509. /// </summary>
  510. /// <param name="sender"></param>
  511. /// <param name="e"></param>
  512. void numDay_ValueChanged( object sender, EventArgs e )
  513. {
  514. if ( !this.IsFirst && !this.IsRun )
  515. {
  516. IsRun = true;
  517. this.IsCurrentShowTotalIncome = false;
  518. this.IsCurrentShowOperatingIncome = false;
  519. this.IsCurrentShowTotalPerformance = false;
  520. this.lblTotalIncome.ForeColor = Color.DarkCyan;
  521. this.lblOperatingIncome.ForeColor = Color.DarkCyan;
  522. this.lblTotalPerformance.ForeColor = Color.DarkCyan;
  523. if ( this.panelDay.Visible )
  524. {
  525. this.DateTimeStart = this.numYear.Value + "-" + this.numMonth.Value + "-" + this.numDay.Value;
  526. this.DateTimeEnd = this.DateTimeStart;
  527. }
  528. System.Threading.Thread t = new System.Threading.Thread( new System.Threading.ThreadStart( delegate ()
  529. {
  530. LYFZ.BLL.GetFinancialReportModel frmodel = orbll.Funt_GetFinanceDayReport_SMSStatistics( StrDateTimeStart: this.DateTimeStart, StrDateTimeEnd: this.DateTimeEnd, IsFinancialOutlay: IsFinancialOutlay, IsShowZeroText: true, StrStoreWhere: this.StrStoreWhere );
  531. this.Invoke( new LYFZ.Software.MainBusiness.DoorCityProcess.PublicCodeClasses.UpdateControl( delegate ()
  532. {
  533. this.lblCount.Text = frmodel.StrFinance_OrderCountStatistic;
  534. this.lblFinancialSMS.Text = frmodel.StrFinance_SMSStatistics;
  535. this.lblPaymentMethodStatistics.Text = frmodel.StrFinance_PaymentStatistic;
  536. this.labSettlement.Text = frmodel.StrFinance_SettlementStatistic;
  537. } ) );
  538. } ) );
  539. t.Start();
  540. this.IsRun = false;
  541. this.cmbtreevSecondOption_ComboBoxTree_NodeMouseClick( this, null );
  542. //string smsContent = orbll.Funt_GetDayFinanceSMS(orbll.Funt_GetFinanceDayReport_SMSStatistics(this.DateTimeStart, this.DateTimeEnd, IsFinancialOutlay: true, IsShowZeroText: true, StrStoreWhere: this.StrStoreWhere), null);
  543. }
  544. }
  545. /// <summary>
  546. /// 年回车
  547. /// </summary>
  548. /// <param name="sender"></param>
  549. /// <param name="e"></param>
  550. void numYear_KeyDown( object sender, KeyEventArgs e )
  551. {
  552. if ( e.KeyCode == Keys.Enter )
  553. {
  554. this.numDay_ValueChanged( this, null );
  555. }
  556. }
  557. /// <summary>
  558. /// 月回车
  559. /// </summary>
  560. /// <param name="sender"></param>
  561. /// <param name="e"></param>
  562. void numMonth_KeyDown( object sender, KeyEventArgs e )
  563. {
  564. if ( e.KeyCode == Keys.Enter )
  565. {
  566. this.numDay_ValueChanged( this, null );
  567. }
  568. }
  569. /// <summary>
  570. /// 日回车
  571. /// </summary>
  572. /// <param name="sender"></param>
  573. /// <param name="e"></param>
  574. void numDay_KeyDown( object sender, KeyEventArgs e )
  575. {
  576. if ( e.KeyCode == Keys.Enter )
  577. {
  578. this.numDay_ValueChanged( this, null );
  579. }
  580. }
  581. /// <summary>
  582. /// 当前是否显示总收入
  583. /// </summary>
  584. bool IsCurrentShowTotalIncome = false;
  585. /// <summary>
  586. /// 当前是否显示营业收入
  587. /// </summary>
  588. bool IsCurrentShowOperatingIncome = false;
  589. /// <summary>
  590. /// 当前是否显示总业绩
  591. /// </summary>
  592. bool IsCurrentShowTotalPerformance = false;
  593. /// <summary>
  594. /// 点击总收入
  595. /// </summary>
  596. /// <param name="sender"></param>
  597. /// <param name="e"></param>
  598. void lblTotalIncome_MouseClick( object sender, MouseEventArgs e )
  599. {
  600. if ( !this.IsCurrentShowTotalIncome )
  601. {
  602. this.IsCurrentShowTotalIncome = true;
  603. this.IsCurrentShowOperatingIncome = false;
  604. this.IsCurrentShowTotalPerformance = false;
  605. this.lblTotalPerformance.ForeColor = Color.DarkCyan;
  606. this.lblOperatingIncome.ForeColor = Color.DarkCyan;
  607. this.lblTotalIncome.ForeColor = Color.Red;
  608. this.totip.SetToolTip( this.lblTotalIncome, "点我查看项目详情" );
  609. this.TotalIncomeOrOperatingIncome_Click( LYFZ.BLL.BLL_ErpOrder.FinancialTotalIncomeSqlWhere );
  610. }
  611. else
  612. {
  613. this.IsCurrentShowTotalIncome = false;
  614. this.lblTotalIncome.ForeColor = Color.DarkCyan;
  615. this.lblOperatingIncome.ForeColor = Color.DarkCyan;
  616. this.lblTotalPerformance.ForeColor = Color.DarkCyan;
  617. this.totip.SetToolTip( this.lblTotalIncome, "点我查看总收入详情" );
  618. this.cmbtreevSecondOption_ComboBoxTree_NodeMouseClick( this, null );
  619. }
  620. }
  621. /// <summary>
  622. /// 点击营业收入
  623. /// </summary>
  624. /// <param name="sender"></param>
  625. /// <param name="e"></param>
  626. void lblOperatingIncome_MouseClick( object sender, MouseEventArgs e )
  627. {
  628. if ( !this.IsCurrentShowOperatingIncome )
  629. {
  630. this.IsCurrentShowOperatingIncome = true;
  631. this.IsCurrentShowTotalIncome = false;
  632. this.IsCurrentShowTotalPerformance = false;
  633. this.lblTotalIncome.ForeColor = Color.DarkCyan;
  634. this.lblTotalPerformance.ForeColor = Color.DarkCyan;
  635. this.lblOperatingIncome.ForeColor = Color.Red;
  636. this.totip.SetToolTip( this.lblOperatingIncome, "点我查看项目详情" );
  637. string StrSQL = "项目类别 != '摄友会返还款' and 项目类别 != '服务消费' and 项目类别 != '其它收入' and 项目类别 != '会员充值' and 项目类别 != '会员返现' and 项目类别 != '财务支出' and 项目类别 != '店面支出' and 项目类别 != '礼服押金' and 项目类别 != '礼服退押金' and 付款方式 != '代金券'";
  638. this.TotalIncomeOrOperatingIncome_Click( StrSQL );
  639. }
  640. else
  641. {
  642. this.IsCurrentShowOperatingIncome = false;
  643. this.lblTotalIncome.ForeColor = Color.DarkCyan;
  644. this.lblOperatingIncome.ForeColor = Color.DarkCyan;
  645. this.lblTotalPerformance.ForeColor = Color.DarkCyan;
  646. this.totip.SetToolTip( this.lblOperatingIncome, "点我查看营业收入详情" );
  647. this.cmbtreevSecondOption_ComboBoxTree_NodeMouseClick( this, null );
  648. }
  649. }
  650. /// <summary>
  651. /// 点击总业绩
  652. /// </summary>
  653. /// <param name="sender"></param>
  654. /// <param name="e"></param>
  655. void lblTotalPerformance_MouseClick( object sender, MouseEventArgs e )
  656. {
  657. if ( !this.IsCurrentShowTotalPerformance )
  658. {
  659. this.IsCurrentShowTotalPerformance = true;
  660. this.IsCurrentShowOperatingIncome = false;
  661. this.IsCurrentShowTotalIncome = false;
  662. this.lblTotalIncome.ForeColor = Color.DarkCyan;
  663. this.lblOperatingIncome.ForeColor = Color.DarkCyan;
  664. this.lblTotalPerformance.ForeColor = Color.Red;
  665. this.totip.SetToolTip( this.lblTotalPerformance, "点我查看项目详情" );
  666. string StrWhere = "";
  667. if ( this.panelDay.Visible )
  668. {
  669. string StrTime = this.numYear.Value + "-" + this.numMonth.Value + "-" + this.numDay.Value;
  670. StrWhere += PublicCodeClasses.GetDateTime( "日期", StrTime, StrTime, ConnectWord: "" );
  671. }
  672. else
  673. {
  674. StrWhere += PublicCodeClasses.GetDateTime( "日期", this.DateTimeStart, this.DateTimeEnd, ConnectWord: "" );
  675. }
  676. StrWhere += " And " + StrStoreWhere;
  677. DataTable tbl = orbll.GetView_Custom( "BView_FinanceReportDay_TotalPerformanceDetail", StrWhere: StrWhere, ShowColumnName: "项目名称,开单人,客户姓名,金额,日期,项目类别", filedOrder: "日期 Asc" ).Tables[0];
  678. this.dgvData.DataSource( tbl, strHideField: "" );
  679. this.dgvData.Columns["日期"].Width = 110;
  680. }
  681. else
  682. {
  683. this.IsCurrentShowTotalPerformance = false;
  684. this.lblTotalIncome.ForeColor = Color.DarkCyan;
  685. this.lblOperatingIncome.ForeColor = Color.DarkCyan;
  686. this.lblTotalPerformance.ForeColor = Color.DarkCyan;
  687. this.totip.SetToolTip( this.lblTotalPerformance, "点我查看总业绩详情" );
  688. this.cmbtreevSecondOption_ComboBoxTree_NodeMouseClick( this, null );
  689. }
  690. }
  691. /// <summary>
  692. /// 点击总收入或营业收入的查询事件
  693. /// </summary>
  694. /// <param name="StrSQL"></param>
  695. void TotalIncomeOrOperatingIncome_Click( string StrWhere )
  696. {
  697. string StrTableName = "";
  698. string StrColumns = "ID,Pay_Type,项目名称,接单人,客户姓名,金额,优惠金额,项目类别,收支,日期,付款方式,收银,审核,备注";
  699. StrTableName = "BView_FinanceReportDay_AllItems";
  700. if ( this.panelDay.Visible )
  701. {
  702. string StrTime = this.numYear.Value + "-" + this.numMonth.Value + "-" + this.numDay.Value;
  703. StrWhere += PublicCodeClasses.GetDateTime( "convert(datetime,日期)", StrTime, StrTime );
  704. }
  705. else
  706. {
  707. StrWhere += PublicCodeClasses.GetDateTime( "convert(datetime,日期)", this.DateTimeStart, this.DateTimeEnd );
  708. }
  709. StrWhere += " And " + StrStoreWhere;
  710. this.FinanceDayReportSmallForm_Load( this, null );
  711. LYFZ.ComponentLibrary.FrmLoadHandling.LoadDoWorkMethod( delegate ( object obj, BackgroundWorker backgroundWorker )
  712. {
  713. string ExecuteSql = orbll.GetView_CustomReturnExecuteSql( StrTableName, StrWhere: StrWhere, ShowColumnName: StrColumns, filedOrder: "日期" );
  714. DataSet dtSet = orbll.GetView_Custom( ExecuteSql );
  715. DataTable tbl = dtSet.Tables["ds"];
  716. //DataRow[] dtRow = tbl.Select("");
  717. try
  718. {
  719. this.Invoke( new LYFZ.Software.MainBusiness.DoorCityProcess.PublicCodeClasses.UpdateControl( delegate ()
  720. {
  721. //this.dgvData.DataSource(dtRow, IsClearRows: true);
  722. this.dgvData.DataSource( tbl, "ID,Pay_Type", IsClearRows: true );
  723. } ) );
  724. }
  725. catch
  726. {
  727. }
  728. } );
  729. }
  730. /// <summary>
  731. /// 订单数右键复制
  732. /// </summary>
  733. /// <param name="sender"></param>
  734. /// <param name="e"></param>
  735. void lblCount_MouseDown( object sender, MouseEventArgs e )
  736. {
  737. if ( e.Button == System.Windows.Forms.MouseButtons.Right )
  738. {
  739. ContextMenuStripEx conMenu = new ContextMenuStripEx();
  740. conMenu.ItemClicked += conMenu_ItemClicked;
  741. ToolStripMenuItem item = new ToolStripMenuItem();
  742. item.Text = "复制订单数";
  743. item.Tag = this.lblCount.Text.Trim();
  744. conMenu.Items.Add( item );
  745. // conMenu.Show();
  746. conMenu.Show( MousePosition.X, MousePosition.Y );//弹出操作菜单
  747. }
  748. }
  749. /// <summary>
  750. /// 财务统计右键复制
  751. /// </summary>
  752. /// <param name="sender"></param>
  753. /// <param name="e"></param>
  754. void lblFinancialSMS_MouseDown( object sender, MouseEventArgs e )
  755. {
  756. if ( e.Button == System.Windows.Forms.MouseButtons.Right )
  757. {
  758. ContextMenuStripEx conMenu = new ContextMenuStripEx();
  759. conMenu.ItemClicked += conMenu_ItemClicked;
  760. ToolStripMenuItem item = new ToolStripMenuItem();
  761. item.Text = "复制财务统计";
  762. item.Tag = this.lblFinancialSMS.Text.Trim();
  763. conMenu.Items.Add( item );
  764. // conMenu.Show();
  765. conMenu.Show( MousePosition.X, MousePosition.Y );//弹出操作菜单
  766. }
  767. }
  768. /// <summary>
  769. /// 支付方式右键复制
  770. /// </summary>
  771. /// <param name="sender"></param>
  772. /// <param name="e"></param>
  773. void lblPaymentMethodStatistics_MouseDown( object sender, MouseEventArgs e )
  774. {
  775. if ( e.Button == System.Windows.Forms.MouseButtons.Right )
  776. {
  777. ContextMenuStripEx conMenu = new ContextMenuStripEx();
  778. conMenu.ItemClicked += conMenu_ItemClicked;
  779. ToolStripMenuItem item = new ToolStripMenuItem();
  780. item.Text = "复制进帐方式";
  781. item.Tag = this.lblPaymentMethodStatistics.Text.Trim();
  782. conMenu.Items.Add( item );
  783. // conMenu.Show();
  784. conMenu.Show( MousePosition.X, MousePosition.Y );//弹出操作菜单
  785. }
  786. }
  787. /// <summary>
  788. /// 右键复制菜单
  789. /// </summary>
  790. /// <param name="sender"></param>
  791. /// <param name="e"></param>
  792. void conMenu_ItemClicked( object sender, ToolStripItemClickedEventArgs e )
  793. {
  794. ToolStripItem item = e.ClickedItem;
  795. if ( !string.IsNullOrEmpty( item.Text.Trim() ) && item.Tag != null )
  796. {
  797. Clipboard.SetDataObject( item.Tag );
  798. }
  799. }
  800. /// <summary>
  801. /// 审核
  802. /// </summary>
  803. /// <param name="sender"></param>
  804. /// <param name="e"></param>
  805. void btnAudit_Click( object sender, EventArgs e )
  806. {
  807. try
  808. {
  809. if ( this.dgvData.SelectedRows.Count == 0 )
  810. {
  811. MessageBoxCustom.Show( "请选择你要审核的数据!" );
  812. return;
  813. }
  814. if ( this.dgvData.SelectedRows.Count > 10 )
  815. {
  816. MessageBoxCustom.Show( "最多只能选择10条审核!" );
  817. return;
  818. }
  819. string StrAuditText = "";
  820. LYFZ.Software.MainBusiness.StatisticalInquiry.FinanceDayAuditTipsSetSmallForm frm = new FinanceDayAuditTipsSetSmallForm();
  821. DialogResult MesResult = frm.ShowDialog();
  822. if ( MesResult == System.Windows.Forms.DialogResult.Cancel )
  823. {
  824. return;
  825. }
  826. else if ( MesResult == System.Windows.Forms.DialogResult.Yes )
  827. {
  828. StrAuditText = "已审核";
  829. }
  830. else if ( MesResult == System.Windows.Forms.DialogResult.No )
  831. {
  832. StrAuditText = "审核不通过";
  833. }
  834. #region 审核
  835. if ( !string.IsNullOrEmpty( StrAuditText ) )
  836. {
  837. DateTime StrTime = DateTime.Now;
  838. string StrUserID = LYFZ.Software.MainBusiness.CommonLogical.SuccessfulLogin.LoginUserModel.User_EmployeeID;
  839. string StrUserName = LYFZ.Software.MainBusiness.CommonLogical.SuccessfulLogin.LoginUserModel.User_Name;
  840. List<Helper.CommandInfo> clist = new List<Helper.CommandInfo>();
  841. for ( int i = 0; i < dgvData.SelectedRows.Count; i++ )
  842. {
  843. string ItemCategory = this.dgvData.SelectedRows[i].Cells["项目类别"].Value.ToString().Trim();
  844. string ID = this.dgvData.SelectedRows[i].Cells["编号"].Value.ToString().Trim();
  845. switch ( this.dgvData.SelectedRows[i].Cells["Pay_Type"].Value.ToString().Trim() )
  846. {
  847. case "0":
  848. case "1":
  849. case "2":
  850. LYFZ.Model.Model_ErpPayment model3 = ptbll.GetModel( Convert.ToInt32( ID ) );
  851. model3.Pay_FinancialAudit = StrAuditText;
  852. model3.Pay_FinancialAuditdPeople = StrUserID;
  853. clist.Add( ptbll.GetUpdateCommandInfo( model3 ) );
  854. break;
  855. case "-1":
  856. if ( this.dgvData.SelectedRows[i].Cells["项目名称"].Value.ToString().Trim() == "储值取现" ||
  857. this.dgvData.SelectedRows[i].Cells["项目名称"].Value.ToString().Trim() == "充值定金退款" )
  858. {
  859. LYFZ.Model.Model_ErpMemberCardTakeCash model4 = mctkcbll.GetModel( Convert.ToInt32( ID ) );
  860. model4.Mctkc_AuditStatus = StrAuditText;
  861. model4.Mctkc_AuditDateTime = StrTime;
  862. model4.Mctkc_AuditName = StrUserID;
  863. model4.Mctkc_UpdateDateTime = StrTime;
  864. model4.Mctkc_UpdateName = StrUserID;
  865. clist.Add( mctkcbll.GetUpdateCommandInfo( model4 ) );
  866. }
  867. else
  868. {
  869. switch ( ItemCategory )
  870. {
  871. case "其它收入":
  872. case "店面支出":
  873. case "财务支出":
  874. LYFZ.Model.Model_ErpOtherIncomeAndExpenses model = oiebll.GetModel( Convert.ToInt32( ID ) );
  875. model.Oiae_FinancialAuditState = StrAuditText;
  876. model.Oiae_FinancialAuditPeople = StrUserID;
  877. clist.Add( oiebll.GetUpdateCommandInfo( model ) );
  878. break;
  879. case "会员充值":
  880. LYFZ.Model.Model_ErpMemberCardRechargeRecord model1 = mcrrbll.GetModel( Convert.ToInt32( ID ) );
  881. model1.Mcrr_FinancialAudit = StrAuditText;
  882. model1.Mcrr_FinancialAuditName = StrUserID;
  883. clist.Add( mcrrbll.GetUpdateCommandInfo( model1 ) );
  884. break;
  885. case "服务消费":
  886. LYFZ.Model.Model_ErpMemberCardPayment model2 = mcptbll.GetModel( Convert.ToInt32( ID ) );
  887. model2.Mcpt_FinancialAudit = StrAuditText;
  888. model2.Mcpt_FinancialAuditName = StrUserID;
  889. model2.Mcpt_FinancialAuditDateTime = StrTime;
  890. clist.Add( mcptbll.GetUpdateCommandInfo( model2 ) );
  891. break;
  892. case "会员返现":
  893. LYFZ.Model.Model_ErpMemberCardBackCashTakeCash model5 = bctcbll.GetModel( Convert.ToInt32( ID ) );
  894. model5.Mctc_CashAmountAudit = StrAuditText;
  895. model5.Mctc_CashAmountAuditName = StrUserID;
  896. model5.Mctc_CashAmountAuditDateTime = StrTime;
  897. clist.Add( bctcbll.GetUpdateCommandInfo( model5 ) );
  898. break;
  899. case "礼服退押金":
  900. LYFZ.Model.Model_ErpDressRefundRecord model6 = drrbll.GetModel( Convert.ToInt32( ID ) );
  901. model6.DRR_RefundAmountAudit = StrAuditText;
  902. model6.DRR_RefundAmountAuditName = StrUserID;
  903. model6.DRR_RefundAmountAuditDateTime = StrTime;
  904. clist.Add( drrbll.GetUpdateCommandInfo( model6 ) );
  905. break;
  906. case "礼服押金":
  907. LYFZ.Model.Model_ErpDressDepositReceivables model7 = ddrbll.GetModel( Convert.ToInt32( ID ) );
  908. model7.DDR_DepositAmountAudit = StrAuditText;
  909. model7.DDR_DepositAmountAuditName = StrUserID;
  910. model7.DDR_DepositAmountAuditDateTime = StrTime;
  911. clist.Add( ddrbll.GetUpdateCommandInfo( model7 ) );
  912. break;
  913. case "摄友会返还款":
  914. LYFZ.Model.Model_ErpMemberCardPhotographerMain model8 = mcpmbll.GetModel( Convert.ToInt32( ID ) );
  915. model8.Mcpm_OKBackAoumntAudit = StrAuditText;
  916. model8.Mcpm_OKBackAoumntAuditName = StrUserID;
  917. model8.Mcpm_OKBackAoumntAuditDateTime = StrTime;
  918. clist.Add( mcpmbll.GetUpdateCommandInfo( model8 ) );
  919. break;
  920. case "摄友会升级":
  921. LYFZ.Model.Model_ErpMemberCardPhotographerMain model9 = mcpmbll.GetModel( Convert.ToInt32( ID ) );
  922. model9.Mcpm_UpgradeAoumntAudit = StrAuditText;
  923. model9.Mcpm_UpgradeAoumntAuditName = StrUserID;
  924. model9.Mcpm_UpgradeAoumntAuditDateTime = StrTime;
  925. clist.Add( mcpmbll.GetUpdateCommandInfo( model9 ) );
  926. break;
  927. }
  928. }
  929. break;
  930. }
  931. }
  932. if ( clist.Count > 0 )
  933. {
  934. if ( LYFZ.BLL.BaseBllOperate.ExecuteSqlTran( clist ) <= 0 )
  935. {
  936. MessageBoxCustom.Show( "审核失败!" );
  937. return;
  938. }
  939. MessageBoxCustom.Show( "审核成功" );
  940. //for ( int i = 0; i < this.dgvData.SelectedRows.Count; i++ )
  941. for ( int i = this.dgvData.SelectedRows.Count - 1; i > -1; i-- )
  942. {
  943. string ItemCategory = this.dgvData.SelectedRows[i].Cells["项目类别"].Value.ToString().Trim();
  944. string ID = this.dgvData.SelectedRows[i].Cells["编号"].Value.ToString().Trim();
  945. switch ( this.dgvData.SelectedRows[i].Cells["Pay_Type"].Value.ToString().Trim() )
  946. {
  947. case "0":
  948. case "1":
  949. case "2":
  950. this.dgvData.SelectedRows[i].Cells["财务审核"].Value = StrAuditText + "/" + StrUserName;
  951. break;
  952. case "-1":
  953. switch ( ItemCategory )
  954. {
  955. case "其它收入":
  956. case "店面支出":
  957. case "财务支出":
  958. case "会员充值":
  959. case "服务消费":
  960. case "会员返现":
  961. case "礼服退押金":
  962. case "礼服押金":
  963. case "摄友会返还款":
  964. case "摄友会升级":
  965. this.dgvData.SelectedRows[i].Cells["财务审核"].Value = StrAuditText + "/" + StrUserName;
  966. break;
  967. }
  968. break;
  969. }
  970. if ( StrAuditText == "已审核" )
  971. {
  972. this.dgvData.SelectedRows[i].DefaultCellStyle.ForeColor = Color.Blue;
  973. if ( OnlyShowUnAudited == true )
  974. {
  975. // 删除这行;
  976. this.dgvData.Rows.RemoveAt( this.dgvData.SelectedRows[i].Index );
  977. }
  978. }
  979. else
  980. {
  981. this.dgvData.SelectedRows[i].DefaultCellStyle.ForeColor = Color.Red;
  982. }
  983. }
  984. }
  985. else
  986. {
  987. MessageBoxCustom.Show( "选中的数据中没有可审核的数据!" );
  988. }
  989. }
  990. #endregion
  991. }
  992. catch ( Exception ex )
  993. {
  994. MessageBoxCustom.Show( ex.Message );
  995. }
  996. }
  997. /// <summary>
  998. /// 导出
  999. /// </summary>
  1000. /// <param name="sender"></param>
  1001. /// <param name="e"></param>
  1002. void btnExport_Click( object sender, EventArgs e )
  1003. {
  1004. //LYFZ.BLL.BLL_SMSTemplates sssbll = new BLL.BLL_SMSTemplates();
  1005. //LYFZ.Model.Model_SMSTemplates modelaa = new Model.Model_SMSTemplates();
  1006. //DateTime strtime = Convert.ToDateTime(this.numYear.Value + "-" + this.numMonth.Value + "-" + this.numDay.Value);
  1007. //sssbll.GenerateFinancialSMS(storeID: LYFZ.Software.MainBusiness.CommonLogical.SuccessfulLogin.GetLocalCompanyInfoID(), date: strtime, tModel: null);
  1008. this.dgvData.ExportDataTable( StrFileName: this.Text.Trim() );
  1009. }
  1010. /// <summary>
  1011. /// 打印
  1012. /// </summary>
  1013. /// <param name="sender"></param>
  1014. /// <param name="e"></param>
  1015. void btnPrint_Click( object sender, EventArgs e )
  1016. {
  1017. try
  1018. {
  1019. string StrPrintType = "";
  1020. string StrTilte = "";
  1021. if ( IsCurrentShowTotalIncome )
  1022. {
  1023. StrTilte = "(总收入)";
  1024. }
  1025. else if ( IsCurrentShowOperatingIncome )
  1026. {
  1027. StrTilte = "(营业收入)";
  1028. }
  1029. if ( IsCurrentShowTotalPerformance )
  1030. {
  1031. StrTilte = "(总业绩)";
  1032. StrPrintType = "总业绩";
  1033. }
  1034. string StrDateWeek = "";
  1035. if ( this.panelDay.Visible )
  1036. {
  1037. string time = Convert.ToDateTime( this.numYear.Value + "-" + this.numMonth.Value + "-" + this.numDay.Value ).ToString( "yyyy-MM-dd" );
  1038. StrDateWeek = time + "(" + LYFZ.Software.MainBusiness.DoorCityProcess.PublicCodeClasses.CaculateWeekDay( Convert.ToDateTime( time ).DayOfWeek.ToString() ) + ")";
  1039. }
  1040. else
  1041. {
  1042. StrDateWeek = this.DateTimeStart.Replace( "-", "." ) + "-" + this.DateTimeEnd.Replace( "-", "." );
  1043. }
  1044. string StrItemText = "项目统计:总业绩:" + this.txtTotalPerformance.Text.Trim() + " 总收入:" + this.txtTotalIncome.Text.Trim() + " 营业收入:" + this.txtOperatingIncome.Text.Trim() + " 支出:" + this.txtTotalOutlay.Text.Trim();
  1045. if ( IsFinancialOutlay )
  1046. {
  1047. StrItemText += " 净收入:" + this.txtNetIncome.Text.Trim();
  1048. }
  1049. StrItemText += " 订单前期:" + this.txtOrderEarly.Text.Trim() + " 订单后期:" + this.txtOrderLate.Text.Trim() + " 总押金:" + this.txtTotalDeposit.Text.Trim() +
  1050. " 总欠款:" + this.txtTotalArrears.Text.Trim() + " 代金券:" + this.txtVoucher.Text.Trim();
  1051. object StrText = StrItemText + "\r\n" + this.lblFinancialSMS.Text.Trim() + "\r\n" + this.lblPaymentMethodStatistics.Text.Trim() + "\r\n" + this.labSettlement.Text.Trim() + "\r\n" + this.lblCount.Text.Trim();
  1052. Hashtable htData = new Hashtable();
  1053. htData["dgvData"] = this.dgvData;
  1054. htData["StrText"] = StrText;
  1055. htData["StrDateWeek"] = StrDateWeek;
  1056. htData["IsPrintType"] = StrPrintType;
  1057. htData["StrTilte"] = StrTilte;
  1058. LYFZ.Software.MainBusiness.ReportPrint.ReportFixedFormat.PrintFixedFormat( EnumPublic.PrintTypeEnum.财务报表日, htData );
  1059. }
  1060. catch ( Exception ex )
  1061. {
  1062. MessageBoxCustom.Show( ex.Message );
  1063. }
  1064. }
  1065. /// <summary>
  1066. /// 关闭
  1067. /// </summary>
  1068. /// <param name="sender"></param>
  1069. /// <param name="e"></param>
  1070. void btnClose_Click( object sender, EventArgs e )
  1071. {
  1072. this.Close();
  1073. }
  1074. /// <summary>
  1075. /// 窗体大小发生变化
  1076. /// </summary>
  1077. /// <param name="sender"></param>
  1078. /// <param name="e"></param>
  1079. void FinanceDayReportSmallForm_Resize( object sender, EventArgs e )
  1080. {
  1081. int LocationY = 0;
  1082. if ( this.panelOrderType.Visible )
  1083. {
  1084. LocationY = this.panelOrderType.Location.Y;
  1085. }
  1086. else
  1087. {
  1088. LocationY = this.panelStoreName.Location.Y;
  1089. }
  1090. switch ( LocationY )
  1091. {
  1092. case 0:
  1093. this.flowLayoutPanel1.Height = 28;
  1094. break;
  1095. case 27:
  1096. this.flowLayoutPanel1.Height = 55;
  1097. break;
  1098. case 54:
  1099. this.flowLayoutPanel1.Height = 82;
  1100. break;
  1101. case 81:
  1102. this.flowLayoutPanel1.Height = 109;
  1103. break;
  1104. }
  1105. this.panelEx2.Height = this.flowLayoutPanel1.Height + 89;
  1106. }
  1107. /// <summary>
  1108. /// 列表添加行时发生事件
  1109. /// </summary>
  1110. /// <param name="sender"></param>
  1111. /// <param name="e"></param>
  1112. void dgvData_RowsAdded( object sender, DataGridViewRowsAddedEventArgs e )
  1113. {
  1114. if ( this.dgvData.Rows[e.RowIndex].Cells["日期"].Value.ToString().Trim() != "" )
  1115. {
  1116. this.dgvData.Rows[e.RowIndex].Cells["日期"].Value = LYFZ.Command.Command_Validate.DateTimeToString( this.dgvData.Rows[e.RowIndex].Cells["日期"].Value, "yyyy-MM-dd HH:mm" );
  1117. }
  1118. }
  1119. /// <summary>
  1120. /// 双击查看详情
  1121. /// </summary>
  1122. /// <param name="sender"></param>
  1123. /// <param name="e"></param>
  1124. void dgvData_CellMouseDoubleClick( object sender, DataGridViewCellMouseEventArgs e )
  1125. {
  1126. if ( e.RowIndex >= 0 && e.ColumnIndex >= 0 )
  1127. {
  1128. try
  1129. {
  1130. LYFZ.Software.MainBusiness.DoorCityProcess.PublicCodeClasses.FinanceDayRowsDoubleClick( this.dgvData.Rows[e.RowIndex].Cells["编号"].Value.ToString().Trim(), this.dgvData.Rows[e.RowIndex].Cells["Pay_Type"].Value.ToString().Trim() );
  1131. }
  1132. catch
  1133. {
  1134. MessageBoxCustom.Show( "此项目不支持查看详情" );
  1135. }
  1136. }
  1137. }
  1138. }
  1139. }