You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
DS7/DSWeb/Areas/SoftMng/Controllers/MsInfoClientFeedbackControl...

369 lines
21 KiB
C#

using System;
using System.IO;
using System.Linq;
using System.Web.Mvc;
using System.Collections.Generic;
using HcUtility.Comm;
using HcUtility.Core;
using DSWeb.EntityDA;
using DSWeb.Models;
using DSWeb.Attributes;
using DSWeb.SoftMng.DAL.MsInfoClientFeedbackDAL;
using DSWeb.SoftMng.Models.MsInfoClientFeedback;
using DSWeb.MvcShipping.Helper;
using DSWeb.MvcShipping.Comm.Cookie;
using DSWeb.MvcShipping.DAL.MsBaseInfoDAL;
using DSWeb.SoftMng.Filter;
namespace DSWeb.SoftMng.Controllers
{
[JsonRequestBehavior]
public class MsInfoClientFeedbackController : Controller
{
public ActionResult Index()
{
return View();
}
public ActionResult Edit()
{
return View();
}
#region 主列表查询
[SqlKeyWordsFilter(Type = "Action")]//sql 防注入过滤器
public ContentResult GetDataList(int start, int limit, string sort, string condition)
{
var dataList = MsInfoClientFeedbackDAL.GetDataList(condition, Convert.ToString(Session["USERID"]).ToString().Trim(), Convert.ToString(Session["SHOWNAME"]).ToString().Trim(), Convert.ToString(Session["COMPANYID"]).ToString().Trim(), sort);
var list = dataList.Skip(start).Take(limit);
var json = JsonConvert.Serialize(new { Success = true, Message = "查询成功", totalCount = dataList.Count, data = list.ToList() });
return new ContentResult() { Content = json };
}
[SqlKeyWordsFilter(Type = "Action")]//sql 防注入过滤器
public ContentResult GetData(string condition)
{
VW_Feedback_InfoEntity head = null;
head = MsInfoClientFeedbackDAL.GetData(condition, Convert.ToString(Session["USERID"]).ToString().Trim(), Convert.ToString(Session["SHOWNAME"]).ToString().Trim(), Convert.ToString(Session["COMPANYID"]).ToString().Trim());
var json = JsonConvert.Serialize(
new { Success = true, Message = "查询成功", data = head });
return new ContentResult() { Content = json };
}
#endregion
#region 删除
public ContentResult Delete(string data)
{
if (Convert.ToString(Session["COMPANYID"]).ToString().Trim() == "" || Convert.ToString(Session["USERID"]).ToString().Trim() == "" || Convert.ToString(Session["CODENAME"]).ToString().Trim() == "" || Convert.ToString(Session["SHOWNAME"]).ToString().Trim() == "" || Convert.ToString(Session["DEPTNAME"]).ToString().Trim() == "")
{
var jsonRespose2 = new JsonResponse { Success = false, Message = "登录超时,请退出系统重新登录!" };
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose2) };
}
//
var head = JsonConvert.Deserialize<VW_Feedback_InfoEntity>(data);
var modb = new ModelObjectDB();
//DBResult result = modb.Delete(head);
DBResult result = MsInfoClientFeedbackDAL.Delete(head);
var jsonRespose = new JsonResponse { Success = result.Success, Message = result.Message };
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
}
#endregion
#region 主列表保存
public ContentResult Save(string data)
{
if (Convert.ToString(Session["COMPANYID"]).ToString().Trim() == "" || Convert.ToString(Session["USERID"]).ToString().Trim() == "" || Convert.ToString(Session["CODENAME"]).ToString().Trim() == "" || Convert.ToString(Session["SHOWNAME"]).ToString().Trim() == "" || Convert.ToString(Session["DEPTNAME"]).ToString().Trim() == "")
{
var jsonRespose2 = new JsonResponse { Success = false, Message = "登录超时,请退出系统重新登录!" };
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose2) };
}
//
T_ALL_DA T_ALL_DA = new EntityDA.T_ALL_DA();
var headData = JsonConvert.Deserialize<VW_Feedback_InfoEntity>(data);
MsInfoClientFeedbackEntity hdFeedback = new MsInfoClientFeedbackEntity();
MsInfoClientFeedbackInfoEntity hdFeedbackInfo = new MsInfoClientFeedbackInfoEntity();
MsInfoClientFeedbackInfoEntity hdFeedbackInfo_HF = new MsInfoClientFeedbackInfoEntity();
var isPost = true;
var errorstr = "";
//
#region 主表
hdFeedback.FEEDBACKID = headData.FEEDBACKID == null ? "" : headData.FEEDBACKID.ToString().Trim();//FEEDBACKID
//
string sSQL = "select top 1 isnull(classKey,0) as classKey from InfoClass where className='" + headData.FEEDBACKTYPE.ToString() + "' and parentID='CI20161222000001'";
string sFEEDBACKTYPE = T_ALL_DA.GetStrSQL("classKey", sSQL);
int iFEEDBACKTYPE = 4;//日常维护
if (sFEEDBACKTYPE.Trim() != "")
{
iFEEDBACKTYPE = int.Parse(sFEEDBACKTYPE);
}
hdFeedback.FEEDBACKTYPE = iFEEDBACKTYPE;//反馈类型
//hdFeedback.FEEDBACKTYPE = int.Parse(headData.FEEDBACKTYPE.ToString());//反馈类型
//
sSQL = "select top 1 isnull(classKey,0) as classKey from InfoClass where className='" + headData.STATUS.ToString() + "' and parentID='CI20161220000007'";
string sSTATUS = T_ALL_DA.GetStrSQL("classKey", sSQL);
int iSTATUS = 2;//已受理未完成
if (sSTATUS.Trim() != "")
{
iSTATUS = int.Parse(sSTATUS);
}
hdFeedback.STATUS = iSTATUS;//维护状态
//hdFeedback.STATUS = int.Parse(headData.STATUS.ToString());//STATUS
//
sSQL = "select top 1 GID from info_client where SHORTNAME='" + headData.COMPANYID.ToString() + "'";
string sCOMPANYID = T_ALL_DA.GetStrSQL("GID", sSQL);
hdFeedback.COMPANYID = sCOMPANYID;//客户加载_委托单位
//hdFeedback.COMPANYID = headData.COMPANYID == null ? "" : headData.COMPANYID.ToString().Trim();//COMPANYID
//
hdFeedback.DEPARTMENT = "";//DEPARTMENT
hdFeedback.MASTER = headData.MASTER == null ? "" : headData.MASTER.ToString().Trim();//MASTER
hdFeedback.TELEPHONE = "";//TELEPHONE
hdFeedback.EMAIL = "";//EMAIL
hdFeedback.QQ = "";//QQ
hdFeedback.BEGINDATE = DateTime.Parse(headData.BEGINDATE.ToString("yyyy-MM-dd"));//BEGINDATE
//hdFeedback.ENDDATE
hdFeedback.PRIORITY = "";//PRIORITY
//
sSQL = "select top 1 classKey from InfoClass where className='" + headData.ACTION.ToString() + "' and parentID='CI20170122000001'";
string sACTION = T_ALL_DA.GetStrSQL("classKey", sSQL);
hdFeedback.ACTION = sACTION;//客户维护方式
//hdFeedback.ACTION = headData.ACTION == null ? "" : headData.ACTION.ToString().Trim();//ACTION
//
hdFeedback.EXPENSE = Decimal.Parse(headData.EXPENSE.ToString("F2"));//EXPENSE
//
sSQL = "select top 1 GID from info_client_item where ITEMNAME='" + headData.PROJECT.ToString() + "' and LINKGID='" + sCOMPANYID + "'";
string sPROJECT = T_ALL_DA.GetStrSQL("GID", sSQL);
hdFeedback.PROJECT = sPROJECT;
//hdFeedback.PROJECT = headData.PROJECT == null ? "" : headData.PROJECT.ToString().Trim();//PROJECT
//
//hdFeedback.COMPLETEDATE
hdFeedback.SATISFACTION = "";
hdFeedback.ACCEPTANCESUGGESTION = "";
hdFeedback.ACCEPTANCEMASTER = "";
//hdFeedback.ACCEPTANCEDATE
hdFeedback.ISTOP = false;
hdFeedback.CREATER = Convert.ToString(Session["SHOWNAME"]).ToString().Trim();
hdFeedback.CREATEDATE = DateTime.Now;
hdFeedback.MODIFYUSER = Convert.ToString(Session["SHOWNAME"]).ToString().Trim();
hdFeedback.MODIFYDATE = DateTime.Now;
hdFeedback.ISSEND = false;//ISSEND
hdFeedback.ISDELETE = false;//ISDELETE
//
sSQL = "select top 1 isnull(classKey,0) as classKey from InfoClass where className='" + headData.USERTYPE.ToString() + "' and parentID='CI20170123000001'";
string sUSERTYPE = T_ALL_DA.GetStrSQL("classKey", sSQL);
int iUSERTYPE = 0;//客服
if (sUSERTYPE.Trim() != "")
{
iUSERTYPE = int.Parse(sUSERTYPE);
}
hdFeedback.USERTYPE = iUSERTYPE;//录入人类型
//hdFeedback.USERTYPE = int.Parse(headData.USERTYPE.ToString().Trim());//录入人类型
//
if (hdFeedback.FEEDBACKID == "*" || hdFeedback.FEEDBACKID.ToString().Trim() == "")
{
hdFeedback.FEEDBACKID = "EI" + DateTime.Now.ToString("yyyyMMddHmsfff");//惟一编号 varchar(36)
hdFeedback.DbOperationType = DbOperationType.DbotIns;
}
else
{
hdFeedback.DbOperationType = DbOperationType.DbotUpd;
hdFeedback.ModelUIStatus = "E";
}
#endregion
#region 明细表_问
hdFeedbackInfo.FEEDBACKID = hdFeedback.FEEDBACKID == null ? "" : hdFeedback.FEEDBACKID.ToString().Trim();//FEEDBACKID
hdFeedbackInfo.REMARKID = headData.REMARKID == null ? "" : headData.REMARKID.ToString().Trim();//REMARKID
hdFeedbackInfo.REMARKTYPE = false;//问
hdFeedbackInfo.REMARK = headData.REMARK == null ? "" : headData.REMARK.ToString().Trim();//REMARK
hdFeedbackInfo.CREATER = Convert.ToString(Session["SHOWNAME"]).ToString().Trim();//CREATER
hdFeedbackInfo.CREATEDATE = DateTime.Now;//CREATEDATE
hdFeedbackInfo.MODIFYUSER = Convert.ToString(Session["SHOWNAME"]).ToString().Trim();//MODIFYUSER
hdFeedbackInfo.MODIFYDATE = DateTime.Now;//MODIFYDATE
if (hdFeedbackInfo.REMARKID == "*" || hdFeedbackInfo.REMARKID.ToString().Trim()=="")
{
hdFeedbackInfo.REMARKID = "IR" + DateTime.Now.ToString("yyyyMMddHmsfff");//惟一编号 varchar(36)
hdFeedbackInfo.DbOperationType = DbOperationType.DbotIns;
}
else
{
hdFeedbackInfo.DbOperationType = DbOperationType.DbotUpd;
hdFeedbackInfo.ModelUIStatus = "E";
}
#endregion
#region 明细表_回复
hdFeedbackInfo_HF.FEEDBACKID = hdFeedback.FEEDBACKID == null ? "" : hdFeedback.FEEDBACKID.ToString().Trim();//FEEDBACKID
hdFeedbackInfo_HF.REMARKID = headData.REMARKID_HF == null ? "" : headData.REMARKID_HF.ToString().Trim();//REMARKID
hdFeedbackInfo_HF.REMARKTYPE = true;//答
hdFeedbackInfo_HF.REMARK = headData.REMARK_HF == null ? "" : headData.REMARK_HF.ToString().Trim();//REMARK
hdFeedbackInfo_HF.CREATER = Convert.ToString(Session["SHOWNAME"]).ToString().Trim();//CREATER
hdFeedbackInfo_HF.CREATEDATE = DateTime.Now;//CREATEDATE
hdFeedbackInfo_HF.MODIFYUSER = Convert.ToString(Session["SHOWNAME"]).ToString().Trim();//MODIFYUSER
hdFeedbackInfo_HF.MODIFYDATE = DateTime.Now;//MODIFYDATE
if (hdFeedbackInfo_HF.REMARKID == "*" || hdFeedbackInfo_HF.REMARKID.ToString().Trim() == "")
{
hdFeedbackInfo_HF.REMARKID = "IR" + DateTime.Now.ToString("yyyyMMddHmsfff");//惟一编号 varchar(36)
hdFeedbackInfo_HF.DbOperationType = DbOperationType.DbotIns;
}
else
{
hdFeedbackInfo_HF.DbOperationType = DbOperationType.DbotUpd;
hdFeedbackInfo_HF.ModelUIStatus = "E";
}
#endregion
if (isPost)
{
var modb = new ModelObjectDB();
DBResult result = modb.Save(hdFeedback);
if (result.Success && hdFeedbackInfo.REMARK.ToString().Trim() != "")
{
hdFeedbackInfo.REMARK = hdFeedbackInfo.REMARK.Replace("\r\n", "<br>");
DBResult result2 = modb.Save(hdFeedbackInfo);
}
if (result.Success && hdFeedbackInfo_HF.REMARK.ToString().Trim()!="")
{
hdFeedbackInfo_HF.REMARK = hdFeedbackInfo_HF.REMARK.Replace("\r\n", "<br>");
DBResult result2 = modb.Save(hdFeedbackInfo_HF);
}
//DBResult result = MsInfoClientFeedbackDAL.Save(headData);
var jsonRespose = new JsonResponse
{
Success = result.Success,
Message = result.Message,
Data = MsInfoClientFeedbackDAL.GetData("FEEDBACKID='" + hdFeedback.FEEDBACKID + "'", Convert.ToString(Session["USERID"]).ToString().Trim(), Convert.ToString(Session["SHOWNAME"]).ToString().Trim(), Convert.ToString(Session["COMPANYID"]).ToString().Trim())
};
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
}
else {
var jsonRespose = new JsonResponse { Success = false, Message =errorstr };
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
}
}
#endregion
#region 取得客户的维护类型(年、次结)
public ContentResult GetSTLNAME(string LINKGID)
{
string sSTLNAME = MsInfoClientFeedbackDAL.GetSTLNAME(LINKGID);
var json = JsonConvert.Serialize(new { Success = true, Message = "查询成功", data = sSTLNAME });
return new ContentResult() { Content = json };
}
#endregion
#region 明细表查询
[SqlKeyWordsFilter(Type = "Action")]//sql 防注入过滤器
public ContentResult GetFeedbackInfoList(int start, int limit, string sort, string condition)
{
var dataList = MsInfoClientFeedbackDAL.GetFeedbackInfoList(condition, Convert.ToString(Session["USERID"]).ToString().Trim(), Convert.ToString(Session["SHOWNAME"]).ToString().Trim(), Convert.ToString(Session["COMPANYID"]).ToString().Trim(), sort);
var list = dataList.Skip(start).Take(limit);
var json = JsonConvert.Serialize(new { Success = true, Message = "查询成功", totalCount = dataList.Count, data = list.ToList() });
return new ContentResult() { Content = json };
}
#endregion
#region 保存明细列表
public ContentResult SaveFeedbackInfo(string dataHead, string data)
{
if (Convert.ToString(Session["COMPANYID"]).ToString().Trim() == "" || Convert.ToString(Session["USERID"]).ToString().Trim() == "" || Convert.ToString(Session["CODENAME"]).ToString().Trim() == "" || Convert.ToString(Session["SHOWNAME"]).ToString().Trim() == "" || Convert.ToString(Session["DEPTNAME"]).ToString().Trim() == "")
{
var jsonRespose2 = new JsonResponse { Success = false, Message = "登录超时,请退出系统重新登录!" };
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose2) };
}
//
T_ALL_DA T_ALL_DA = new EntityDA.T_ALL_DA();
var headData = JsonConvert.Deserialize<VW_Feedback_InfoEntity>(dataHead);
var headData2 = JsonConvert.Deserialize<MsInfoClientFeedbackInfoEntity>(data);
MsInfoClientFeedbackEntity hdFeedback = new MsInfoClientFeedbackEntity();
MsInfoClientFeedbackInfoEntity hdFeedbackInfo = new MsInfoClientFeedbackInfoEntity();
var isPost = true;
var errorstr = "";
//
#region 主表
string sSQL = "select top 1 classKey from InfoClass where className='" + headData.ACTION.ToString() + "' and parentID='CI20170122000001'";
string sACTION = T_ALL_DA.GetStrSQL("classKey", sSQL);
Decimal dEXPENSE = Decimal.Parse(headData.EXPENSE.ToString("F2"));
sSQL = "update Feedback set ACTION=" + sACTION + ",EXPENSE=" + dEXPENSE + ",MODIFYUSER='" + Convert.ToString(Session["SHOWNAME"]).ToString().Trim() + "',MODIFYDATE=getdate() where FEEDBACKID='" + headData.FEEDBACKID.ToString().Trim() + "'";
bool bl = T_ALL_DA.GetExecuteSqlCommand(sSQL);
#endregion
#region 明细表
hdFeedbackInfo.FEEDBACKID = headData.FEEDBACKID == null ? "" : headData.FEEDBACKID.ToString().Trim();//FEEDBACKID
hdFeedbackInfo.REMARKID = headData2.REMARKID == null ? "" : headData2.REMARKID.ToString().Trim();//REMARKID
bool blREMARKTYPE = headData2.REMARKTYPENAME.ToString().Trim() == "问" ? false : true;
hdFeedbackInfo.REMARKTYPE = blREMARKTYPE;//问
hdFeedbackInfo.REMARK = headData2.REMARK == null ? "" : headData2.REMARK.ToString().Trim().Replace("<br>", "\r\n");//REMARK
hdFeedbackInfo.CREATER = Convert.ToString(Session["SHOWNAME"]).ToString().Trim();//CREATER
hdFeedbackInfo.CREATEDATE = DateTime.Now;//CREATEDATE
hdFeedbackInfo.MODIFYUSER = Convert.ToString(Session["SHOWNAME"]).ToString().Trim();//MODIFYUSER
hdFeedbackInfo.MODIFYDATE = DateTime.Now;//MODIFYDATE
if (hdFeedbackInfo.REMARKID == "*" || hdFeedbackInfo.REMARKID.ToString().Trim() == "")
{
hdFeedbackInfo.REMARKID = "IR" + DateTime.Now.ToString("yyyyMMddHmsfff");//惟一编号 varchar(36)
hdFeedbackInfo.DbOperationType = DbOperationType.DbotIns;
}
else
{
hdFeedbackInfo.DbOperationType = DbOperationType.DbotUpd;
hdFeedbackInfo.ModelUIStatus = "E";
}
#endregion
if (isPost)
{
var modb = new ModelObjectDB();
DBResult result = modb.Save(hdFeedbackInfo);
//DBResult result = MsInfoClientFeedbackDAL.Save(headData);
var jsonRespose = new JsonResponse
{
Success = result.Success,
Message = result.Message,
Data = MsInfoClientFeedbackDAL.GetDataFeedbackInfo("FEEDBACKID='" + hdFeedbackInfo.FEEDBACKID + "' and REMARKID='" + hdFeedbackInfo.REMARKID.ToString() + "'")
};
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
}
else
{
var jsonRespose = new JsonResponse { Success = false, Message = errorstr };
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
}
}
#endregion
#region 删除明细列表
public ContentResult DeleteFeedbackInfo(string data)
{
if (Convert.ToString(Session["COMPANYID"]).ToString().Trim() == "" || Convert.ToString(Session["USERID"]).ToString().Trim() == "" || Convert.ToString(Session["CODENAME"]).ToString().Trim() == "" || Convert.ToString(Session["SHOWNAME"]).ToString().Trim() == "" || Convert.ToString(Session["DEPTNAME"]).ToString().Trim() == "")
{
var jsonRespose2 = new JsonResponse { Success = false, Message = "登录超时,请退出系统重新登录!" };
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose2) };
}
//
var head = JsonConvert.Deserialize<MsInfoClientFeedbackInfoEntity>(data);
var modb = new ModelObjectDB();
//DBResult result = modb.Delete(head);
DBResult result = MsInfoClientFeedbackDAL.DeleteFeedbackInfo(head);
var jsonRespose = new JsonResponse { Success = result.Success, Message = result.Message };
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
}
#endregion
#region 提交
public ContentResult onEnter(string data)
{
if (Convert.ToString(Session["COMPANYID"]).ToString().Trim() == "" || Convert.ToString(Session["USERID"]).ToString().Trim() == "" || Convert.ToString(Session["CODENAME"]).ToString().Trim() == "" || Convert.ToString(Session["SHOWNAME"]).ToString().Trim() == "" || Convert.ToString(Session["DEPTNAME"]).ToString().Trim() == "")
{
var jsonRespose2 = new JsonResponse { Success = false, Message = "登录超时,请退出系统重新登录!" };
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose2) };
}
//
var head = JsonConvert.Deserialize<VW_Feedback_InfoEntity>(data);
var modb = new ModelObjectDB();
DBResult result = MsInfoClientFeedbackDAL.onEnter(head);
var jsonRespose = new JsonResponse { Success = result.Success, Message = result.Message };
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
}
#endregion
//
}
}