⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 checkperform.aspx.cs

📁 基于.net(c#+sql)人事管理系统
💻 CS
字号:
using System;
using System.Configuration;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
using DBUtils;

namespace BlueHill.Performance
{
	/// <summary>
	/// CheckPerform 的摘要说明。
	/// </summary>
	public class CheckPerform : System.Web.UI.Page
	{
		protected System.Web.UI.WebControls.Label lblMessage;
		protected System.Web.UI.WebControls.Label lblDeptID;
		protected System.Web.UI.WebControls.Label lblYear;
		protected System.Web.UI.WebControls.Label lblSeason;
		protected System.Web.UI.WebControls.Label lblNoResult;
		protected System.Web.UI.WebControls.Button btnPrev;
		protected System.Web.UI.WebControls.Button btnNext;
		protected System.Web.UI.WebControls.DataGrid grdResult;
		protected System.Web.UI.WebControls.Panel pnlHeader;
	
		/// <summary>
		/// 网页初始化时执行该方法。
		/// </summary>
		/// <param name="sender"></param>
		/// <param name="e"></param>
		private void Page_Load(object sender, System.EventArgs e)
		{
			// 在此处放置用户代码以初始化页面
			if ( !IsPostBack )
			{
				//如果网页是第一次生成时,执行如下操作:
        
				//设置界面控件的显示方式。
				grdResult.Visible = false;
				pnlHeader.Visible = false;

				Employee emp = new Employee();
				int iEmpID;

				//检查员工的登录信息是否丢失,是则显示出错信息。
				if ( Session["EmployeeID"] == null )
				{
					lblMessage.Text = "登录信息丢失,请重新登录!";
					return;
				}

				//获取保存在 Session 中的员工编号信息。
				iEmpID = int.Parse ((string)(Session["EmployeeID"]));

				//从数据库中获取员工的其他信息。
				Employee.GetEmployeeInfo(iEmpID, emp);

				//如果员工不是部门经理,则显示出错信息。
				if ( !emp.IsManager )
				{
					lblMessage.Text = "对不起,该网页属经理专用,请退出!";
					return;
				}

				//从数据库中获取总经理的员工编号。
				int iCEOID = 0;
				Employee.GetCEOInfo(ref iCEOID);

				//如果登录用户为总经理,则提示没有可查看的信息。
				if ( iEmpID == iCEOID )
				{
					lblMessage.Text = "对不起,没有您要查看的信息!";
					return;
				}

				if ( Request["Year"] == null )
				{
					//如果网页的 URL 中不含有年份信息,则使用当前年份和季度。
					lblYear.Text = DateTime.Now.Year.ToString();
					lblSeason.Text = ((DateTime.Now.Month + 2) / 3).ToString();
				}
				else
				{
					//如果网页的 URL 中已指定了年份和季度信息,则使用该信息。
					lblYear.Text =(string) Request["Year"];
					lblSeason.Text = (string) Request["Season"];
				}

				pnlHeader.Visible = true;

				//保存部门编号。
				lblDeptID.Text = emp.DeptID.ToString();

				//借用 RefreshPage 方法,设置网页其他控件的显示内容和方式。
				RefreshPage();

			}
		}
		/// <summary>
		/// 该方法根据网页中的年份和季度等信息,设置界面控件的显示内容和方式。
		/// </summary>
		/// <param name="e"></param>
		
		void RefreshPage()
		{

			DataSet dsResult = new DataSet();
			int iYear, iSeason, iDeptID;

			//获取网页中以前保存的年份、季度和部门编号。
			iYear = int.Parse(lblYear.Text);
			iSeason = int.Parse(lblSeason.Text);
			iDeptID = int.Parse(lblDeptID.Text);

			//从 Web.Config 文件中读取公司的起始年份。
			int iStartYear;
			iStartYear = int.Parse(ConfigurationSettings.AppSettings["StartYear"]);

			if ( iYear == iStartYear && iSeason == 1 )
			{
				//如果当前季度为公司起始年份的第一个季度,则应禁用“上一季度”按钮。
				btnPrev.Enabled = false;
			}
			else
			{
				//否则启用该按钮。
				btnPrev.Enabled = true;
			}

			if ( iYear == DateTime.Now.Year && iSeason ==(int)((DateTime.Now.Month + 2) / 3) )
			{
				//如果当前季度为现在,则应禁用“下一季度”按钮。
				btnNext.Enabled = false;
			}
			else
			{
				//否则启用该按钮。
				btnNext.Enabled = true;
			}

			//从数据库中获取该部门该季度的业绩汇总信息。
			DBUtils.Performance.GetSubmittedPerform(iDeptID, iYear, iSeason, ref dsResult);

			if ( dsResult.Tables[0].Rows.Count > 0 )
			{
				//找到了要审批的记录
				DataView dv = new DataView(dsResult.Tables[0]);

				dv.Sort = "PerformID Asc";
				grdResult.DataSource = dv;
				grdResult.DataBind();
				grdResult.Visible = true;
				lblNoResult.Visible = false;
			}
			else
			{
				//没有找到任何记录
				grdResult.Visible = false;
				lblNoResult.Visible = true;
				return;
			}
		}

		#region Web 窗体设计器生成的代码
		override protected void OnInit(EventArgs e)
		{
			//
			// CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
			//
			InitializeComponent();
			base.OnInit(e);
		}
		
		/// <summary>
		/// 设计器支持所需的方法 - 不要使用代码编辑器修改
		/// 此方法的内容。
		/// </summary>
		private void InitializeComponent()
		{    
			this.btnPrev.Click += new System.EventHandler(this.btnPrev_Click);
			this.btnNext.Click += new System.EventHandler(this.btnNext_Click);
			this.grdResult.ItemCommand += new System.Web.UI.WebControls.DataGridCommandEventHandler(this.grdResult_ItemCommand);
			this.Load += new System.EventHandler(this.Page_Load);

		}
		#endregion

		/// <summary>
		/// 当用户单击“上一季度”按钮时,该方法刷新界面的显示内容。
		/// </summary>
		/// <param name="sender"></param>
		/// <param name="e"></param>
		private void btnPrev_Click(object sender, System.EventArgs e)
		{
			int iYear, iSeason;
			int iStartYear;

			//从 Web.Config 文件中读取公司的起始年份。
			iStartYear = int.Parse(ConfigurationSettings.AppSettings["StartYear"]);

			//获取当前季度和年份信息,并将季度数目减一。
			iYear = int.Parse(lblYear.Text);
			iSeason = int.Parse(lblSeason.Text) - 1;

			//如果季度为0,则应调整为上一年的最后一个季度。
			if ( iSeason == 0 )
			{
				iSeason = 4;
				iYear -= 1;
			}

			//保存更新后的年份和季度。
			lblYear.Text = iYear.ToString();
			lblSeason.Text = iSeason.ToString();

			//根据新的年份和季度信息刷新界面的显示内容。
			RefreshPage();
		}

		/// <summary>
		/// 当用户单击“下一季度”按钮时,该方法刷新界面的显示内容。
		/// </summary>
		/// <param name="sender"></param>
		/// <param name="e"></param>
		private void btnNext_Click(object sender, System.EventArgs e)
		{
			int iYear, iSeason;
			int iStartYear;

			//从 Web.Config 文件中读取公司的起始年份。
			iStartYear = int.Parse(ConfigurationSettings.AppSettings["StartYear"]);

			//获取当前季度和年份信息,并将季度数目加一。
			iYear = int.Parse(lblYear.Text);
			iSeason = int.Parse(lblSeason.Text) + 1;

			//如果季度为 5,则应调整为下一年的第一个季度。
			if ( iSeason == 5 )
			{
				iSeason = 1;
				iYear += 1;
			}

			//保存更新后的年份和季度。
			lblYear.Text = iYear.ToString();
			lblSeason.Text = iSeason.ToString();

			//根据新的年份和季度信息刷新界面的显示内容。
			RefreshPage();
		}
		/// <summary>
		/// 当用户单击“审核”按钮时,该方法将网页跳转到业绩报告详细页面上去。
		/// </summary>
		/// <param name="source"></param>
		/// <param name="e"></param>
		private void grdResult_ItemCommand(object source, System.Web.UI.WebControls.DataGridCommandEventArgs e)
		{
			//判定用户是否单击了“审核”按钮。
			if ( e.CommandName == "Check" ) 
			{

				int iEmpID, iYear, iSeason;
				
				//根据用户单击的记录,获取该记录相应的员工编号。
				iEmpID = int.Parse(e.Item.Cells[1].Text);

				//获取当前季度和年份信息。
				iYear = int.Parse(lblYear.Text);
				iSeason = int.Parse(lblSeason.Text);

				//将网页跳转到业绩报告详细页面,并指定年份和季度等附加信息。
				Response.Redirect("ShowDetail.aspx?EmpID=" + iEmpID + "&Year=" + iYear + "&Season=" + iSeason);
			}
		}

		
	}
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -