using System;
using System.Collections.Generic;
using System.Linq;
using System.Data;
using System.Data.SqlClient;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using BLL;

namespace FineUIPro.Web.common.SysManage
{
    public partial class UpdatePassword : PageBase
    {
        protected void Page_Load(object sender, EventArgs e)
        {
            if (!IsPostBack)
            {
                BLL.Base_UnitService.InitUnitDropDownList(drpUnit, true, null,Resources.Lan.PleaseSelect);
                ddlPageSize.SelectedValue = Grid1.PageSize.ToString();
                if (this.CurrUser.UserId != Const.GlyId)
                {
                    txtUserName.Hidden = true;
                    drpUnit.Hidden = true;
                    btnQuery.Hidden = true;
                }
                // 绑定表格
                BindGrid();
            }
        }


        /// <summary>
        /// 绑定数据
        /// </summary>
        private void BindGrid()
        {
            string strSql = @"SELECT u.UserId,u.Account,u.UserCode,u.UserName,u.IsPost,u.RoleIds,un.UnitName
                                FROM dbo.Sys_User u
                                     LEFT JOIN dbo.Base_Unit un ON un.UnitId = u.UnitId
                                where 1=1";

            List<SqlParameter> parms = new List<SqlParameter>();
            if (this.CurrUser.Account != BLL.Const.Gly)
            {
                strSql += " and u.Account = @Account";
            }
            
            parms.Add(new SqlParameter("@Account", this.CurrUser.Account));

            if (!string.IsNullOrEmpty(this.txtUserName.Text))
            {
                strSql += " and u.UserName LIKE  @UserName";
                parms.Add(new SqlParameter("@UserName", "%" + this.txtUserName.Text.Trim() + "%"));
            }
            if (this.drpUnit.SelectedValue != Const._Null)
            {
                strSql += " and u.UnitId = @UnitId";
                parms.Add(new SqlParameter("@UnitId", this.drpUnit.SelectedValue));
            }
            SqlParameter[] parameter = parms.ToArray();
            DataTable dt = SQLHelper.GetDataTableRunText(strSql, parameter);

            // 2.获取当前分页数据
            Grid1.RecordCount = dt.Rows.Count;
            var table = this.GetPagedDataTable(Grid1, dt);
            Grid1.DataSource = table;
            Grid1.DataBind();
        }

        /// <summary>
        /// 查询
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        protected void btnQuery_Click(object sender, EventArgs e)
        {
            this.BindGrid();
        }


        #region 分页
        /// <summary>
        /// 分页
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        protected void Grid1_PageIndexChange(object sender, GridPageEventArgs e)
        {
            Grid1.PageIndex = e.NewPageIndex;
            BindGrid();
        }

        /// <summary>
        /// 分页显示条数下拉框
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        protected void ddlPageSize_SelectedIndexChanged(object sender, EventArgs e)
        {
            Grid1.PageSize = Convert.ToInt32(ddlPageSize.SelectedValue);
            BindGrid();
        }
        #endregion

        /// <summary>
        /// 排序
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        protected void Grid1_Sort(object sender, FineUIPro.GridSortEventArgs e)
        {
            Grid1.SortDirection = e.SortDirection;
            Grid1.SortField = e.SortField;
            BindGrid();
        }

        /// <summary>
        /// 关闭窗口
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        protected void Window1_Close(object sender, EventArgs e)
        {
            BindGrid();
        }

        #region  重置密码
        /// <summary>
        /// 批量删除数据
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        protected void btnRefresh_Click(object sender, EventArgs e)
        {
            if (Grid1.SelectedRowIndexArray.Length > 0)
            {
                foreach (int rowIndex in Grid1.SelectedRowIndexArray)
                {
                    string rowID = Grid1.DataKeys[rowIndex][0].ToString();
                    BLL.Sys_UserService.UpdatePassword(rowID, "abc.1234");
                }
                BindGrid();
                //BLL.Sys_LogService.AddLog(BLL.Const.System_1, this.CurrUser.LoginProjectId, this.CurrUser.UserId, "重置密码");
                ShowNotify("密码已重置为初始密码!");
            }
            else
            {
                ShowNotify("请至少选中一行!");
            }
        }
        #endregion

        /// <summary>
        /// 编辑
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        protected void btnEdit_Click(object sender, EventArgs e)
        {
            if (Grid1.SelectedRowIndexArray.Length == 0)
            {
                Alert.ShowInParent("请至少选择一条记录!");
                return;
            }
            string Id = Grid1.SelectedRowID;
            PageContext.RegisterStartupScript(Window1.GetShowReference(String.Format("UpdatePasswordEdit.aspx?userId={0}", Id, "编辑 - ")));
        }

        /// <summary>
        /// Grid行双击事件
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        protected void Grid1_RowDoubleClick(object sender, GridRowClickEventArgs e)
        {
            btnEdit_Click(null, null);
        }

        #region 格式化字符串
        /// <summary>
        /// 转换热处理类型
        /// </summary>
        /// <param name="pt"></param>
        /// <returns></returns>
        protected string ConvertRoleName(object roleIds)
        {
            string roleNames = string.Empty;
            if (roleIds != null)
            {
                string[] roles = roleIds.ToString().Split('|');
                foreach (string r in roles)
                {
                    var q = BLL.Sys_RoleService.GetRole(r);
                    if (q != null)
                    {
                        roleNames = roleNames + q.RoleName + ",";
                    }
                }
            }
            if (roleNames.Length > 0)
            {
                roleNames = roleNames.Substring(0, roleNames.Length - 1);
            }
            return roleNames;
        }
        #endregion

    }
}