using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
namespace LYFZ.Software.MainBusiness.StatisticalInquiry.SatisfactionReport
{
public partial class FrmSatisfactionSeeDetails : LYFZ.Software.UI.StatisticalInquiry.SatisfactionReport.FrmSatisfactionSeeDetails
{
LYFZ.BLL.BLL_ErpOrder orbll = new LYFZ.BLL.BLL_ErpOrder();
LYFZ.BLL.BLL_ErpSatisfactionSurvey Surveybll = new BLL.BLL_ErpSatisfactionSurvey();
LYFZ.BLL.BLL_ErpSatisfactionRatingSet srsbll = new BLL.BLL_ErpSatisfactionRatingSet();
LYFZ.BLL.BLL_ErpSatisfactionSurveySet setbll = new BLL.BLL_ErpSatisfactionSurveySet();
LYFZ.BLL.BLL_ErpSatisfactionReturningMattersSet sfrmbll = new BLL.BLL_ErpSatisfactionReturningMattersSet();
public FrmSatisfactionSeeDetails()
{
this.Load += FrmSatisfactionSeeDetails_Load;
this.Shown += FrmSatisfactionSeeDetails_Shown;
this.btnSelect.Click += btnSelect_Click;
this.btnClose.Click += btnClose_Click;
}
public string TimeStar;
public string TimeEnd;
public string PersonnelNumber;
public string PersonnelName;
///
/// 窗体加载事件
///
///
///
void FrmSatisfactionSeeDetails_Load(object sender, EventArgs e)
{
this.Location = new Point(LYFZ.EnumPublic.FormLocation_X, LYFZ.EnumPublic.FormLocation_Y);
this.Size = new Size(LYFZ.EnumPublic.FormSize_Width, LYFZ.EnumPublic.FormSize_Height);
}
///
/// 窗体加载事件
///
///
///
void FrmSatisfactionSeeDetails_Shown(object sender, EventArgs e)
{
DataTable dt = orbll.GetView_Custom("tb_ErpSatisfactionRatingSet", StrWhere: "", ShowColumnName: "Sfrs_Name", filedOrder: "ID").Tables[0];
string StrColumnName = "人员ID,服务人员";
for (int i = 0; i < dt.Rows.Count; i++)
{ StrColumnName += "," + dt.Rows[i]["Sfrs_Name"].ToString().Trim(); }
StrColumnName += ",总满意程度分值,总满意程度";
this.dgvData2.DataColumns(StrColumnName, strHideField: "人员ID");
this.BindReturningItems();
this.BindScores();
this.PublicFunctionRows();
this.PublicFunctionRows2();
}
///
/// 查询
///
///
///
void btnSelect_Click(object sender, EventArgs e)
{
this.PublicFunctionRows2();
this.PublicFunctionRows();
}
///
/// 关闭
///
///
///
void btnClose_Click(object sender, EventArgs e)
{
this.Close();
}
///
/// 获取回访事项
///
void BindReturningItems()
{
DataTable tbl = orbll.GetView_Custom("tb_ErpSatisfactionSurveySet", StrWhere: "", ShowColumnName: "ID,Sfss_Name", filedOrder: "ID").Tables[0];
if (tbl.Rows.Count > 0)
{
TreeNode root = null;
for (int i = 0; i < tbl.Rows.Count; i++)
{
if (i == 0)
{
root = new TreeNode();
root.Text = "全部";
root.Tag = "0";
root.Tag = "All";
this.cmbReturningItems.TreeView.Nodes.Add(root);
}
root = new TreeNode();
root.Text = tbl.Rows[i]["Sfss_Name"].ToString().Trim();
root.Tag = tbl.Rows[i]["ID"].ToString().Trim();
root.Name = "Max";
this.CreateTreeReturningItems(root.Nodes, tbl.Rows[i]["ID"].ToString().Trim());
this.cmbReturningItems.TreeView.Nodes.Add(root);
}
}
}
///
/// 绑定第二级人员
///
/// TreeView的节点集合
/// 数据源
///
void CreateTreeReturningItems(TreeNodeCollection nodes, string ClassCode)
{
if (ClassCode != "")
{
DataTable tbl = sfrmbll.GetList("Sfrms_EnableStatus = 0 and Sfrms_SurveySetID = " + ClassCode + "").Tables[0];
if (tbl.Rows.Count > 0)
{
TreeNode node;
for (int i = 0; i < tbl.Rows.Count; i++)
{
node = new TreeNode();
node.Text = tbl.Rows[i]["Sfrms_Contents"].ToString().Trim();
node.Tag = tbl.Rows[i]["ID"].ToString().Trim();
node.Name = "Min";
nodes.Add(node);
}
}
}
}
///
/// 获取单项满意度
///
void BindScores()
{
DataTable dt = orbll.GetView_Custom("tb_ErpSatisfactionRatingSet", StrWhere: "", ShowColumnName: "ID,Sfrs_Name", filedOrder: "ID").Tables[0];
cmbScores.DataSource = dt;
cmbScores.ValueMember = "ID";
cmbScores.DisplayMember = "Sfrs_Name";
DataRow dr = dt.NewRow();
dr["ID"] = "-1";
dr["Sfrs_Name"] = "";
dt.Rows.InsertAt(dr, 0);
cmbScores.SelectedIndex = -1;
}
///
/// 画分页
///
///
///
void PublicFunctionRows()
{
this.dgvData.Rows.Clear();
string StrWhere = " Where Sfs_EmployeeID='" + this.PersonnelNumber + "'";
if (!string.IsNullOrEmpty(this.TimeStar) && !string.IsNullOrEmpty(this.TimeEnd))
{ StrWhere += LYFZ.Software.MainBusiness.DoorCityProcess.PublicCodeClasses.GetDateTime("Sfs_CreateTime", this.TimeStar, this.TimeEnd); }
if (this.cmbReturningItems.Tag != null && this.cmbReturningItems.Text.Trim().Length > 0 && this.cmbReturningItems.Text.Trim() != "全部")
{
switch (this.cmbReturningItems.StrGetName.Trim())
{
case "Max":
StrWhere += " And Sfs_SurveySetID = " + this.cmbReturningItems.Tag.ToString().Trim();
break;
case "Min":
StrWhere += " And Sfs_ReturningMattersSetID = " + this.cmbReturningItems.Tag.ToString().Trim();
break;
}
}
if (this.cmbScores.Text.Trim().Length > 0)
{ StrWhere += " And Sfs_RatingSetID = " + this.cmbScores.SelectedValue.ToString(); }
DataTable newTable = new DataTable();
LYFZ.ComponentLibrary.FrmLoadHandling.LoadDoWorkMethod(delegate(object obj, BackgroundWorker backgroundWorker)
{
string StrTableName = "SELECT Sfs_OrderNumber AS 订单号," +
"Cus_Name AS 客户姓名," +
"Cus_Telephone AS 客户电话," +
"Ords_PhotographMaxTime as 拍照时间," +
"Sfs_EmployeeID AS 调查对象," +
"Sfss_Name AS 回访对象," +
"Sfrms_Contents AS 回访事项," +
"Sfrs_Name AS 满意度," +
"isnull(Sfrs_Scores, 0) AS 满意分值," +
"Sfs_Remark AS 备注," +
"Sfs_CreateName AS 回访人," +
"Sfs_CreateTime AS 回访时间 " +
"FROM tb_ErpSatisfactionSurvey " +
"left join tb_ErpSatisfactionSurveySet on Sfs_SurveySetID = tb_ErpSatisfactionSurveySet.ID " +
"left join tb_ErpSatisfactionReturningMattersSet on tb_ErpSatisfactionReturningMattersSet.ID = Sfs_ReturningMattersSetID " +
"left join tb_ErpSatisfactionRatingSet on Sfs_RatingSetID = tb_ErpSatisfactionRatingSet.ID " +
"Left Join tempTB_AggregationCustomer on GP_OrderNumber = Sfs_OrderNumber " +
"left join tb_ErpOrderDigitalStatus on tempTB_AggregationCustomer.GP_OrderNumber = tb_ErpOrderDigitalStatus.Ords_OrdNumber and "+
" tb_ErpSatisfactionSurvey.Sfs_OrderNumberDeputy=tb_ErpOrderDigitalStatus.Ords_ViceNumber" +
StrWhere+
" order by Sfs_CreateTime asc ";
newTable = orbll.GetView_Custom(StrTableName).Tables[0];
});
#region
this.dgvData.DataColumns(newTable.Columns, strHideField: "");
this.dgvData.Columns["客户姓名"].Width = 150;
this.dgvData.Columns["客户电话"].Width = 180;
this.dgvData.Columns["回访时间"].Width = 120;
this.dgvData.Columns["回访事项"].Width = 350;
this.dgvData.FillLastColumn();
for (int t = 0; t < newTable.Rows.Count; t++)
{
DataGridViewRow dgvr = new DataGridViewRow();
DataGridViewCell cell = null;
cell = new DataGridViewTextBoxCell();
cell.Value = newTable.Rows[t]["订单号"].ToString().Trim();
dgvr.Cells.Add(cell);
cell = new DataGridViewTextBoxCell();
cell.Value = newTable.Rows[t]["客户姓名"].ToString().Trim();
dgvr.Cells.Add(cell);
cell = new DataGridViewTextBoxCell();
cell.Value = newTable.Rows[t]["客户电话"].ToString().Trim();
dgvr.Cells.Add(cell);
cell = new DataGridViewTextBoxCell();
cell.Value = newTable.Rows[t]["拍照时间"].ToString().Trim();
dgvr.Cells.Add(cell);
cell = new DataGridViewTextBoxCell();
cell.Value = LYFZ.Software.MainBusiness.DoorCityProcess.PublicCodeClasses.GetUserName(newTable.Rows[t]["调查对象"]);
dgvr.Cells.Add(cell);
cell = new DataGridViewTextBoxCell();
cell.Value = newTable.Rows[t]["回访对象"].ToString().Trim();
dgvr.Cells.Add(cell);
cell = new DataGridViewTextBoxCell();
cell.Value = newTable.Rows[t]["回访事项"].ToString().Trim();
dgvr.Cells.Add(cell);
cell = new DataGridViewTextBoxCell();
cell.Value = newTable.Rows[t]["满意度"].ToString().Trim();
dgvr.Cells.Add(cell);
cell = new DataGridViewTextBoxCell();
cell.Value = newTable.Rows[t]["满意分值"].ToString();
dgvr.Cells.Add(cell);
cell = new DataGridViewTextBoxCell();
cell.Value = newTable.Rows[t]["备注"].ToString().Trim();
dgvr.Cells.Add(cell);
cell = new DataGridViewTextBoxCell();
cell.Value = LYFZ.Software.MainBusiness.DoorCityProcess.PublicCodeClasses.GetUserName(newTable.Rows[t]["回访人"]);
dgvr.Cells.Add(cell);
cell = new DataGridViewTextBoxCell();
cell.Value = LYFZ.BLL.OtherCommonModel.DateTimeToString(newTable.Rows[t]["回访时间"]);
dgvr.Cells.Add(cell);
this.dgvData.Rows.Add(dgvr);
}
this.dgvData.ClearSelection();
#endregion
}
///
/// 获取人员查询满意度
///
void PublicFunctionRows2()
{
dgvData2.Rows.Clear();
DataTable dt = new DataTable();
string StrWhere = " Sfs_EmployeeID='" + PersonnelNumber + "'" + LYFZ.Software.MainBusiness.DoorCityProcess.PublicCodeClasses.GetDateTime("Sfs_CreateTime", this.TimeStar, this.TimeEnd);
if (this.cmbReturningItems.Tag != null && this.cmbReturningItems.Text.Trim().Length > 0 && this.cmbReturningItems.Text.Trim() != "全部")
{
switch (this.cmbReturningItems.StrGetName.Trim())
{
case "Max":
StrWhere += " And Sfs_SurveySetID = " + this.cmbReturningItems.Tag.ToString().Trim();
break;
case "Min":
StrWhere += " And Sfs_ReturningMattersSetID = " + this.cmbReturningItems.Tag.ToString().Trim();
break;
}
}
if (this.cmbScores.Text.Trim().Length > 0)
{ StrWhere += " And Sfs_RatingSetID = " + this.cmbScores.SelectedValue.ToString(); }
DataTable newTable2 = orbll.GetView_Custom("select Sfs_RatingSetID,Count(Sfs_EmployeeID) AS CountID,Sum(Sfrs_Scores) AS Sfrs_Scores from tb_ErpSatisfactionSurvey Left Join tb_ErpSatisfactionRatingSet on Sfs_RatingSetID=tb_ErpSatisfactionRatingSet.ID Where " + StrWhere + " Group By Sfs_RatingSetID").Tables[0];
newTable2.PrimaryKey = new DataColumn[] { newTable2.Columns["Sfs_RatingSetID"] };
#region
DataGridViewRow dgvr = new DataGridViewRow();
DataGridViewCell cell = null;
cell = new DataGridViewTextBoxCell();
cell.Value = PersonnelNumber;
dgvr.Cells.Add(cell);
cell = new DataGridViewTextBoxCell();
cell.Value = PersonnelName;
dgvr.Cells.Add(cell);
cell = new DataGridViewTextBoxCell();
decimal decScores = 0;
int intScores = 0;
DataRow dtRow1 = newTable2.Rows.Find("1");
if (dtRow1 != null)
{
cell.Value = dtRow1["CountID"].ToString().Trim();
intScores += Convert.ToInt32(dtRow1["CountID"]);
decScores += Convert.ToDecimal(dtRow1["Sfrs_Scores"]);
}
else
{ cell.Value = 0; }
dgvr.Cells.Add(cell);
cell = new DataGridViewTextBoxCell();
DataRow dtRow2 = newTable2.Rows.Find("2");
if (dtRow2 != null)
{
cell.Value = dtRow2["CountID"].ToString().Trim();
intScores += Convert.ToInt32(dtRow2["CountID"]);
decScores += Convert.ToDecimal(dtRow2["Sfrs_Scores"]);
}
else
{ cell.Value = 0; }
dgvr.Cells.Add(cell);
cell = new DataGridViewTextBoxCell();
DataRow dtRow3 = newTable2.Rows.Find("3");
if (dtRow3 != null)
{
cell.Value = dtRow3["CountID"].ToString().Trim();
intScores += Convert.ToInt32(dtRow3["CountID"]);
decScores += Convert.ToDecimal(dtRow3["Sfrs_Scores"]);
}
else
{ cell.Value = 0; }
dgvr.Cells.Add(cell);
cell = new DataGridViewTextBoxCell();
DataRow dtRow4 = newTable2.Rows.Find("4");
if (dtRow4 != null)
{
cell.Value = dtRow4["CountID"].ToString().Trim();
intScores += Convert.ToInt32(dtRow4["CountID"]);
decScores += Convert.ToDecimal(dtRow4["Sfrs_Scores"]);
}
else
{ cell.Value = 0; }
dgvr.Cells.Add(cell);
cell = new DataGridViewTextBoxCell();
DataRow dtRow5 = newTable2.Rows.Find("5");
if (dtRow5 != null)
{
cell.Value = dtRow5["CountID"].ToString().Trim();
intScores += Convert.ToInt32(dtRow5["CountID"]);
decScores += Convert.ToDecimal(dtRow5["Sfrs_Scores"]);
}
else
{ cell.Value = 0; }
dgvr.Cells.Add(cell);
//总满意程度分值
string Sfrs_Scores = "0";
cell = new DataGridViewTextBoxCell();
if (intScores > 0)
{ Sfrs_Scores = LYFZ.BLL.OtherCommonModel.RemoveLastExcessZero(decScores / intScores); }
cell.Value = Sfrs_Scores;
dgvr.Cells.Add(cell);
//总满意程度
cell = new DataGridViewTextBoxCell();
cell.Value = "";
string[] StrValue = Sfrs_Scores.Split('.');
int intValue = Convert.ToInt32(StrValue[0]);
if (intValue > 0)
{
DataTable dt2 = orbll.GetView_Custom("tb_ErpSatisfactionRatingSet", "Sfrs_Scores <= '" + intValue + "'", ShowColumnName: "Sfrs_Name", filedOrder: "Sfrs_Scores DESC", TopCount: 1).Tables[0];
if (dt2.Rows.Count > 0)
{ cell.Value = dt2.Rows[0]["Sfrs_Name"].ToString().Trim(); }
}
dgvr.Cells.Add(cell);
this.dgvData2.Rows.Add(dgvr);
this.dgvData2.ClearSelection();
#endregion
}
}
}