地铁二期项目正式开始

OrderController.cs 137KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241
  1. using Newtonsoft.Json;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.Data;
  5. using System.Linq;
  6. using System.Web;
  7. using System.Web.Mvc;
  8. using YTSoft.BaseCallCenter.Model;
  9. using YTSoft.BaseCallCenter.MVCWeb.Models;
  10. using YTSoft.Common;
  11. namespace YTSoft.BaseCallCenter.MVCWeb.Controllers
  12. {
  13. public class OrderController : BaseController
  14. {
  15. BLL.T_Call_CallRecords recordBLL = new BLL.T_Call_CallRecords();
  16. //工单信息
  17. BLL.T_Wo_WorkOrderBase orderBLL = new BLL.T_Wo_WorkOrderBase();
  18. //客户信息
  19. BLL.T_Cus_CustomerBase cusBLL = new BLL.T_Cus_CustomerBase();
  20. //部门表
  21. BLL.T_Sys_Department deptBll = new BLL.T_Sys_Department();
  22. //转单通知
  23. BLL.T_Wo_WorkOrderNotice noticeBLL = new BLL.T_Wo_WorkOrderNotice();
  24. //用户表
  25. BLL.T_Sys_UserAccount userBll = new BLL.T_Sys_UserAccount();
  26. //历史工单表
  27. BLL.T_Wo_WorkOrderHistory historyBll = new BLL.T_Wo_WorkOrderHistory();
  28. int rxzhj = 0;
  29. int wxzhj = 0;
  30. int wbzhj = 0;
  31. #region 待处理
  32. /// <summary>
  33. /// 获取待办工单 新
  34. /// </summary>
  35. /// <param name="dtype">工单类型 1、所有待办工单 2、代办结工单</param>
  36. /// <returns></returns>
  37. public ActionResult WorkOrderWaitList(int dtype)
  38. {
  39. WorkOrderMyModel model = new WorkOrderMyModel();
  40. model.DType = dtype;
  41. //业务类型字典表
  42. model.WorkOrderTypeModelList = GetWorkTypeModelList();
  43. //话务标志
  44. model.SeatFlag = F_SeatFlag;
  45. return View(model);
  46. }
  47. /// <summary>
  48. /// 我的待办工单
  49. /// </summary>
  50. /// <param name="page">当前页码</param>
  51. /// <param name="limit">每页数据量</param>
  52. /// <param name="sqlWhere">查询条件</param>
  53. /// <returns></returns>
  54. [ActionName("WorkOrderMyWaitData")]
  55. [HttpGet]
  56. public string WorkOrderMyWaitData(DateTime? NowDateTime, int page, int limit, int? types, string dateParty,
  57. string workorderNum, string cusName, string phoneNumber,
  58. string userInfo, int? bussType, int? detailType, string Content)
  59. {
  60. //数据结果集
  61. ResponseData dataModel = new ResponseData();
  62. //F_FILEFLAG 业务类型ID
  63. //F_WORKORDERSTATEID 0未处理 1处理中 2已办结 status
  64. //F_WORKORDERTYPEID 处理方式 1转单 3客服处理 GoType
  65. //F_REPAIRMANID 接入渠道 1语音 2留言 3微信 4微博 FromType
  66. // string sql = string.Format(" and F_WORKORDERTYPEID=1 and F_WORKORDERSTATEID=1 and F_WORKORDERID in (select F_INSTANCEID from T_Wo_WorkOrderHistory A where F_WORKORDERSTATEID=0 and F_OPTUSERID={0} AND F_OPTDATE= (select TOP 1 F_OPTDATE from T_Wo_WorkOrderHistory WHERE F_INSTANCEID = A.F_INSTANCEID ORDER BY F_OPTDATE DESC) )", F_UserID);
  67. string sql = "";
  68. //9.29注释
  69. //sql = " and F_WORKORDERTYPEID=1 and F_WORKORDERSTATEID=1 and ( F_WORKORDERID in (select F_INSTANCEID from T_Wo_WorkOrderHistory A where F_WORKORDERSTATEID=0 and F_OPTUSERID='" + F_UserID + "' AND CONVERT(CHAR(20), F_OPTDATE, 120)= (select TOP 1 CONVERT(CHAR(20), F_OPTDATE, 120) from T_Wo_WorkOrderHistory WHERE F_INSTANCEID = A.F_INSTANCEID ORDER BY F_OPTDATE DESC) OR F_WORKORDERID in (select F_INSTANCEID from T_Wo_WorkOrderHistory A where F_WORKORDERSTATEID = 1 and F_OPTUSERID = '" + F_UserID + "' AND ReplayTime IS NOT NULL )) )";
  70. sql = " and F_WORKORDERTYPEID=1 and F_WORKORDERSTATEID=1 and ( F_WORKORDERID in (select F_INSTANCEID from T_Wo_WorkOrderHistory A where F_WORKORDERSTATEID=0 and F_StateName='未处理' and F_OPTUSERID='" + F_UserID + "' OR F_WORKORDERID in (select F_INSTANCEID from T_Wo_WorkOrderHistory A where F_WORKORDERSTATEID = 1 and F_OPTUSERID = '" + F_UserID + "' AND ReplayTime IS NOT NULL )) )";
  71. //datatype = "可撤回";
  72. //if (datatype != "可撤回")
  73. //{
  74. //9.2号注释 sql = " and F_WORKORDERTYPEID=1 and F_WORKORDERSTATEID=1 and ( F_WORKORDERID in (select F_INSTANCEID from T_Wo_WorkOrderHistory A where F_WORKORDERSTATEID=0 and F_OPTUSERID='" + F_UserID + "' AND F_OPTDATE= (select TOP 1 F_OPTDATE from T_Wo_WorkOrderHistory WHERE F_INSTANCEID = A.F_INSTANCEID ORDER BY F_OPTDATE DESC) OR F_WORKORDERID in (select F_INSTANCEID from T_Wo_WorkOrderHistory A where F_WORKORDERSTATEID = 1 and F_OPTUSERID = '" + F_UserID + "' AND ReplayTime IS NOT NULL )) )";
  75. //}
  76. //else
  77. //{
  78. // sql = string.Format(" and F_WORKORDERTYPEID=1 and F_WORKORDERSTATEID=3 and F_WORKORDERID in (select F_INSTANCEID from T_Wo_WorkOrderHistory where F_WORKORDERSTATEID=1 and F_OPTUSERID={0})", F_UserID);
  79. //}
  80. // string sql = " and F_WORKORDERTYPEID=1 and F_WORKORDERSTATEID=1 and ( F_WORKORDERID in (select F_INSTANCEID from T_Wo_WorkOrderHistory A where F_WORKORDERSTATEID=0 and F_OPTUSERID='"+F_UserID+ "' AND F_OPTDATE= (select TOP 1 F_OPTDATE from T_Wo_WorkOrderHistory WHERE F_INSTANCEID = A.F_INSTANCEID ORDER BY F_OPTDATE DESC) OR F_WORKORDERID in (select F_INSTANCEID from T_Wo_WorkOrderHistory A where F_WORKORDERSTATEID = 1 and F_OPTUSERID = '"+F_UserID+"' AND ReplayTime IS NOT NULL )) )";
  81. //工单编号
  82. if (!string.IsNullOrEmpty(workorderNum))
  83. {
  84. sql += " and F_CODE like '%" + workorderNum.Trim() + "%'";
  85. }
  86. //客户姓名
  87. if (!string.IsNullOrEmpty(cusName))
  88. {
  89. sql += " and F_CUSTOMERNAME like '%" + cusName.Trim() + "%'";
  90. }
  91. //客户电话
  92. if (!string.IsNullOrEmpty(phoneNumber))
  93. {
  94. sql += " and F_CUSTOMERTELEPHONE like '%" + phoneNumber.Trim() + "%'";
  95. }
  96. //坐席工号
  97. if (!string.IsNullOrEmpty(userInfo))
  98. {
  99. sql += " and F_LINKMAN like '%" + userInfo.Trim() + "%'";
  100. }
  101. //业务类别
  102. if (bussType != null && bussType > 0)
  103. {
  104. sql += " and F_FILEFLAG =" + bussType;
  105. }
  106. //业务类型
  107. if (detailType != null && detailType > 0)
  108. {
  109. sql += " and F_REPAIRLEVEL =" + detailType;
  110. }
  111. //内容
  112. if (!string.IsNullOrEmpty(Content))
  113. {
  114. sql += " and F_CONTENT like '%" + Content.Trim() + "%'";
  115. }
  116. //查询按钮
  117. if (types == 0)
  118. {
  119. if (!string.IsNullOrEmpty(dateParty))
  120. {
  121. string startDate = dateParty.Substring(0, 10);
  122. string endDate = dateParty.Substring(12);
  123. sql += " and F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  124. sql += " and F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  125. }
  126. }//一周按钮
  127. else if (types == 1)
  128. {
  129. string endDate = DateTime.Now.ToString();
  130. string startDate = DateTime.Now.AddDays(-7).ToString();
  131. sql += " and F_CREATEDATE>= '" + startDate + "'";
  132. sql += " and F_CREATEDATE<= '" + endDate + "'";
  133. }//一月按钮
  134. else if (types == 2)
  135. {
  136. string endDate = DateTime.Now.ToString();
  137. string startDate = DateTime.Now.AddMonths(-1).ToString();
  138. sql += " and F_CREATEDATE>= '" + startDate + "'";
  139. sql += " and F_CREATEDATE<= '" + endDate + "'";
  140. }//一年按钮
  141. else if (types == 3)
  142. {
  143. string endDate = DateTime.Now.ToString();
  144. string startDate = DateTime.Now.AddYears(-1).ToString();
  145. sql += " and F_CREATEDATE>= '" + startDate + "'";
  146. sql += " and F_CREATEDATE<= '" + endDate + "'";
  147. }
  148. DataTable dt = new DataTable();
  149. int recordCount = 0;
  150. Model.PageData<Model.T_Wo_WorkOrderBase> pageModel = new Model.PageData<Model.T_Wo_WorkOrderBase>();
  151. dt = BLL.PagerBLL.GetListPager(
  152. "T_Wo_WorkOrderBase",
  153. "F_WORKORDERID",
  154. "*,CONVERT(varchar,F_CREATEDATE, 120 ) as F_CREATEDATENew"
  155. + string.Format(",(select top 1 F_HISTORYID from T_Wo_WorkOrderHistory where F_INSTANCEID=F_WORKORDERID and F_WORKORDERSTATEID=0 and F_OPTUSERID={0} Order by F_OPTDATE desc) AS F_HISTORYID", F_UserID)
  156. + @" , replace(replace(CASE F_WORKORDERFROM WHEN '留言工单' THEN (SELECT top 1 F_RecFileUrl FROM dbo.T_Call_LeaveRecord WHERE F_CallId=F_KSHADDRESSCODE) WHEN '语音工单' THEN (SELECT top 1 FilePath FROM dbo.T_Call_CallRecords WHERE CallId=F_KSHADDRESSCODE AND FilePath!='') ELSE NULL END,'\','/'),'" + GetSysconfig("newFilePath") + "','" + GetSysconfig("newPlayPath") + "') as FilePath",
  157. //+ " ,(CASE F_WORKORDERFROM WHEN '留言工单' THEN (SELECT F_RecFileUrl FROM dbo.T_Call_LeaveRecord WHERE F_CallId=F_KSHADDRESSCODE) WHEN '语音工单' THEN (SELECT FilePath FROM dbo.T_Call_CallRecords WHERE CallId=F_KSHADDRESSCODE AND FilePath!='') ELSE NULL END ) as FilePath",
  158. sql,
  159. "ORDER BY F_CREATEDATE desc",
  160. limit,
  161. page,
  162. true,
  163. out recordCount);
  164. dataModel.code = 0;
  165. dataModel.count = recordCount;
  166. dataModel.data = dt;
  167. return JsonConvert.SerializeObject(dataModel);
  168. }
  169. /// <summary>
  170. /// 二级单位处理完成提交处理信息
  171. /// </summary>
  172. /// <param name="workOrderBaseModel"></param>
  173. /// <returns></returns>
  174. [AcceptVerbs(HttpVerbs.Post)]
  175. public bool SubmitOrder(T_Wo_WorkOrderHistory workOrderBaseModel )
  176. {
  177. AddAction("t_wo_workorderhistory", workOrderBaseModel.F_HISTORYID.ToMyString(), "提交工单", "数据:" + JsonConvert.SerializeObject(workOrderBaseModel), "关键信息");
  178. AddAction("t_wo_workorderhistory", workOrderBaseModel.F_HISTORYID.ToMyString(), "部门提交工单", workOrderBaseModel.F_INSTANCEID.ToMyString());
  179. return orderBLL.SubmitOrder(workOrderBaseModel);
  180. }
  181. /// <summary>
  182. ///
  183. /// </summary>
  184. /// <param name="workOrderBaseModel"></param>
  185. /// <returns></returns>
  186. public int WorkOrderMyWaitDataCount()
  187. {
  188. string sql = string.Format(" F_WORKORDERTYPEID=1 and F_WORKORDERSTATEID=1 and F_WORKORDERID in (select F_INSTANCEID from T_Wo_WorkOrderHistory where F_WORKORDERSTATEID=0 and F_OPTUSERID={0})", F_UserID);
  189. return orderBLL.GetRecordCount(sql);
  190. }
  191. #endregion
  192. #region 待回访
  193. /// <summary>
  194. /// 获取待回访工单
  195. /// </summary>
  196. /// <param name="dtype">工单类型 1、所有待办工单 2、代办结工单</param>
  197. /// <returns></returns>
  198. public ActionResult WorkOrderMyListHF(int dtype)
  199. {
  200. WorkOrderMyModel model = new WorkOrderMyModel();
  201. model.DType = dtype;
  202. //业务类型字典表
  203. model.WorkOrderTypeModelList = GetWorkTypeModelList();
  204. //话务标志
  205. model.SeatFlag = F_SeatFlag;
  206. return View(model);
  207. }
  208. /// <summary>
  209. /// 全媒体客服处理回访
  210. /// </summary>
  211. /// <param name="workOrderBaseModel"></param>
  212. /// <returns></returns>
  213. [AcceptVerbs(HttpVerbs.Post)]
  214. public bool SubmitOrderHF(T_Wo_WorkOrderBase workOrderBaseModel)
  215. {
  216. AddAction("t_wo_workorderbase", workOrderBaseModel.F_WORKORDERID.ToMyString(), "回访提交工单", workOrderBaseModel.F_CODE);
  217. AddAction("t_wo_workorderbase", workOrderBaseModel.F_WORKORDERID.ToMyString(), "回访提交工单", "数据:" + JsonConvert.SerializeObject(workOrderBaseModel), "关键信息");
  218. return orderBLL.SubmitOrderHF(workOrderBaseModel);
  219. }
  220. /// <summary>
  221. /// 待回访工单
  222. /// </summary>
  223. /// <param name="page">当前页码</param>
  224. /// <param name="limit">每页数据量</param>
  225. /// <param name="sqlWhere">查询条件</param>
  226. /// <returns></returns>
  227. [ActionName("WorkOrderMyDataHF")]
  228. [HttpGet]
  229. public string WorkOrderMyDataHF(DateTime? NowDateTime, int page, int limit, int? types, string dateParty,
  230. string workorderNum, string cusName, string phoneNumber,
  231. string userInfo, int? bussType, int? detailType, string Content)
  232. {
  233. //数据结果集
  234. ResponseData dataModel = new ResponseData();
  235. //F_FILEFLAG 业务类型ID
  236. //F_WORKORDERSTATEID 0未处理 1处理中 2已办结 status
  237. //F_WORKORDERTYPEID 处理方式 1转单 3客服处理 GoType
  238. //F_REPAIRMANID 接入渠道 1语音 2留言 3微信 4微博 FromType
  239. //string sql = string.Format(" and F_WORKORDERTYPEID=1 and F_WORKORDERSTATEID=1 and F_WORKORDERID in (select F_INSTANCEID from T_Wo_WorkOrderHistory where F_WORKORDERSTATEID=0 and F_OPTUSERID={0})", F_UserID);
  240. string sql = string.Format(" and F_WORKORDERSTATEID=3 and F_UserId={0}", F_UserID);
  241. //工单编号
  242. if (!string.IsNullOrEmpty(workorderNum))
  243. {
  244. sql += " and F_CODE like '%" + workorderNum.Trim() + "%'";
  245. }
  246. //客户姓名
  247. if (!string.IsNullOrEmpty(cusName))
  248. {
  249. sql += " and F_CUSTOMERNAME like '%" + cusName.Trim() + "%'";
  250. }
  251. //客户电话
  252. if (!string.IsNullOrEmpty(phoneNumber))
  253. {
  254. sql += " and F_CUSTOMERTELEPHONE like '%" + phoneNumber.Trim() + "%'";
  255. }
  256. //坐席工号
  257. if (!string.IsNullOrEmpty(userInfo))
  258. {
  259. sql += " and F_LINKMAN like '%" + userInfo.Trim() + "%'";
  260. }
  261. //业务类别
  262. if (bussType != null && bussType > 0)
  263. {
  264. sql += " and F_FILEFLAG =" + bussType;
  265. }
  266. //业务类型
  267. if (detailType != null && detailType > 0)
  268. {
  269. sql += " and F_REPAIRLEVEL =" + detailType;
  270. }
  271. //内容
  272. if (!string.IsNullOrEmpty(Content))
  273. {
  274. sql += " and F_CONTENT like '%" + Content.Trim() + "%'";
  275. }
  276. //查询按钮
  277. if (types == 0)
  278. {
  279. if (!string.IsNullOrEmpty(dateParty))
  280. {
  281. string startDate = dateParty.Substring(0, 10);
  282. string endDate = dateParty.Substring(12);
  283. sql += " and F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  284. sql += " and F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  285. }
  286. }//一周按钮
  287. else if (types == 1)
  288. {
  289. string endDate = DateTime.Now.ToString();
  290. string startDate = DateTime.Now.AddDays(-7).ToString();
  291. sql += " and F_CREATEDATE>= '" + startDate + "'";
  292. sql += " and F_CREATEDATE<= '" + endDate + "'";
  293. }//一月按钮
  294. else if (types == 2)
  295. {
  296. string endDate = DateTime.Now.ToString();
  297. string startDate = DateTime.Now.AddMonths(-1).ToString();
  298. sql += " and F_CREATEDATE>= '" + startDate + "'";
  299. sql += " and F_CREATEDATE<= '" + endDate + "'";
  300. }//一年按钮
  301. else if (types == 3)
  302. {
  303. string endDate = DateTime.Now.ToString();
  304. string startDate = DateTime.Now.AddYears(-1).ToString();
  305. sql += " and F_CREATEDATE>= '" + startDate + "'";
  306. sql += " and F_CREATEDATE<= '" + endDate + "'";
  307. }
  308. DataTable dt = new DataTable();
  309. int recordCount = 0;
  310. Model.PageData<Model.T_Wo_WorkOrderBase> pageModel = new Model.PageData<Model.T_Wo_WorkOrderBase>();
  311. dt = BLL.PagerBLL.GetListPager(
  312. "T_Wo_WorkOrderBase",
  313. "F_WORKORDERID",
  314. "*,CONVERT(varchar,F_CREATEDATE, 120 ) as F_CREATEDATENew"
  315. + @" , replace(replace(CASE F_WORKORDERFROM WHEN '留言工单' THEN (SELECT top 1 F_RecFileUrl FROM dbo.T_Call_LeaveRecord WHERE F_CallId=F_KSHADDRESSCODE) WHEN '语音工单' THEN (SELECT top 1 FilePath FROM dbo.T_Call_CallRecords WHERE CallId=F_KSHADDRESSCODE AND FilePath!='') ELSE NULL END,'\','/'),'" + GetSysconfig("newFilePath") + "','" + GetSysconfig("newPlayPath") + "') as FilePath",
  316. //+ " ,(CASE F_WORKORDERFROM WHEN '留言工单' THEN (SELECT F_RecFileUrl FROM dbo.T_Call_LeaveRecord WHERE F_CallId=F_KSHADDRESSCODE) WHEN '语音工单' THEN (SELECT FilePath FROM dbo.T_Call_CallRecords WHERE CallId=F_KSHADDRESSCODE AND FilePath!='') ELSE NULL END ) as FilePath",
  317. sql,
  318. "ORDER BY F_CREATEDATE desc",
  319. limit,
  320. page,
  321. true,
  322. out recordCount);
  323. dataModel.code = 0;
  324. dataModel.count = recordCount;
  325. dataModel.data = dt;
  326. return JsonConvert.SerializeObject(dataModel);
  327. }
  328. public int WorkOrderMyDataHFCount()
  329. {
  330. string sql = string.Format(" F_WORKORDERSTATEID=3 and F_UserId={0}", F_UserID);
  331. return orderBLL.GetRecordCount(sql);
  332. }
  333. #endregion
  334. #region 待定责
  335. public string DZDeptList(int workid)
  336. {
  337. DataTable dt = null;
  338. DataSet ds = historyBll.GetListDZ(string.Format(" F_INSTANCEID={0} ", workid));
  339. if (ds != null && ds.Tables.Count > 0 && ds.Tables[0].Rows.Count > 0)
  340. {
  341. dt = ds.Tables[0];
  342. }
  343. ResponseData dataModel = new ResponseData();
  344. dataModel.code = 0;
  345. dataModel.count = 0;
  346. dataModel.data = dt;
  347. return JsonConvert.SerializeObject(dataModel);
  348. }
  349. /// <summary>
  350. /// 定责视图
  351. /// </summary>
  352. /// <param name="dtype">工单类型 1、所有待办工单 2、代办结工单</param>
  353. /// <returns></returns>
  354. public ActionResult WorkOrderMyListDZ(int dtype)
  355. {
  356. WorkOrderMyModel model = new WorkOrderMyModel();
  357. model.DType = dtype;
  358. //业务类型字典表
  359. model.WorkOrderTypeModelList = GetWorkTypeModelList();
  360. //话务标志
  361. model.SeatFlag = F_SeatFlag;
  362. return View(model);
  363. }
  364. /// <summary>
  365. /// 录入定责结果
  366. /// </summary>
  367. /// <param name="workOrderBaseModel"></param>
  368. /// <returns></returns>
  369. [AcceptVerbs(HttpVerbs.Post)]
  370. public bool SubmitOrderDZ(T_Wo_WorkOrderNoticeInput modelinput)
  371. {
  372. if (modelinput.orderid == 0)
  373. {
  374. return false;
  375. }
  376. #region 处理工单事件分类
  377. Model.T_Wo_WorkOrderBase modelorder =orderBLL.GetModel(modelinput.orderid);
  378. modelorder.F_PROVINCE = modelinput.ClassName1;
  379. modelorder.F_CITY = modelinput.ClassName2;
  380. modelorder.F_AREA = modelinput.ClassName3;
  381. modelorder.F_SERVICENATURE = modelinput.F_SERVICENATURE;
  382. modelorder.F_SERVICETYPE = modelinput.F_SERVICETYPE;
  383. #endregion
  384. int DZNumber=noticeBLL.updatenum(modelinput.orderid);
  385. if (string.IsNullOrEmpty(modelinput.DeptIds)&&false)
  386. {
  387. #region 通知 定责相关处理部门
  388. if (modelorder.F_WORKORDERTYPEID == 1)
  389. {
  390. List<T_Wo_WorkOrderHistory> modelhisList = historyBll.GetModelList(string.Format(" F_INSTANCEID={0}", modelinput.orderid));
  391. if (modelhisList.Count > 0)
  392. {
  393. Dictionary<int, string> dict = new Dictionary<int, string>() { };
  394. foreach (T_Wo_WorkOrderHistory modelhis in modelhisList)
  395. {
  396. if (dict.ContainsKey(modelhis.F_OPTBTNID.ToInt32()))
  397. {
  398. continue;
  399. }
  400. T_Wo_WorkOrderNotice modeladd = new T_Wo_WorkOrderNotice();
  401. modeladd.OrderId = modelinput.orderid;
  402. modeladd.DealAdvise = modelinput.F_SERVICETYPE;
  403. modeladd.DealResult = modelinput.F_SERVICENATURE;
  404. modeladd.Class1 = modelorder.F_PROVINCE;
  405. modeladd.Class2 = modelorder.F_CITY;
  406. modeladd.Class3 = modelorder.F_AREA;
  407. modeladd.DZNumber = DZNumber;
  408. modeladd.NoticeState = 1;
  409. modeladd.NoticeType = 1;
  410. modeladd.Userid = F_UserID;
  411. modeladd.Username = F_UserName;
  412. modeladd.NoticeUserid = modelhis.F_OPTUSERID.ToInt32();
  413. modeladd.NoticeUsername = modelhis.F_UserName;
  414. modeladd.NoticeDeptId = modelhis.F_OPTBTNID.ToInt32();
  415. modeladd.NoticeDeptName = modelhis.F_NEXTOWNERARRID;
  416. modeladd.NoticeDeptContent = modelhis.F_NEXTOWNERARRID + " 调查情况:\n";
  417. modeladd.NoticeDeptAdvise = modelhis.F_NEXTOWNERARRID + " 处理意见和整改措施:\n";
  418. foreach (T_Wo_WorkOrderHistory modelhistemp in modelhisList)
  419. {
  420. if (string.IsNullOrEmpty(modelhistemp.F_REMARK))
  421. {
  422. continue;
  423. }
  424. int tempint = modelhistemp.F_REMARK.IndexOf("|");
  425. if (tempint == -1)
  426. {
  427. modeladd.NoticeDeptContent += modelhistemp.F_REMARK;
  428. modeladd.NoticeDeptAdvise += modelhistemp.F_REMARK;
  429. }
  430. else
  431. {
  432. string[] arrystr = modelhistemp.F_REMARK.Split('|');
  433. modeladd.NoticeDeptContent += arrystr[0];
  434. modeladd.NoticeDeptContent += "\n";
  435. modeladd.NoticeDeptAdvise += arrystr[1];
  436. modeladd.NoticeDeptAdvise += "\n";
  437. }
  438. }
  439. dict.Add(modelhis.F_OPTBTNID.ToInt32(), "1");
  440. noticeBLL.Add(modeladd);
  441. }
  442. }
  443. }
  444. else
  445. {
  446. T_Wo_WorkOrderNotice modeladd = new T_Wo_WorkOrderNotice();
  447. modeladd.OrderId = modelinput.orderid;
  448. modeladd.DealAdvise = modelinput.F_SERVICETYPE;
  449. modeladd.DealResult = modelinput.F_SERVICENATURE;
  450. modeladd.Class1 = modelorder.F_PROVINCE;
  451. modeladd.Class2 = modelorder.F_CITY;
  452. modeladd.Class3 = modelorder.F_AREA;
  453. modeladd.DZNumber = DZNumber;
  454. modeladd.NoticeState = 1;
  455. modeladd.NoticeType = 1;
  456. modeladd.Userid = F_UserID;
  457. modeladd.Username = F_UserName;
  458. modeladd.NoticeUserid = modelorder.F_USERID.ToInt32();
  459. modeladd.NoticeUsername = modelorder.F_USERNAME;
  460. modeladd.NoticeDeptId = modelorder.F_DEPTID.ToInt32();
  461. modeladd.NoticeDeptName = modelorder.F_DEPTCODE;
  462. modeladd.NoticeDeptContent = modelorder.F_DEPTCODE + " 调查情况:\n";
  463. modeladd.NoticeDeptAdvise = modelorder.F_DEPTCODE + " 处理意见和整改措施:\n";
  464. if (!string.IsNullOrEmpty(modelorder.F_RETURNVISITCONTENT))
  465. {
  466. int tempint = modelorder.F_RETURNVISITCONTENT.IndexOf("|");
  467. if (tempint == -1)
  468. {
  469. modeladd.NoticeDeptContent += modelorder.F_RETURNVISITCONTENT;
  470. modeladd.NoticeDeptAdvise += modelorder.F_RETURNVISITCONTENT;
  471. }
  472. else
  473. {
  474. string[] arrystr = modelorder.F_RETURNVISITCONTENT.Split('|');
  475. modeladd.NoticeDeptContent += arrystr[0];
  476. modeladd.NoticeDeptContent += "\n";
  477. modeladd.NoticeDeptAdvise += arrystr[1];
  478. modeladd.NoticeDeptAdvise += "\n";
  479. }
  480. }
  481. noticeBLL.Add(modeladd);
  482. }
  483. #endregion
  484. }
  485. #region 通知 自选部门
  486. if (!string.IsNullOrEmpty(modelinput.DeptIds))
  487. {
  488. List<T_Sys_Department> modelhisList = deptBll.GetModelList(string.Format(" F_DeptId in ({0})", modelinput.DeptIds));
  489. if (modelhisList.Count > 0)
  490. {
  491. foreach (T_Sys_Department modeldept in modelhisList)
  492. {
  493. T_Wo_WorkOrderNotice modeladd = new T_Wo_WorkOrderNotice();
  494. modeladd.OrderId = modelinput.orderid;
  495. modeladd.DealAdvise = modelinput.F_SERVICETYPE;
  496. modeladd.DealResult = modelinput.F_SERVICENATURE;
  497. modeladd.Class1 = modelorder.F_PROVINCE;
  498. modeladd.Class2 = modelorder.F_CITY;
  499. modeladd.Class3 = modelorder.F_AREA;
  500. modeladd.DZNumber = DZNumber + 1;
  501. modeladd.NoticeState = 1;
  502. modeladd.NoticeType = 1;
  503. modeladd.Userid = F_UserID;
  504. modeladd.Username = F_UserName;
  505. modeladd.NoticeUserid = 0;
  506. modeladd.NoticeUsername = "";
  507. modeladd.NoticeDeptId = modeldept.F_DeptId;
  508. modeladd.NoticeDeptName = modeldept.F_DeptName;
  509. modeladd.NoticeDeptContent = "";
  510. modeladd.NoticeDeptAdvise = "";
  511. //modeladd.NoticeDeptContent = modelhis.F_NEXTOWNERARRID + " 调查情况:\n";
  512. //modeladd.NoticeDeptAdvise = modelhis.F_NEXTOWNERARRID + " 处理意见和整改措施:\n";
  513. noticeBLL.Add(modeladd);
  514. }
  515. }
  516. }
  517. #endregion
  518. AddAction("t_wo_workorderbase", modelorder.F_WORKORDERID.ToMyString(), "提交定责工单", modelorder.F_CODE);
  519. AddAction("t_wo_workorderbase", modelorder.F_WORKORDERID.ToMyString(), "提交定责工单", "数据:" + JsonConvert.SerializeObject(modelorder), "关键信息");
  520. return orderBLL.UpdateDZClass(modelorder);
  521. }
  522. /// <summary>
  523. /// 待定责列表
  524. /// </summary>
  525. /// <param name="page">当前页码</param>
  526. /// <param name="limit">每页数据量</param>
  527. /// <param name="sqlWhere">查询条件</param>
  528. /// <returns></returns>
  529. [ActionName("WorkOrderMyDataDZ")]
  530. [HttpGet]
  531. public string WorkOrderMyDataDZ(DateTime? NowDateTime, int page, int limit, int? types, string dateParty,
  532. string workorderNum, string cusName, string phoneNumber,
  533. string userInfo, int? bussType, int? detailType, string Content, int? F_RETURNVISITRESULT)
  534. {
  535. //数据结果集
  536. ResponseData dataModel = new ResponseData();
  537. //F_FILEFLAG 业务类型ID
  538. //F_WORKORDERSTATEID 0未处理 1处理中 2已办结 status
  539. //F_WORKORDERTYPEID 处理方式 1转单 3客服处理 GoType
  540. //F_REPAIRMANID 接入渠道 1语音 2留言 3微信 4微博 FromType
  541. //string sql = string.Format(" and F_WORKORDERTYPEID=1 and F_WORKORDERSTATEID=1 and F_WORKORDERID in (select F_INSTANCEID from T_Wo_WorkOrderHistory where F_WORKORDERSTATEID=0 and F_OPTUSERID={0})", F_UserID);
  542. //因为yanyanfei和马岭娜调整权限了,所以待定责和已定责改成 展示所有的
  543. // string sql = string.Format(" and F_WORKORDERSTATEID=4 and (F_HASTENCOUNTS=0 OR F_HASTENCOUNTS IS NULL) and (F_ROAD='{0}' Or F_ROAD='' Or F_ROAD IS NULL)", F_UserID);
  544. string sql = string.Format(" and F_WORKORDERSTATEID=4 and (F_HASTENCOUNTS=0 OR F_HASTENCOUNTS IS NULL)");
  545. if (F_RETURNVISITRESULT != null && F_RETURNVISITRESULT > 0)
  546. {
  547. sql += " and F_RETURNVISITRESULT =" + F_RETURNVISITRESULT;
  548. }
  549. //if (F_UserID == 8000)
  550. //{
  551. // sql = string.Format(" and F_WORKORDERSTATEID=4 and (F_HASTENCOUNTS=0 OR F_HASTENCOUNTS IS NULL)");
  552. //}
  553. //工单编号
  554. if (!string.IsNullOrEmpty(workorderNum))
  555. {
  556. sql += " and F_CODE like '%" + workorderNum.Trim() + "%'";
  557. }
  558. //客户姓名
  559. if (!string.IsNullOrEmpty(cusName))
  560. {
  561. sql += " and F_CUSTOMERNAME like '%" + cusName.Trim() + "%'";
  562. }
  563. //客户电话
  564. if (!string.IsNullOrEmpty(phoneNumber))
  565. {
  566. sql += " and F_CUSTOMERTELEPHONE like '%" + phoneNumber.Trim() + "%'";
  567. }
  568. //坐席工号
  569. if (!string.IsNullOrEmpty(userInfo))
  570. {
  571. sql += " and F_LINKMAN like '%" + userInfo.Trim() + "%'";
  572. }
  573. //业务类别
  574. if (bussType != null && bussType > 0)
  575. {
  576. sql += " and F_FILEFLAG =" + bussType;
  577. }
  578. //业务类型
  579. if (detailType != null && detailType > 0)
  580. {
  581. sql += " and F_REPAIRLEVEL =" + detailType;
  582. }
  583. //内容
  584. if (!string.IsNullOrEmpty(Content))
  585. {
  586. sql += " and F_CONTENT like '%" + Content.Trim() + "%'";
  587. }
  588. //查询按钮
  589. if (types == 0)
  590. {
  591. if (!string.IsNullOrEmpty(dateParty))
  592. {
  593. string startDate = dateParty.Substring(0, 10);
  594. string endDate = dateParty.Substring(12);
  595. sql += " and F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  596. sql += " and F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  597. }
  598. }//一周按钮
  599. else if (types == 1)
  600. {
  601. string endDate = DateTime.Now.ToString();
  602. string startDate = DateTime.Now.AddDays(-7).ToString();
  603. sql += " and F_CREATEDATE>= '" + startDate + "'";
  604. sql += " and F_CREATEDATE<= '" + endDate + "'";
  605. }//一月按钮
  606. else if (types == 2)
  607. {
  608. string endDate = DateTime.Now.ToString();
  609. string startDate = DateTime.Now.AddMonths(-1).ToString();
  610. sql += " and F_CREATEDATE>= '" + startDate + "'";
  611. sql += " and F_CREATEDATE<= '" + endDate + "'";
  612. }//一年按钮
  613. else if (types == 3)
  614. {
  615. string endDate = DateTime.Now.ToString();
  616. string startDate = DateTime.Now.AddYears(-1).ToString();
  617. sql += " and F_CREATEDATE>= '" + startDate + "'";
  618. sql += " and F_CREATEDATE<= '" + endDate + "'";
  619. }
  620. DataTable dt = new DataTable();
  621. int recordCount = 0;
  622. Model.PageData<Model.T_Wo_WorkOrderBase> pageModel = new Model.PageData<Model.T_Wo_WorkOrderBase>();
  623. dt = BLL.PagerBLL.GetListPager(
  624. "T_Wo_WorkOrderBase",
  625. "F_WORKORDERID",
  626. "*,CONVERT(varchar,F_CREATEDATE, 120 ) as F_CREATEDATENew"
  627. + @" , replace(replace(CASE F_WORKORDERFROM WHEN '留言工单' THEN (SELECT top 1 F_RecFileUrl FROM dbo.T_Call_LeaveRecord WHERE F_CallId=F_KSHADDRESSCODE) WHEN '语音工单' THEN (SELECT top 1 FilePath FROM dbo.T_Call_CallRecords WHERE CallId=F_KSHADDRESSCODE AND FilePath!='') ELSE NULL END,'\','/'),'" + GetSysconfig("newFilePath") + "','" + GetSysconfig("newPlayPath") + "') as FilePath",
  628. //+ " ,(CASE F_WORKORDERFROM WHEN '留言工单' THEN (SELECT F_RecFileUrl FROM dbo.T_Call_LeaveRecord WHERE F_CallId=F_KSHADDRESSCODE) WHEN '语音工单' THEN (SELECT FilePath FROM dbo.T_Call_CallRecords WHERE CallId=F_KSHADDRESSCODE AND FilePath!='') ELSE NULL END ) as FilePath",
  629. sql,
  630. "ORDER BY F_CREATEDATE desc",
  631. limit,
  632. page,
  633. true,
  634. out recordCount);
  635. dataModel.code = 0;
  636. dataModel.count = recordCount;
  637. dataModel.data = dt;
  638. return JsonConvert.SerializeObject(dataModel);
  639. }
  640. [AcceptVerbs(HttpVerbs.Post)]
  641. public bool canDZ(int workid)
  642. {
  643. int n = orderBLL.GetRecordCount(string.Format("F_ROAD='{0}' AND F_WORKORDERID={1}", F_UserID, workid));
  644. if (n > 0)
  645. return true;
  646. else
  647. {
  648. Model.T_Wo_WorkOrderBase model = new T_Wo_WorkOrderBase();
  649. model.F_WORKORDERID = workid;
  650. model.F_ROAD = F_UserID.ToMyString();
  651. return orderBLL.UpdateDZuser(model);
  652. }
  653. }
  654. public int WorkOrderMyDataDZCount()
  655. {
  656. // string sql = string.Format(" F_WORKORDERSTATEID=4 and (F_HASTENCOUNTS=0 OR F_HASTENCOUNTS IS NULL) and (F_ROAD='{0}' Or F_ROAD='' Or F_ROAD IS NULL)", F_UserID);
  657. string sql = " F_WORKORDERSTATEID=4 and (F_HASTENCOUNTS=0 OR F_HASTENCOUNTS IS NULL)";
  658. return orderBLL.GetRecordCount(sql);
  659. }
  660. #endregion
  661. #region 已定责
  662. /// <summary>
  663. /// 已定责视图
  664. /// </summary>
  665. /// <param name="dtype">工单类型 1、所有待办工单 2、代办结工单</param>
  666. /// <returns></returns>
  667. public ActionResult WorkOrderMyListDZ1(int dtype)
  668. {
  669. WorkOrderMyModel model = new WorkOrderMyModel();
  670. model.DType = dtype;
  671. //业务类型字典表
  672. model.WorkOrderTypeModelList = GetWorkTypeModelList();
  673. //话务标志
  674. model.SeatFlag = F_SeatFlag;
  675. return View(model);
  676. }
  677. #region
  678. ///// <summary>
  679. ///// 录入定责结果
  680. ///// </summary>
  681. ///// <param name="workOrderBaseModel"></param>
  682. ///// <returns></returns>
  683. //[AcceptVerbs(HttpVerbs.Post)]
  684. //public bool SubmitOrderDZ1(T_Wo_WorkOrderNoticeInput modelinput)
  685. //{
  686. // if (modelinput.orderid == 0)
  687. // {
  688. // return false;
  689. // }
  690. // #region 处理工单事件分类
  691. // Model.T_Wo_WorkOrderBase modelorder = new T_Wo_WorkOrderBase();
  692. // modelorder.F_WORKORDERID = modelinput.orderid;
  693. // modelorder.F_PROVINCE = modelinput.ClassName1;
  694. // modelorder.F_CITY = modelinput.ClassName2;
  695. // modelorder.F_AREA = modelinput.ClassName3;
  696. // #endregion
  697. // if (modelinput.Noticelist != null)
  698. // {
  699. // noticeBLL.updatenum(modelinput.orderid);
  700. // foreach (T_Wo_WorkOrderNotice model in modelinput.Noticelist)
  701. // {
  702. // T_Wo_WorkOrderNotice modeladd = new T_Wo_WorkOrderNotice();
  703. // #region 前端传入参数
  704. // modeladd.OrderId = modelinput.orderid;
  705. // modeladd.DealAdvise = model.DealAdvise;
  706. // modeladd.DealResult = model.DealResult;
  707. // modeladd.NoticeDeptId = model.NoticeDeptId;
  708. // modeladd.NoticeDeptName = model.NoticeDeptName;
  709. // #endregion
  710. // modeladd.NoticeState = 1;
  711. // modeladd.NoticeType = 1;
  712. // modeladd.Userid = F_UserID;
  713. // modeladd.Username = F_UserName;
  714. // List<T_Wo_WorkOrderHistory> modelhisList = historyBll.GetModelList(string.Format(" F_INSTANCEID={0} AND F_OPTBTNID={1}", model.OrderId, model.NoticeDeptId));
  715. // foreach (T_Wo_WorkOrderHistory modelhis in modelhisList)
  716. // {
  717. // modeladd.NoticeDeptContent += modelhis.F_REMARK;
  718. // modeladd.NoticeDeptAdvise += modelhis.F_REMARK;
  719. // modeladd.NoticeUserid = modelhis.F_OPTUSERID.ToInt32();
  720. // modeladd.NoticeUsername = modelhis.F_UserName;
  721. // }
  722. // noticeBLL.Add(modeladd);
  723. // }
  724. // }
  725. // return orderBLL.UpdateDZClass(modelorder);
  726. //}
  727. #endregion
  728. /// <summary>
  729. /// 已定责列表
  730. /// </summary>
  731. /// <param name="F_RETURNVISITRESULT">满意度</param>
  732. /// <param name="limit">每页数据量</param>
  733. /// <param name="sqlWhere">查询条件</param>
  734. /// <returns></returns>
  735. [ActionName("WorkOrderMyDataDZ1")]
  736. [HttpGet]
  737. public string WorkOrderMyDataDZ1(DateTime? NowDateTime, int page, int limit, int? types, string dateParty,
  738. string workorderNum, string cusName, string phoneNumber,
  739. string userInfo, int? bussType, int? detailType, string Content,int? F_RETURNVISITRESULT)
  740. {
  741. bussType = 3;
  742. //数据结果集
  743. ResponseData dataModel = new ResponseData();
  744. //F_FILEFLAG 业务类型ID
  745. //F_WORKORDERSTATEID 0未处理 1处理中 2已办结 status
  746. //F_WORKORDERTYPEID 处理方式 1转单 3客服处理 GoType
  747. //F_REPAIRMANID 接入渠道 1语音 2留言 3微信 4微博 FromType
  748. //string sql = string.Format(" and F_WORKORDERTYPEID=1 and F_WORKORDERSTATEID=1 and F_WORKORDERID in (select F_INSTANCEID from T_Wo_WorkOrderHistory where F_WORKORDERSTATEID=0 and F_OPTUSERID={0})", F_UserID);
  749. string sql = "";
  750. //if (F_RoleID != 17)
  751. //{
  752. // sql = string.Format(" and F_WORKORDERSTATEID=5 and F_HOUSING='投诉' and F_REPAIRREQUEST='已定责' and F_ROAD='{0}' ", F_UserID);
  753. //}
  754. //else
  755. //{
  756. sql = string.Format(" and F_WORKORDERSTATEID=5 and F_HOUSING='投诉' and F_REPAIRREQUEST='已定责'");
  757. //}
  758. //满意度
  759. if (F_RETURNVISITRESULT>0)
  760. {
  761. sql += " and F_RETURNVISITRESULT ="+ F_RETURNVISITRESULT ;
  762. }
  763. //工单编号
  764. if (!string.IsNullOrEmpty(workorderNum))
  765. {
  766. sql += " and F_CODE like '%" + workorderNum.Trim() + "%'";
  767. }
  768. //客户姓名
  769. if (!string.IsNullOrEmpty(cusName))
  770. {
  771. sql += " and F_CUSTOMERNAME like '%" + cusName.Trim() + "%'";
  772. }
  773. //客户电话
  774. if (!string.IsNullOrEmpty(phoneNumber))
  775. {
  776. sql += " and F_CUSTOMERTELEPHONE like '%" + phoneNumber.Trim() + "%'";
  777. }
  778. //坐席工号
  779. if (!string.IsNullOrEmpty(userInfo))
  780. {
  781. sql += " and F_LINKMAN like '%" + userInfo.Trim() + "%'";
  782. }
  783. //业务类别
  784. if (bussType != null && bussType > 0)
  785. {
  786. sql += " and F_FILEFLAG =" + bussType;
  787. }
  788. //业务类型
  789. if (detailType != null && detailType > 0)
  790. {
  791. sql += " and F_REPAIRLEVEL =" + detailType;
  792. }
  793. //内容
  794. if (!string.IsNullOrEmpty(Content))
  795. {
  796. sql += " and F_CONTENT like '%" + Content.Trim() + "%'";
  797. }
  798. //查询按钮
  799. if (types == 0)
  800. {
  801. if (!string.IsNullOrEmpty(dateParty))
  802. {
  803. string startDate = dateParty.Substring(0, 10);
  804. string endDate = dateParty.Substring(12);
  805. sql += " and F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  806. sql += " and F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  807. }
  808. }//一周按钮
  809. else if (types == 1)
  810. {
  811. string endDate = DateTime.Now.ToString();
  812. string startDate = DateTime.Now.AddDays(-7).ToString();
  813. sql += " and F_CREATEDATE>= '" + startDate + "'";
  814. sql += " and F_CREATEDATE<= '" + endDate + "'";
  815. }//一月按钮
  816. else if (types == 2)
  817. {
  818. string endDate = DateTime.Now.ToString();
  819. string startDate = DateTime.Now.AddMonths(-1).ToString();
  820. sql += " and F_CREATEDATE>= '" + startDate + "'";
  821. sql += " and F_CREATEDATE<= '" + endDate + "'";
  822. }//一年按钮
  823. else if (types == 3)
  824. {
  825. string endDate = DateTime.Now.ToString();
  826. string startDate = DateTime.Now.AddYears(-1).ToString();
  827. sql += " and F_CREATEDATE>= '" + startDate + "'";
  828. sql += " and F_CREATEDATE<= '" + endDate + "'";
  829. }
  830. DataTable dt = new DataTable();
  831. int recordCount = 0;
  832. Model.PageData<Model.T_Wo_WorkOrderBase> pageModel = new Model.PageData<Model.T_Wo_WorkOrderBase>();
  833. dt = BLL.PagerBLL.GetListPager(
  834. "T_Wo_WorkOrderBase",
  835. "F_WORKORDERID",
  836. "*,CONVERT(varchar,F_CREATEDATE, 120 ) as F_CREATEDATENew"
  837. + @" , replace(replace(CASE F_WORKORDERFROM WHEN '留言工单' THEN (SELECT top 1 F_RecFileUrl FROM dbo.T_Call_LeaveRecord WHERE F_CallId=F_KSHADDRESSCODE) WHEN '语音工单' THEN (SELECT top 1 FilePath FROM dbo.T_Call_CallRecords WHERE CallId=F_KSHADDRESSCODE AND FilePath!='') ELSE NULL END,'\','/'),'" + GetSysconfig("newFilePath") + "','" + GetSysconfig("newPlayPath") + "') as FilePath",
  838. //+ " ,(CASE F_WORKORDERFROM WHEN '留言工单' THEN (SELECT F_RecFileUrl FROM dbo.T_Call_LeaveRecord WHERE F_CallId=F_KSHADDRESSCODE) WHEN '语音工单' THEN (SELECT FilePath FROM dbo.T_Call_CallRecords WHERE CallId=F_KSHADDRESSCODE AND FilePath!='') ELSE NULL END ) as FilePath",
  839. sql,
  840. "ORDER BY F_CREATEDATE desc",
  841. limit,
  842. page,
  843. true,
  844. out recordCount);
  845. dataModel.code = 0;
  846. dataModel.count = recordCount;
  847. dataModel.data = dt;
  848. return JsonConvert.SerializeObject(dataModel);
  849. }
  850. #endregion
  851. #region 已处理建议
  852. /// <summary>
  853. /// 已处理建议视图
  854. /// </summary>
  855. /// <param name="dtype">工单类型 1、所有待办工单 2、代办结工单</param>
  856. /// <returns></returns>
  857. public ActionResult WorkOrderMyListJY(int dtype)
  858. {
  859. WorkOrderMyModel model = new WorkOrderMyModel();
  860. model.DType = dtype;
  861. //业务类型字典表
  862. model.WorkOrderTypeModelList = GetWorkTypeModelList();
  863. //话务标志
  864. model.SeatFlag = F_SeatFlag;
  865. return View(model);
  866. }
  867. /// <summary>
  868. /// 获取工单信息
  869. /// </summary>
  870. /// <param name="page">当前页码</param>
  871. /// <param name="limit">每页数据量</param>
  872. /// <param name="sqlWhere">查询条件</param>
  873. /// <returns></returns>
  874. [ActionName("WorkOrderMyDataJY")]
  875. [HttpGet]
  876. public string WorkOrderMyDataJY(DateTime? NowDateTime, int page, int limit, int? types, string dateParty,
  877. string workorderNum, string cusName, string phoneNumber, string userInfo, int? bussType, int? detailType, string Content)
  878. {
  879. //数据结果集
  880. ResponseData dataModel = new ResponseData();
  881. string sql = " and F_WORKORDERSTATEID=5 and F_HOUSING='建议' ";
  882. //工单编号
  883. if (!string.IsNullOrEmpty(workorderNum))
  884. {
  885. sql += " and t.F_CODE like '%" + workorderNum.Trim() + "%'";
  886. }
  887. //客户姓名
  888. if (!string.IsNullOrEmpty(cusName))
  889. {
  890. sql += " and t.F_CUSTOMERNAME like '%" + cusName.Trim() + "%'";
  891. }
  892. //客户电话
  893. if (!string.IsNullOrEmpty(phoneNumber))
  894. {
  895. sql += " and t.F_CUSTOMERTELEPHONE like '%" + phoneNumber.Trim() + "%'";
  896. }
  897. //坐席工号
  898. if (!string.IsNullOrEmpty(userInfo))
  899. {
  900. sql += " and t.F_LINKMAN like '%" + userInfo.Trim() + "%'";
  901. }
  902. #region
  903. //状态 F_WORKORDERSTATEID 0未处理 1处理中 2已办结(结束) 3待回访 4待定责 5已定责
  904. //if (status != null)
  905. //{
  906. // sql += " and t.F_WORKORDERSTATEID =" + status;
  907. //}
  908. #endregion
  909. //业务类别
  910. if (bussType != null && bussType > 0)
  911. {
  912. sql += " and t.F_FILEFLAG =" + bussType;
  913. }
  914. //业务类型
  915. if (detailType != null && detailType > 0)
  916. {
  917. sql += " and t.F_REPAIRLEVEL =" + detailType;
  918. }
  919. //内容
  920. if (!string.IsNullOrEmpty(Content))
  921. {
  922. sql += " and t.F_CONTENT like '%" + Content.Trim() + "%'";
  923. }
  924. #region
  925. ////处理方式 F_WORKORDERTYPEID 处理方式 1转单 3客服处理
  926. //if (GoType != null && GoType > 0)
  927. //{
  928. // sql += " and t.F_WORKORDERTYPEID =" + GoType;
  929. //}
  930. ////接入渠道 1语音 2留言 3微信 4微博
  931. //if (FromType != null && FromType > 0)
  932. //{
  933. // sql += " and t.F_REPAIRMANID =" + FromType;
  934. //}
  935. #endregion
  936. //查询按钮
  937. if (types == 0 || types == null)
  938. {
  939. if (!string.IsNullOrEmpty(dateParty))
  940. {
  941. string startDate = dateParty.Substring(0, 10);
  942. string endDate = dateParty.Substring(12);
  943. sql += " and t.F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  944. sql += " and t.F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  945. }
  946. else
  947. {
  948. //string endDate = DateTime.Now.ToString("yyyy-MM-dd");
  949. //string startDate = DateTime.Now.ToString("yyyy-MM-dd");
  950. //sql += " and t.F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  951. //sql += " and t.F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  952. string endDate = DateTime.Now.ToString("yyyy-MM-dd");
  953. string startDate = DateTime.Now.AddMonths(-1).ToString("yyyy-MM-dd");
  954. sql += " and t.F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  955. sql += " and t.F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  956. }
  957. }//一周按钮
  958. else if (types == 1)
  959. {
  960. string endDate = DateTime.Now.ToString("yyyy-MM-dd");
  961. string startDate = DateTime.Now.AddDays(-7).ToString("yyyy-MM-dd");
  962. sql += " and t.F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  963. sql += " and t.F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  964. }//一月按钮
  965. else if (types == 2)
  966. {
  967. string endDate = DateTime.Now.ToString("yyyy-MM-dd");
  968. string startDate = DateTime.Now.AddMonths(-1).ToString("yyyy-MM-dd");
  969. sql += " and t.F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  970. sql += " and t.F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  971. }//一年按钮
  972. else if (types == 3)
  973. {
  974. string endDate = DateTime.Now.ToString("yyyy-MM-dd");
  975. string startDate = DateTime.Now.AddYears(-1).ToString("yyyy-MM-dd");
  976. sql += " and t.F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  977. sql += " and t.F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  978. }
  979. //一天按钮
  980. else if (types == 4)
  981. {
  982. string endDate = DateTime.Now.ToString("yyyy-MM-dd");
  983. string startDate = DateTime.Now.ToString("yyyy-MM-dd");
  984. sql += " and t.F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  985. sql += " and t.F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  986. }
  987. string tableNew = "(select DISTINCT t.* from T_Wo_WorkOrderBase t LEFT JOIN T_Wo_WorkOrderHistory h ON t.F_WORKORDERID=h.F_INSTANCEID LEFT JOIN T_Sys_UserAccount u ON t.F_USERID= u.F_UserId ) as t";
  988. DataTable dt = new DataTable();
  989. int recordCount = 0;
  990. Model.PageData<Model.T_Wo_WorkOrderBase> pageModel = new Model.PageData<Model.T_Wo_WorkOrderBase>();
  991. dt = BLL.PagerBLL.GetListPager(
  992. tableNew,
  993. "F_WORKORDERID",
  994. " t.*,CONVERT(varchar,t.F_CREATEDATE, 120 ) as F_CREATEDATENew"
  995. + @" , replace(replace(CASE F_WORKORDERFROM WHEN '留言工单' THEN (SELECT top 1 F_RecFileUrl FROM dbo.T_Call_LeaveRecord WHERE F_CallId=t.F_KSHADDRESSCODE) WHEN '语音工单' THEN (SELECT top 1 FilePath FROM dbo.T_Call_CallRecords WHERE CallId=t.F_KSHADDRESSCODE) ELSE NULL END,'\','/'),'" + GetSysconfig("newFilePath") + "','" + GetSysconfig("newPlayPath") + "') as FilePath"
  996. ,
  997. sql,
  998. "ORDER BY t.F_CREATEDATE desc",
  999. limit,
  1000. page,
  1001. true,
  1002. out recordCount);
  1003. dataModel.code = 0;
  1004. dataModel.count = recordCount;
  1005. dataModel.data = dt;
  1006. return JsonConvert.SerializeObject(dataModel);
  1007. }
  1008. #endregion
  1009. #region 相关通知
  1010. /// <summary>
  1011. /// 已定责视图
  1012. /// </summary>
  1013. /// <param name="dtype">工单类型 1、所有待办工单 2、代办结工单</param>
  1014. /// <returns></returns>
  1015. public ActionResult WorkOrderMyListNotice(int dtype)
  1016. {
  1017. WorkOrderMyModel model = new WorkOrderMyModel();
  1018. model.DType = dtype;
  1019. //业务类型字典表
  1020. model.WorkOrderTypeModelList = GetWorkTypeModelList();
  1021. //话务标志
  1022. model.SeatFlag = F_SeatFlag;
  1023. return View(model);
  1024. }
  1025. /// <summary>
  1026. /// 相关表扬
  1027. /// </summary>
  1028. /// <param name="page">当前页码</param>
  1029. /// <param name="limit">每页数据量</param>
  1030. /// <param name="sqlWhere">查询条件</param>
  1031. /// <returns></returns>
  1032. [ActionName("WorkOrderMyDataNotice")]
  1033. [HttpGet]
  1034. public string WorkOrderMyDataNotice(DateTime? NowDateTime, int page, int limit, int? types, string dateParty,
  1035. string workorderNum, string cusName, string phoneNumber,
  1036. string userInfo, int? bussType, int? detailType, string Content, int NoticeType)
  1037. {
  1038. //数据结果集
  1039. ResponseData dataModel = new ResponseData();
  1040. //F_FILEFLAG 业务类型ID
  1041. //F_WORKORDERSTATEID 0未处理 1处理中 2已办结 status
  1042. //F_WORKORDERTYPEID 处理方式 1转单 3客服处理 GoType
  1043. //F_REPAIRMANID 接入渠道 1语音 2留言 3微信 4微博 FromType
  1044. //string sql = string.Format(" and F_WORKORDERTYPEID=1 and F_WORKORDERSTATEID=1 and F_WORKORDERID in (select F_INSTANCEID from T_Wo_WorkOrderHistory where F_WORKORDERSTATEID=0 and F_OPTUSERID={0})", F_UserID);
  1045. string sql = string.Format(" and F_WORKORDERTYPEID=3 and F_WORKORDERSTATEID in (2,5) and T2.NoticeDeptId={0} AND NoticeType={1} AND NoticeState=1", F_DeptId, NoticeType);
  1046. if (NoticeType == 1)
  1047. {
  1048. sql = string.Format(" and F_HOUSING='投诉' and F_WORKORDERSTATEID=5 and T2.NoticeDeptId={0} AND NoticeType={1} AND NoticeState=1", F_DeptId, NoticeType);
  1049. }
  1050. //工单编号
  1051. if (!string.IsNullOrEmpty(workorderNum))
  1052. {
  1053. sql += " and F_CODE like '%" + workorderNum.Trim() + "%'";
  1054. }
  1055. //客户姓名
  1056. if (!string.IsNullOrEmpty(cusName))
  1057. {
  1058. sql += " and F_CUSTOMERNAME like '%" + cusName.Trim() + "%'";
  1059. }
  1060. //客户电话
  1061. if (!string.IsNullOrEmpty(phoneNumber))
  1062. {
  1063. sql += " and F_CUSTOMERTELEPHONE like '%" + phoneNumber.Trim() + "%'";
  1064. }
  1065. //坐席工号
  1066. if (!string.IsNullOrEmpty(userInfo))
  1067. {
  1068. sql += " and F_LINKMAN like '%" + userInfo.Trim() + "%'";
  1069. }
  1070. //业务类别
  1071. if (bussType != null && bussType > 0)
  1072. {
  1073. sql += " and F_FILEFLAG =" + bussType;
  1074. }
  1075. //业务类型
  1076. if (detailType != null && detailType > 0)
  1077. {
  1078. sql += " and F_REPAIRLEVEL =" + detailType;
  1079. }
  1080. //内容
  1081. if (!string.IsNullOrEmpty(Content))
  1082. {
  1083. sql += " and F_CONTENT like '%" + Content.Trim() + "%'";
  1084. }
  1085. //查询按钮
  1086. if (types == 0)
  1087. {
  1088. if (!string.IsNullOrEmpty(dateParty))
  1089. {
  1090. //if (F_UserName == "闫艳飞")
  1091. //{
  1092. // sql += " and F_CREATEDATE>=' 2021-06-21 00:00:00'";
  1093. //}
  1094. string startDate = dateParty.Substring(0, 10);
  1095. string endDate = dateParty.Substring(12);
  1096. sql += " and F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  1097. sql += " and F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  1098. }
  1099. }//一周按钮
  1100. else if (types == 1)
  1101. {
  1102. //if (F_UserName == "闫艳飞")
  1103. //{
  1104. // sql += " and F_CREATEDATE>=' 2021-06-21 00:00:00'";
  1105. //}
  1106. string endDate = DateTime.Now.ToString();
  1107. string startDate = DateTime.Now.AddDays(-7).ToString();
  1108. sql += " and F_CREATEDATE>= '" + startDate + "'";
  1109. sql += " and F_CREATEDATE<= '" + endDate + "'";
  1110. }//一月按钮
  1111. else if (types == 2)
  1112. {
  1113. //if (F_UserName == "闫艳飞")
  1114. //{
  1115. // sql += " and F_CREATEDATE>=' 2021-06-21 00:00:00'";
  1116. //}
  1117. string endDate = DateTime.Now.ToString();
  1118. string startDate = DateTime.Now.AddMonths(-1).ToString();
  1119. sql += " and F_CREATEDATE>= '" + startDate + "'";
  1120. sql += " and F_CREATEDATE<= '" + endDate + "'";
  1121. }//一年按钮
  1122. else if (types == 3)
  1123. {
  1124. //if (F_UserName == "闫艳飞")
  1125. //{
  1126. // sql += " and F_CREATEDATE>=' 2021-06-21 00:00:00'";
  1127. //}
  1128. string endDate = DateTime.Now.ToString();
  1129. string startDate = DateTime.Now.AddYears(-1).ToString();
  1130. sql += " and F_CREATEDATE>= '" + startDate + "'";
  1131. sql += " and F_CREATEDATE<= '" + endDate + "'";
  1132. }
  1133. DataTable dt = new DataTable();
  1134. int recordCount = 0;
  1135. Model.PageData<Model.T_Wo_WorkOrderBase> pageModel = new Model.PageData<Model.T_Wo_WorkOrderBase>();
  1136. dt = BLL.PagerBLL.GetTableList(
  1137. " T_Wo_WorkOrderBase T1 Inner join T_Wo_WorkOrderNotice T2 On T1.F_WORKORDERID=T2.OrderId ",
  1138. "F_WORKORDERID",
  1139. "T1.*,CONVERT(varchar,F_CREATEDATE, 120 ) as F_CREATEDATENew,NoticeDeptId,NoticeDeptName"
  1140. + @" , replace(replace(CASE F_WORKORDERFROM WHEN '留言工单' THEN (SELECT top 1 F_RecFileUrl FROM dbo.T_Call_LeaveRecord WHERE F_CallId=F_KSHADDRESSCODE) WHEN '语音工单' THEN (SELECT top 1 FilePath FROM dbo.T_Call_CallRecords WHERE CallId=F_KSHADDRESSCODE AND FilePath!='') ELSE NULL END,'\','/'),'" + GetSysconfig("newFilePath") + "','" + GetSysconfig("newPlayPath") + "') as FilePath",
  1141. //+ " ,(CASE F_WORKORDERFROM WHEN '留言工单' THEN (SELECT F_RecFileUrl FROM dbo.T_Call_LeaveRecord WHERE F_CallId=F_KSHADDRESSCODE) WHEN '语音工单' THEN (SELECT FilePath FROM dbo.T_Call_CallRecords WHERE CallId=F_KSHADDRESSCODE AND FilePath!='') ELSE NULL END ) as FilePath",
  1142. sql,
  1143. " F_CREATEDATE desc",
  1144. limit,
  1145. page,
  1146. out recordCount);
  1147. dataModel.code = 0;
  1148. dataModel.count = recordCount;
  1149. dataModel.data = dt;
  1150. return JsonConvert.SerializeObject(dataModel);
  1151. }
  1152. #endregion
  1153. #region 超时工单
  1154. /// <summary>
  1155. /// 视图
  1156. /// </summary>
  1157. /// <param name="dtype">工单类型 1、所有待办工单 2、代办结工单</param>
  1158. /// <returns></returns>
  1159. public ActionResult OverOrderView(int dtype=0)
  1160. {
  1161. CallScreenModel callScreenModel = new CallScreenModel();
  1162. //业务类型字典表
  1163. callScreenModel.WorkOrderTypeModelList = GetWorkTypeModelList();
  1164. //业务类型字典表
  1165. callScreenModel.GoTypeModelList = GetCodeType("CLFS");
  1166. //话务标志
  1167. callScreenModel.SeatFlag = F_SeatFlag;
  1168. //1、所有工单页面2、工单编辑页面
  1169. callScreenModel.OrderType = 1;
  1170. return View(callScreenModel);
  1171. }
  1172. /// <summary>
  1173. /// 获取工单信息
  1174. /// </summary>
  1175. /// <param name="page">当前页码</param>
  1176. /// <param name="limit">每页数据量</param>
  1177. /// <param name="sqlWhere">查询条件</param>
  1178. /// <returns></returns>
  1179. [ActionName("OverOrderData")]
  1180. [HttpGet]
  1181. public string OverOrderData(DateTime? NowDateTime, int page, int limit, int? types, string dateParty,
  1182. string workorderNum, string cusName, string phoneNumber, string userInfo, int? status, int? bussType, int? detailType, string Content, int? GoType, int? FromType,int? overtime)
  1183. {
  1184. //数据结果集
  1185. ResponseData dataModel = new ResponseData();
  1186. string sql = " AND t.F_OVERTIMES>0 AND t.F_HOUSING IN ('投诉','建议','咨询')";
  1187. //工单编号
  1188. if (!string.IsNullOrEmpty(workorderNum))
  1189. {
  1190. sql += " and t.F_CODE like '%" + workorderNum.Trim() + "%'";
  1191. }
  1192. //客户姓名
  1193. if (!string.IsNullOrEmpty(cusName))
  1194. {
  1195. sql += " and t.F_CUSTOMERNAME like '%" + cusName.Trim() + "%'";
  1196. }
  1197. //客户电话
  1198. if (!string.IsNullOrEmpty(phoneNumber))
  1199. {
  1200. sql += " and t.F_CUSTOMERTELEPHONE like '%" + phoneNumber.Trim() + "%'";
  1201. }
  1202. //坐席工号
  1203. if (!string.IsNullOrEmpty(userInfo))
  1204. {
  1205. sql += " and t.F_LINKMAN like '%" + userInfo.Trim() + "%'";
  1206. }
  1207. //状态 F_WORKORDERSTATEID 0未处理 1处理中 2已办结
  1208. if (status != null)
  1209. {
  1210. sql += " and t.F_WORKORDERSTATEID =" + status;
  1211. }
  1212. //业务类别
  1213. if (bussType != null && bussType > 0)
  1214. {
  1215. sql += " and t.F_FILEFLAG =" + bussType;
  1216. }
  1217. //业务类型
  1218. if (detailType != null && detailType > 0)
  1219. {
  1220. sql += " and t.F_REPAIRLEVEL =" + detailType;
  1221. }
  1222. #region
  1223. //定责次数
  1224. //if (F_HASTENCOUNTS != null)
  1225. //{
  1226. // if (F_HASTENCOUNTS == 0)
  1227. // {
  1228. // sql += " AND (t.F_HASTENCOUNTS is null OR t.F_HASTENCOUNTS =0) ";
  1229. // }
  1230. // else
  1231. // {
  1232. // sql += " AND t.F_HASTENCOUNTS >0 ";
  1233. // }
  1234. //}
  1235. #endregion
  1236. //内容
  1237. if (!string.IsNullOrEmpty(Content))
  1238. {
  1239. sql += " and t.F_CONTENT like '%" + Content.Trim() + "%'";
  1240. }
  1241. //处理方式 F_WORKORDERTYPEID 处理方式 1转单 3客服处理
  1242. if (GoType != null && GoType > 0)
  1243. {
  1244. sql += " and t.F_WORKORDERTYPEID =" + GoType;
  1245. }
  1246. //接入渠道 1语音 2留言 3微信 4微博
  1247. if (FromType != null && FromType > 0)
  1248. {
  1249. sql += " and t.F_REPAIRMANID =" + FromType;
  1250. }
  1251. //查询按钮
  1252. if (types == 0 || types == null)
  1253. {
  1254. if (!string.IsNullOrEmpty(dateParty))
  1255. {
  1256. string startDate = dateParty.Substring(0, 10);
  1257. string endDate = dateParty.Substring(12);
  1258. sql += " and t.F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  1259. sql += " and t.F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  1260. }
  1261. else
  1262. {
  1263. string endDate = DateTime.Now.ToString("yyyy-MM-dd");
  1264. string startDate = DateTime.Now.ToString("yyyy-MM-dd");
  1265. sql += " and t.F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  1266. sql += " and t.F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  1267. }
  1268. }//一周按钮
  1269. else if (types == 1)
  1270. {
  1271. string endDate = DateTime.Now.ToString("yyyy-MM-dd");
  1272. string startDate = DateTime.Now.AddDays(-7).ToString("yyyy-MM-dd");
  1273. sql += " and t.F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  1274. sql += " and t.F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  1275. }//一月按钮
  1276. else if (types == 2)
  1277. {
  1278. string endDate = DateTime.Now.ToString("yyyy-MM-dd");
  1279. string startDate = DateTime.Now.AddMonths(-1).ToString("yyyy-MM-dd");
  1280. sql += " and t.F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  1281. sql += " and t.F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  1282. }//一年按钮
  1283. else if (types == 3)
  1284. {
  1285. string endDate = DateTime.Now.ToString("yyyy-MM-dd");
  1286. string startDate = DateTime.Now.AddYears(-1).ToString("yyyy-MM-dd");
  1287. sql += " and t.F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  1288. sql += " and t.F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  1289. }
  1290. //一天按钮
  1291. else if (types == 4)
  1292. {
  1293. string endDate = DateTime.Now.ToString("yyyy-MM-dd");
  1294. string startDate = DateTime.Now.ToString("yyyy-MM-dd");
  1295. sql += " and t.F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  1296. sql += " and t.F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  1297. }
  1298. string tableNew = string.Format("(select DISTINCT t.* from T_Wo_WorkOrderBase t LEFT JOIN T_Wo_WorkOrderHistory h ON t.F_WORKORDERID=h.F_INSTANCEID LEFT JOIN T_Sys_UserAccount u ON t.F_USERID= u.F_UserId where (u.F_DeptId={0} OR h.F_OPTBTNID={0})) as t", F_DeptId);
  1299. DataTable dt = new DataTable();
  1300. int recordCount = 0;
  1301. Model.PageData<Model.T_Wo_WorkOrderBase> pageModel = new Model.PageData<Model.T_Wo_WorkOrderBase>();
  1302. dt = BLL.PagerBLL.GetListPager(
  1303. tableNew,
  1304. "F_WORKORDERID",
  1305. " t.*,CONVERT(varchar,t.F_CREATEDATE, 120 ) as F_CREATEDATENew,CONVERT(VARCHAR(10),F_OVERTIMES/3600)+'时'+CONVERT(VARCHAR(10),F_OVERTIMES%3600/60)+'分'+CONVERT(VARCHAR(10),F_OVERTIMES%3600%60)+'秒' AS F_OVERTIME"
  1306. + @" , replace(replace(CASE F_WORKORDERFROM WHEN '留言工单' THEN (SELECT top 1 F_RecFileUrl FROM dbo.T_Call_LeaveRecord WHERE F_CallId=t.F_KSHADDRESSCODE) WHEN '语音工单' THEN (SELECT top 1 FilePath FROM dbo.T_Call_CallRecords WHERE CallId=t.F_KSHADDRESSCODE) ELSE NULL END,'\','/'),'" + GetSysconfig("newFilePath") + "','" + GetSysconfig("newPlayPath") + "') as FilePath"
  1307. ,
  1308. sql,
  1309. "ORDER BY t.F_CREATEDATE desc",
  1310. limit,
  1311. page,
  1312. true,
  1313. out recordCount);
  1314. dataModel.code = 0;
  1315. dataModel.count = recordCount;
  1316. dataModel.data = dt;
  1317. return JsonConvert.SerializeObject(dataModel);
  1318. }
  1319. #endregion
  1320. #region 全部工单
  1321. /// <summary>
  1322. /// 获取所有工单信息
  1323. /// </summary>
  1324. /// <returns></returns>
  1325. public ActionResult WorkOrderAllList(int? orderType)
  1326. {
  1327. CallScreenModel callScreenModel = new CallScreenModel();
  1328. //业务类型字典表
  1329. callScreenModel.WorkOrderTypeModelList = GetWorkTypeModelList();
  1330. //业务类型字典表
  1331. callScreenModel.GoTypeModelList = GetCodeType("CLFS");
  1332. //话务标志
  1333. callScreenModel.SeatFlag = F_SeatFlag;
  1334. //1、所有工单页面2、工单编辑页面
  1335. if (orderType != null && orderType > 0)
  1336. {
  1337. callScreenModel.OrderType = int.Parse(orderType.ToString());
  1338. }
  1339. else
  1340. {
  1341. callScreenModel.OrderType = 1;
  1342. }
  1343. return View(callScreenModel);
  1344. }
  1345. /// <summary>
  1346. /// 获取工单信息
  1347. /// </summary>
  1348. /// <param name="page">当前页码</param>
  1349. /// <param name="limit">每页数据量</param>
  1350. /// <param name="sqlWhere">查询条件</param>
  1351. /// <returns></returns>
  1352. [ActionName("WorkOrderAllData")]
  1353. [HttpGet]
  1354. public string WorkOrderAllList(DateTime? NowDateTime, int page, int limit, int? types, string dateParty,
  1355. string workorderNum, string cusName, string phoneNumber, string userInfo, int? status, int? bussType, int? detailType, string Content, int? GoType, int? FromType, int? F_HASTENCOUNTS,int? turnout)
  1356. {
  1357. //数据结果集
  1358. ResponseData dataModel = new ResponseData();
  1359. string sql = "";
  1360. //未按时转出
  1361. if (turnout.ToInt32() > 0)
  1362. {
  1363. sql += " and t.turntime =0 ";
  1364. }
  1365. //工单编号
  1366. if (!string.IsNullOrEmpty(workorderNum))
  1367. {
  1368. sql += " and t.F_CODE like '%" + workorderNum.Trim() + "%'";
  1369. }
  1370. //客户姓名
  1371. if (!string.IsNullOrEmpty(cusName))
  1372. {
  1373. sql += " and t.F_CUSTOMERNAME like '%" + cusName.Trim() + "%'";
  1374. }
  1375. //客户电话
  1376. if (!string.IsNullOrEmpty(phoneNumber))
  1377. {
  1378. sql += " and t.F_CUSTOMERTELEPHONE like '%" + phoneNumber.Trim() + "%'";
  1379. }
  1380. //坐席工号
  1381. if (!string.IsNullOrEmpty(userInfo))
  1382. {
  1383. sql += " and t.F_LINKMAN like '%" + userInfo.Trim() + "%'";
  1384. }
  1385. //状态 F_WORKORDERSTATEID 0未处理 1处理中 2已办结(结束) 3待回访 4待定责 5已定责
  1386. if (status != null)
  1387. {
  1388. if (status == 6)
  1389. {
  1390. sql += " and t.F_WORKORDERSTATEID =5 and t.F_REPAIRREQUEST='已定责'";
  1391. }
  1392. else if (status == 5)
  1393. {
  1394. sql += " and t.F_WORKORDERSTATEID =5 and t.F_REPAIRREQUEST='已处理'";
  1395. }
  1396. else
  1397. {
  1398. sql += " and t.F_WORKORDERSTATEID =" + status;
  1399. }
  1400. }
  1401. //业务类别
  1402. if (bussType != null && bussType > 0)
  1403. {
  1404. sql += " and t.F_FILEFLAG =" + bussType;
  1405. }
  1406. //业务类型
  1407. if (detailType != null && detailType > 0)
  1408. {
  1409. sql += " and t.F_REPAIRLEVEL =" + detailType;
  1410. }
  1411. #region
  1412. //定责次数
  1413. //if (F_HASTENCOUNTS != null)
  1414. //{
  1415. // if (F_HASTENCOUNTS == 0)
  1416. // {
  1417. // sql += " AND (t.F_HASTENCOUNTS is null OR t.F_HASTENCOUNTS =0) ";
  1418. // }
  1419. // else
  1420. // {
  1421. // sql += " AND t.F_HASTENCOUNTS >0 ";
  1422. // }
  1423. //}
  1424. #endregion
  1425. //内容
  1426. if (!string.IsNullOrEmpty(Content))
  1427. {
  1428. sql += " and t.F_CONTENT like '%" + Content.Trim() + "%'";
  1429. }
  1430. //处理方式 F_WORKORDERTYPEID 处理方式 1转单 3客服处理
  1431. if (GoType != null && GoType > 0)
  1432. {
  1433. sql += " and t.F_WORKORDERTYPEID =" + GoType;
  1434. }
  1435. //接入渠道 1语音 2留言 3微信 4微博
  1436. if (FromType != null && FromType > 0)
  1437. {
  1438. sql += " and t.F_REPAIRMANID =" + FromType;
  1439. }
  1440. //查询按钮
  1441. if (types == 0 || types == null)
  1442. {
  1443. if (!string.IsNullOrEmpty(dateParty))
  1444. {
  1445. string startDate = dateParty.Substring(0, 10);
  1446. string endDate = dateParty.Substring(12);
  1447. sql += " and t.F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  1448. sql += " and t.F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  1449. }
  1450. else
  1451. {
  1452. string endDate = DateTime.Now.ToString("yyyy-MM-dd");
  1453. string startDate = DateTime.Now.ToString("yyyy-MM-dd");
  1454. sql += " and t.F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  1455. sql += " and t.F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  1456. }
  1457. }//一周按钮
  1458. else if (types == 1)
  1459. {
  1460. string endDate = DateTime.Now.ToString("yyyy-MM-dd");
  1461. string startDate = DateTime.Now.AddDays(-7).ToString("yyyy-MM-dd");
  1462. sql += " and t.F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  1463. sql += " and t.F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  1464. }//一月按钮
  1465. else if (types == 2)
  1466. {
  1467. string endDate = DateTime.Now.ToString("yyyy-MM-dd");
  1468. string startDate = DateTime.Now.AddMonths(-1).ToString("yyyy-MM-dd");
  1469. sql += " and t.F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  1470. sql += " and t.F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  1471. }//一年按钮
  1472. else if (types == 3)
  1473. {
  1474. string endDate = DateTime.Now.ToString("yyyy-MM-dd");
  1475. string startDate = DateTime.Now.AddYears(-1).ToString("yyyy-MM-dd");
  1476. sql += " and t.F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  1477. sql += " and t.F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  1478. }
  1479. //一天按钮
  1480. else if (types == 4)
  1481. {
  1482. string endDate = DateTime.Now.ToString("yyyy-MM-dd");
  1483. string startDate = DateTime.Now.ToString("yyyy-MM-dd");
  1484. sql += " and t.F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  1485. sql += " and t.F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  1486. }
  1487. string tableNew = "(select DISTINCT t.* ";
  1488. tableNew += ", case WHEN F_SENTORDERTIME IS NULL AND DATEDIFF(minute, DATEADD(day,1,F_CREATEDATE), GETDATE())> 0 THEN 0 WHEN F_SENTORDERTIME IS NULL THEN 1 WHEN DATEDIFF(minute, DATEADD(day,1,F_CREATEDATE), F_SENTORDERTIME)> 0 THEN 0 ELSE 1 END AS turntime ";
  1489. tableNew += " from T_Wo_WorkOrderBase t LEFT JOIN T_Wo_WorkOrderHistory h ON t.F_WORKORDERID=h.F_INSTANCEID LEFT JOIN T_Sys_UserAccount u ON t.F_USERID= u.F_UserId";
  1490. tableNew += " ) as t";
  1491. #region
  1492. //if (F_RoleID == 17)
  1493. //{
  1494. // tableNew += " ) as t";
  1495. //}
  1496. //else
  1497. //{
  1498. // tableNew += string.Format(" where (u.F_DeptId ={0} OR h.F_OPTBTNID ={0})) as t", F_DeptId);
  1499. //}
  1500. #endregion
  1501. DataTable dt = new DataTable();
  1502. int recordCount = 0;
  1503. Model.PageData<Model.T_Wo_WorkOrderBase> pageModel = new Model.PageData<Model.T_Wo_WorkOrderBase>();
  1504. dt = BLL.PagerBLL.GetListPager(
  1505. tableNew,
  1506. "F_WORKORDERID",
  1507. " t.*,CONVERT(varchar,t.F_CREATEDATE, 120 ) as F_CREATEDATENew"
  1508. + @" , replace(replace(CASE F_WORKORDERFROM WHEN '留言工单' THEN (SELECT top 1 F_RecFileUrl FROM dbo.T_Call_LeaveRecord WHERE F_CallId=t.F_KSHADDRESSCODE) WHEN '语音工单' THEN (SELECT top 1 FilePath FROM dbo.T_Call_CallRecords WHERE CallId=t.F_KSHADDRESSCODE) ELSE NULL END,'\','/'),'" + GetSysconfig("newFilePath") + "','" + GetSysconfig("newPlayPath") + "') as FilePath"
  1509. ,
  1510. sql,
  1511. "ORDER BY t.F_CREATEDATE desc",
  1512. limit,
  1513. page,
  1514. true,
  1515. out recordCount);
  1516. dataModel.code = 0;
  1517. dataModel.count = recordCount;
  1518. dataModel.data = dt;
  1519. return JsonConvert.SerializeObject(dataModel);
  1520. }
  1521. #endregion
  1522. #region 公共
  1523. /// <summary>
  1524. /// 获取二级业务类型
  1525. /// </summary>
  1526. /// <param name="deptId">业务类别</param>
  1527. /// <returns></returns>
  1528. public string GetBussType(int? bussnessType)
  1529. {
  1530. try
  1531. {
  1532. if (bussnessType != null && bussnessType > 0)
  1533. {
  1534. List<Model.T_Wo_WorkOrderType> modelList = GetWorkTypeModelList();
  1535. return JsonConvert.SerializeObject(modelList.Where(t => t.F_WorkOrderTypeId == bussnessType).ToList()[0].WorkTypeModelList);
  1536. }
  1537. else
  1538. {
  1539. return null;
  1540. }
  1541. }
  1542. catch (Exception ex)
  1543. {
  1544. }
  1545. return null;
  1546. }
  1547. /// <summary>
  1548. /// 导出数据
  1549. /// </summary>
  1550. /// <param name="page">当前页码</param>
  1551. /// <param name="limit">每页数据量</param>
  1552. /// <param name="sqlWhere">查询条件</param>
  1553. /// <returns></returns>
  1554. [AcceptVerbs(HttpVerbs.Post)]
  1555. public string ExToExcel(ExToExcel paramModel)
  1556. {
  1557. //数据结果集
  1558. ResponseData dataModel = new ResponseData();
  1559. string sql = "";
  1560. //工单编号
  1561. if (!string.IsNullOrEmpty(paramModel.workorderNum))
  1562. {
  1563. sql += " and t.F_CODE like '%" + paramModel.workorderNum.Trim() + "%'";
  1564. }
  1565. //客户姓名
  1566. if (!string.IsNullOrEmpty(paramModel.cusName))
  1567. {
  1568. sql += " and t.F_CUSTOMERNAME like '%" + paramModel.cusName.Trim() + "%'";
  1569. }
  1570. //客户电话
  1571. if (!string.IsNullOrEmpty(paramModel.phoneNumber))
  1572. {
  1573. sql += " and t.F_CUSTOMERTELEPHONE like '%" + paramModel.phoneNumber.Trim() + "%'";
  1574. }
  1575. //坐席工号
  1576. if (!string.IsNullOrEmpty(paramModel.userInfo))
  1577. {
  1578. sql += " and t.F_LINKMAN like '%" + paramModel.userInfo.Trim() + "%'";
  1579. }
  1580. //状态
  1581. if (paramModel.status != null)
  1582. {
  1583. sql += " and t.F_WORKORDERSTATEID =" + paramModel.status;
  1584. }
  1585. //业务类别
  1586. if (paramModel.bussType != null && paramModel.bussType > 0)
  1587. {
  1588. sql += " and t.F_FILEFLAG =" + paramModel.bussType;
  1589. }
  1590. //业务类型
  1591. if (paramModel.detailType != null && paramModel.detailType > 0)
  1592. {
  1593. sql += " and t.F_REPAIRLEVEL =" + paramModel.detailType;
  1594. }
  1595. //内容
  1596. if (!string.IsNullOrEmpty(paramModel.Content))
  1597. {
  1598. sql += " and t.F_CONTENT like '%" + paramModel.Content.Trim() + "%'";
  1599. }
  1600. //处理方式
  1601. if (paramModel.GoType != null && paramModel.GoType > 0)
  1602. {
  1603. sql += " and t.F_WORKORDERTYPEID =" + paramModel.GoType;
  1604. }
  1605. //渠道
  1606. if (paramModel.FromType != null && paramModel.FromType > 0)
  1607. {
  1608. sql += " and t.F_REPAIRMANID =" + paramModel.FromType;
  1609. }
  1610. //查询按钮
  1611. if (!string.IsNullOrEmpty(paramModel.dateParty))
  1612. {
  1613. string startDate = paramModel.dateParty.Substring(0, 10);
  1614. string endDate = paramModel.dateParty.Substring(12);
  1615. sql += " and t.F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  1616. sql += " and t.F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  1617. }
  1618. else
  1619. {
  1620. string endDate = DateTime.Now.ToString("yyyy-MM-dd");
  1621. string startDate = DateTime.Now.ToString("yyyy-MM-dd");
  1622. sql += " and t.F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  1623. sql += " and t.F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  1624. }
  1625. string tableNew = "(select DISTINCT t.* ";
  1626. tableNew += ", case WHEN F_SENTORDERTIME IS NULL AND DATEDIFF(minute, DATEADD(day,1,F_CREATEDATE), GETDATE())> 0 THEN 0 WHEN F_SENTORDERTIME IS NULL THEN 1 WHEN DATEDIFF(minute, DATEADD(day,1,F_CREATEDATE), F_SENTORDERTIME)> 0 THEN 0 ELSE 1 END AS turntime ";
  1627. tableNew += " from T_Wo_WorkOrderBase t LEFT JOIN T_Wo_WorkOrderHistory h ON t.F_WORKORDERID=h.F_INSTANCEID LEFT JOIN T_Sys_UserAccount u ON t.F_USERID= u.F_UserId";
  1628. tableNew += " ) as t";
  1629. // string tableNew = string.Format("(select DISTINCT t.* from T_Wo_WorkOrderBase t LEFT JOIN T_Wo_WorkOrderHistory h ON t.F_WORKORDERID=h.F_INSTANCEID LEFT JOIN T_Sys_UserAccount u ON t.F_USERID= u.F_UserId where (u.F_DeptId={0} OR h.F_OPTBTNID={0})) as t", F_DeptId);
  1630. DataTable dt = new DataTable();
  1631. int recordCount = 0;
  1632. Model.PageData<Model.T_Wo_WorkOrderBase> pageModel = new Model.PageData<Model.T_Wo_WorkOrderBase>();
  1633. dt = BLL.PagerBLL.GetListPager(
  1634. tableNew,
  1635. "F_WORKORDERID",
  1636. " t.F_CODE as 工单编号"
  1637. + ",F_CUSTOMERNAME as 客户姓名"
  1638. + ",F_CUSTOMERTELEPHONE as 客户电话"
  1639. + ",F_LINKMAN as 坐席工号"
  1640. + ",F_REPAIRMANNAME as 坐席姓名"
  1641. + ",F_WORKORDERFROM as 接入渠道"
  1642. + " , CONVERT(varchar, t.F_CREATEDATE, 120) as 受理时间"
  1643. + ",F_REPAIRREQUEST as 业务状态"
  1644. + ",F_CONTENT as 内容"
  1645. + ",F_RETURNVISITCONTENT as 处理回复内容"
  1646. + ",F_HOUSING as 业务类型"
  1647. + ",F_ADSLACCOUNT as 业务明细"
  1648. ,
  1649. sql,
  1650. "ORDER BY t.F_CREATEDATE desc",
  1651. 100000,
  1652. 1,
  1653. true,
  1654. out recordCount);
  1655. ResponseDataModel NewData = new ResponseDataModel();
  1656. ExcelReadWrite erw = new ExcelReadWrite();
  1657. byte[] Filebyte = erw.GetExcelByte(dt, "sheet1", true);
  1658. int officeVersion = erw.OfficeType();
  1659. if (officeVersion == 1 || officeVersion == 2)
  1660. {
  1661. NewData.Message = DateTime.Now.ToString("yyyy-MM-dd") + "工单数据.xls";
  1662. }
  1663. else
  1664. {
  1665. NewData.Message = DateTime.Now.ToString("yyyy-MM-dd") + "工单数据.xlsx";
  1666. }
  1667. NewData.Code = "0";
  1668. NewData.Data = JsonConvert.SerializeObject(Filebyte);
  1669. return JsonConvert.SerializeObject(NewData);
  1670. }
  1671. /// <summary>
  1672. /// 导出数据
  1673. /// </summary>
  1674. /// <param name="page">当前页码</param>
  1675. /// <param name="limit">每页数据量</param>
  1676. /// <param name="sqlWhere">查询条件</param>
  1677. /// <returns></returns>
  1678. [AcceptVerbs(HttpVerbs.Post)]
  1679. public string ExToExcelDZ(ExToExcel paramModel)
  1680. {
  1681. string sql = " and F_WORKORDERSTATEID=5 and F_HOUSING='投诉' and F_REPAIRREQUEST='已定责' ";
  1682. //工单编号
  1683. if (!string.IsNullOrEmpty(paramModel.workorderNum))
  1684. {
  1685. sql += " and F_CODE like '%" + paramModel.workorderNum.Trim() + "%'";
  1686. }
  1687. //客户姓名
  1688. if (!string.IsNullOrEmpty(paramModel.cusName))
  1689. {
  1690. sql += " and F_CUSTOMERNAME like '%" + paramModel.cusName.Trim() + "%'";
  1691. }
  1692. //客户姓名
  1693. if (!string.IsNullOrEmpty(paramModel.cusName))
  1694. {
  1695. sql += " and F_CUSTOMERNAME like '%" + paramModel.cusName.Trim() + "%'";
  1696. }
  1697. //客户电话
  1698. if (!string.IsNullOrEmpty(paramModel.phoneNumber))
  1699. {
  1700. sql += " and F_CUSTOMERTELEPHONE like '%" + paramModel.phoneNumber.Trim() + "%'";
  1701. }
  1702. //坐席工号
  1703. if (!string.IsNullOrEmpty(paramModel.userInfo))
  1704. {
  1705. sql += " and F_LINKMAN like '%" + paramModel.userInfo.Trim() + "%'";
  1706. }
  1707. //状态
  1708. if (paramModel.status != null)
  1709. {
  1710. sql += " and F_WORKORDERSTATEID =" + paramModel.status;
  1711. }
  1712. //业务类别
  1713. if (paramModel.bussType != null && paramModel.bussType > 0)
  1714. {
  1715. sql += " and F_FILEFLAG =" + paramModel.bussType;
  1716. }
  1717. //业务类型
  1718. if (paramModel.detailType != null && paramModel.detailType > 0)
  1719. {
  1720. sql += " and F_REPAIRLEVEL =" + paramModel.detailType;
  1721. }
  1722. //内容
  1723. if (!string.IsNullOrEmpty(paramModel.Content))
  1724. {
  1725. sql += " and F_CONTENT like '%" + paramModel.Content.Trim() + "%'";
  1726. }
  1727. //处理方式
  1728. if (paramModel.GoType != null && paramModel.GoType > 0)
  1729. {
  1730. sql += " and F_WORKORDERTYPEID =" + paramModel.GoType;
  1731. }
  1732. //渠道
  1733. if (paramModel.FromType != null && paramModel.FromType > 0)
  1734. {
  1735. sql += " and F_REPAIRMANID =" + paramModel.FromType;
  1736. }
  1737. if (paramModel.F_RETURNVISITRESULT != null && paramModel.F_RETURNVISITRESULT > 0)
  1738. {
  1739. sql += " and F_RETURNVISITRESULT =" + paramModel.F_RETURNVISITRESULT;
  1740. }
  1741. //处理方式
  1742. if (paramModel.F_HASTENCOUNTS != null && paramModel.F_HASTENCOUNTS > -1)
  1743. {
  1744. if (paramModel.F_HASTENCOUNTS == 0)
  1745. {
  1746. sql += " and F_HASTENCOUNTS =0";
  1747. }
  1748. else
  1749. {
  1750. sql += " and F_HASTENCOUNTS >0";
  1751. }
  1752. }
  1753. //查询按钮
  1754. if (!string.IsNullOrEmpty(paramModel.dateParty))
  1755. {
  1756. string startDate = paramModel.dateParty.Substring(0, 10);
  1757. string endDate = paramModel.dateParty.Substring(12);
  1758. sql += " and F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  1759. sql += " and F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  1760. }
  1761. else
  1762. {
  1763. string endDate = DateTime.Now.ToString("yyyy-MM-dd");
  1764. string startDate = DateTime.Now.ToString("yyyy-MM-dd");
  1765. sql += " and F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  1766. sql += " and F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  1767. }
  1768. DataTable dt = new DataTable();
  1769. int recordCount = 0;
  1770. Model.PageData<Model.T_Wo_WorkOrderBase> pageModel = new Model.PageData<Model.T_Wo_WorkOrderBase>();
  1771. dt = BLL.PagerBLL.GetListPager(
  1772. "T_Wo_WorkOrderBase",
  1773. " F_WORKORDERID",
  1774. " F_WORKORDERID as 序号"
  1775. + ", F_CODE as 工单编号"
  1776. + ", F_UserName as 受理人"
  1777. + ",CONVERT(varchar, F_CREATEDATE, 120) as 受理时间"
  1778. + ", F_WORKORDERFROM as 事件来源"
  1779. + ", F_RETURNVISITPROBLEM as 事件概况"
  1780. + ", F_CONTENT as 事件内容"
  1781. + ", F_PROVINCE as 一级内容分类"
  1782. + " , F_CITY as 二级内容分类"
  1783. + ", F_AREA as 三级内容分类"
  1784. + ", '' as 责任部门"
  1785. + ", '' as 责任部门调查情况"
  1786. + ", '' as 责任部门处理意见和整改措施"
  1787. + ", F_SERVICETYPE as 计划经营部处理意见"
  1788. + ", F_SERVICENATURE as 定性定责结果"
  1789. + ",case when F_WORKORDERSTATEID=0 then '未处理' when F_WORKORDERSTATEID=1 then '处理中' else '已处理' END AS 办理状态"
  1790. + " ,'-' as 风险点"
  1791. + ",'-' as 风险等级"
  1792. + ",'-' as 风险概率"
  1793. + ",'-' as 风险评估"
  1794. + ",case when F_WORKORDERTYPEID=1 then '转单处理' else '客服处理' END AS 处理方式"
  1795. + ",F_RETURNVISITCONTENT"
  1796. + ",case when F_RETURNVISITRESULT=1 then '满意' when F_RETURNVISITRESULT=2 then '一般' when F_RETURNVISITRESULT=3 then '不满意' else '空' END AS 满意度"
  1797. ,
  1798. sql,
  1799. "ORDER BY F_CREATEDATE desc",
  1800. 100000,
  1801. 1,
  1802. true,
  1803. out recordCount);
  1804. if (recordCount > 0)
  1805. {
  1806. int tempn = 0;
  1807. foreach (DataRow dr in dt.Rows)
  1808. {
  1809. string temp1 = "";
  1810. string temp2 = "";
  1811. string temp3 = "";
  1812. #region 责任部门
  1813. List<T_Wo_WorkOrderNotice> modellistnotice = noticeBLL.GetModelList(string.Format(" orderid={0} and NoticeType=1 AND NoticeState=1", dr["序号"].ToInt32()));
  1814. if (modellistnotice.Count > 0)
  1815. {
  1816. foreach (T_Wo_WorkOrderNotice modelnotice in modellistnotice)
  1817. {
  1818. temp1 += modelnotice.NoticeDeptName + "\n";
  1819. }
  1820. }
  1821. dr["责任部门"] = temp1;
  1822. #endregion
  1823. if (dr["处理方式"].ToMyString() == "转单处理")
  1824. {
  1825. List<T_Wo_WorkOrderHistory> modelhisList = historyBll.GetModelList(string.Format(" F_INSTANCEID={0} and F_StateName='已处理' AND NeedReplayTime IS NOT NULL ", dr["序号"].ToInt32()));
  1826. if (modelhisList.Count > 0)
  1827. {
  1828. foreach (T_Wo_WorkOrderHistory modelhistemp in modelhisList)
  1829. {
  1830. temp2 += modelhistemp.F_NEXTOWNERARRID + " 调查情况:\n";
  1831. temp3 += modelhistemp.F_NEXTOWNERARRID + " 处理意见和整改措施:\n";
  1832. if (string.IsNullOrEmpty(modelhistemp.F_REMARK))
  1833. {
  1834. continue;
  1835. }
  1836. int tempint = modelhistemp.F_REMARK.IndexOf("|");
  1837. if (tempint == -1)
  1838. {
  1839. temp2 += modelhistemp.F_REMARK;
  1840. temp3 += modelhistemp.F_REMARK;
  1841. }
  1842. else
  1843. {
  1844. string[] arrystr = modelhistemp.F_REMARK.Split('|');
  1845. temp2 += arrystr[0];
  1846. temp2 += "\n";
  1847. temp3 += arrystr[1];
  1848. temp3 += "\n";
  1849. }
  1850. }
  1851. }
  1852. }
  1853. else
  1854. {
  1855. temp2 += dr["F_RETURNVISITCONTENT"].ToMyString();
  1856. temp3 += "客服即时处理工单";
  1857. }
  1858. dr["责任部门调查情况"] = temp2;
  1859. dr["责任部门处理意见和整改措施"] = temp3;
  1860. tempn += 1;
  1861. dr["序号"] = tempn;
  1862. //tempCode = dr["工单编号"].ToMyString();
  1863. }
  1864. }
  1865. DataTable dataTable = dt.Copy();
  1866. foreach (DataColumn dc in dataTable.Columns)
  1867. {
  1868. if (dc.ColumnName.Equals("F_RETURNVISITCONTENT"))
  1869. dt.Columns.Remove(dc.ColumnName);
  1870. if (dc.ColumnName.Equals("F_WORKORDERTYPEID"))
  1871. dt.Columns.Remove(dc.ColumnName);
  1872. }
  1873. ResponseDataModel NewData = new ResponseDataModel();
  1874. ExcelReadWrite erw = new ExcelReadWrite();
  1875. byte[] Filebyte = erw.GetExcelByte(dt, "sheet1", true);
  1876. int officeVersion = erw.OfficeType();
  1877. if (officeVersion == 1 || officeVersion == 2)
  1878. {
  1879. NewData.Message = DateTime.Now.ToString("yyyy-MM-dd") + "全媒体客服转办及化解投诉定性定责情况汇总表.xls";
  1880. }
  1881. else
  1882. {
  1883. NewData.Message = DateTime.Now.ToString("yyyy-MM-dd") + "全媒体客服转办及化解投诉定性定责情况汇总表.xlsx";
  1884. }
  1885. NewData.Code = "0";
  1886. NewData.Data = JsonConvert.SerializeObject(Filebyte);
  1887. return JsonConvert.SerializeObject(NewData);
  1888. }
  1889. #endregion
  1890. #region 工单详情
  1891. public ActionResult ViewMyOrder(int orderKeyId)
  1892. {
  1893. //实例化基础信息表
  1894. CallScreenModel callScreenModel = new CallScreenModel();
  1895. //获取业务工单信息
  1896. if (orderKeyId > 0)
  1897. {
  1898. callScreenModel.WorkOrderBaseModel = orderBLL.GetModel(orderKeyId);
  1899. //如果电话号码不为空
  1900. if (callScreenModel.WorkOrderBaseModel != null && !string.IsNullOrEmpty(callScreenModel.WorkOrderBaseModel.F_CUSTOMERTELEPHONE))
  1901. {
  1902. T_Cus_CustomerBase baseCusModel = cusBLL.GetCusInfoModel(callScreenModel.WorkOrderBaseModel.F_CUSTOMERTELEPHONE);
  1903. if (baseCusModel != null && baseCusModel.F_CustomerId > 0)
  1904. {
  1905. callScreenModel.WorkOrderBaseModel.CustomerBaseModel = baseCusModel;
  1906. }
  1907. else
  1908. {
  1909. callScreenModel.WorkOrderBaseModel.CustomerBaseModel = new T_Cus_CustomerBase();
  1910. }
  1911. }
  1912. else
  1913. {
  1914. callScreenModel.WorkOrderBaseModel.CustomerBaseModel = new T_Cus_CustomerBase();
  1915. }
  1916. //获取客户基本信息
  1917. if (!string.IsNullOrEmpty(callScreenModel.WorkOrderBaseModel.F_EMPCODE))
  1918. {
  1919. T_Cus_CustomerBase baseCusModel = cusBLL.GetCusInfoModel(1, callScreenModel.WorkOrderBaseModel.F_EMPCODE);
  1920. if (baseCusModel != null && baseCusModel.F_CustomerId > 0)
  1921. {
  1922. callScreenModel.WorkOrderBaseModel.CustomerBaseModel = baseCusModel;
  1923. }
  1924. else
  1925. {
  1926. callScreenModel.WorkOrderBaseModel.CustomerBaseModel = new T_Cus_CustomerBase();
  1927. }
  1928. }
  1929. }
  1930. //业务类型字典表
  1931. callScreenModel.WorkOrderTypeModelList = GetWorkTypeModelList();
  1932. //获取处理方式字典表
  1933. callScreenModel.GoTypeModelList = GetCodeType("CLFS");
  1934. //获取部门列表
  1935. callScreenModel.DepartmentList = deptBll.GetModelList("F_ParentId=0");
  1936. callScreenModel.HistoryOrderList = historyBll.GetModelList("F_INSTANCEID=" + orderKeyId);
  1937. callScreenModel.Noticelist = noticeBLL.GetModelList(" Orderid=" + orderKeyId + " Order by DZNumber ASC");
  1938. callScreenModel.F_RoleID = F_RoleID;
  1939. return View(callScreenModel);
  1940. }
  1941. /// <summary>
  1942. /// 处理历史工单
  1943. /// </summary>
  1944. /// <param name="orderKeyId">主键</param>
  1945. /// <returns></returns>
  1946. public ActionResult EditMyOrder(int dtype = 0, int orderKeyId = 0)
  1947. {
  1948. //实例化基础信息表
  1949. CallScreenModel callScreenModel = new CallScreenModel();
  1950. //工单类型
  1951. callScreenModel.DType = dtype;
  1952. //话务标志
  1953. callScreenModel.SeatFlag = F_SeatFlag;
  1954. //获取业务工单信息
  1955. if (orderKeyId > 0)
  1956. {
  1957. callScreenModel.WorkOrderBaseModel = orderBLL.GetModel(orderKeyId);
  1958. //如果电话号码不为空
  1959. if (callScreenModel.WorkOrderBaseModel != null && callScreenModel.WorkOrderBaseModel.F_CUSTOMERID > 1)
  1960. {
  1961. T_Cus_CustomerBase baseCusModel = cusBLL.GetModel((int)callScreenModel.WorkOrderBaseModel.F_CUSTOMERID);
  1962. if (baseCusModel != null && baseCusModel.F_CustomerId > 1)
  1963. {
  1964. callScreenModel.WorkOrderBaseModel.CustomerBaseModel = baseCusModel;
  1965. }
  1966. else
  1967. {
  1968. callScreenModel.WorkOrderBaseModel.CustomerBaseModel = new T_Cus_CustomerBase();
  1969. }
  1970. }
  1971. else
  1972. {
  1973. callScreenModel.WorkOrderBaseModel.CustomerBaseModel = new T_Cus_CustomerBase();
  1974. }
  1975. if (callScreenModel.WorkOrderBaseModel.F_WORKORDERTYPEID == 1)
  1976. { callScreenModel.HistoryOrderList = historyBll.GetModelList("F_INSTANCEID=" + orderKeyId); }
  1977. else
  1978. { callScreenModel.HistoryOrderList = null; }
  1979. }
  1980. //业务类型字典表
  1981. callScreenModel.WorkOrderTypeModelList = GetWorkTypeModelList();
  1982. //获取处理方式字典表
  1983. callScreenModel.GoTypeModelList = GetCodeType("CLFS");
  1984. //回访满意度
  1985. callScreenModel.MYdModelList = GetCodeType("khyjfl");
  1986. //获取部门列表
  1987. callScreenModel.DepartmentList = deptBll.GetModelList("F_ParentId=0");
  1988. callScreenModel.Noticelist = noticeBLL.GetModelList(" Orderid=" + orderKeyId + " Order by DZNumber ASC");
  1989. return View(callScreenModel);
  1990. }
  1991. #endregion
  1992. #region 已定责
  1993. /// <summary>
  1994. /// 超时答复视图
  1995. /// </summary>
  1996. /// <param name="dtype">工单类型 1、所有待办工单 2、代办结工单</param>
  1997. /// <returns></returns>
  1998. public ActionResult WorkOrderMyDataOverAnswer(int dtype)
  1999. {
  2000. WorkOrderMyModel model = new WorkOrderMyModel();
  2001. model.DType = dtype;
  2002. //业务类型字典表
  2003. model.WorkOrderTypeModelList = GetWorkTypeModelList();
  2004. //话务标志
  2005. model.SeatFlag = F_SeatFlag;
  2006. return View(model);
  2007. }
  2008. /// <summary>
  2009. /// 超时答复数据
  2010. /// </summary>
  2011. /// <param name="F_RETURNVISITRESULT">满意度</param>
  2012. /// <param name="limit">每页数据量</param>
  2013. /// <param name="sqlWhere">查询条件</param>
  2014. /// <returns></returns>
  2015. [ActionName("WorkOrderMyDataOverAnswerData")]
  2016. [HttpGet]
  2017. public string WorkOrderMyDataOverAnswerData(DateTime? NowDateTime, int page, int limit, int? types, string dateParty,
  2018. string workorderNum, string cusName, string phoneNumber,
  2019. string userInfo, int? bussType, int? detailType, string Content, int? F_RETURNVISITRESULT, int? turnout)
  2020. {
  2021. //数据结果集
  2022. ResponseData dataModel = new ResponseData();
  2023. string sql = " and t.F_WORKORDERSTATEID>0 and t.F_WORKORDERTYPEID=1 ";
  2024. //未按时转出
  2025. if (turnout.ToInt32() > 0)
  2026. {
  2027. sql += " and t.turntime =0 ";
  2028. }
  2029. //工单编号
  2030. if (!string.IsNullOrEmpty(workorderNum))
  2031. {
  2032. sql += " and t.F_CODE like '%" + workorderNum.Trim() + "%'";
  2033. }
  2034. //客户姓名
  2035. if (!string.IsNullOrEmpty(cusName))
  2036. {
  2037. sql += " and t.F_CUSTOMERNAME like '%" + cusName.Trim() + "%'";
  2038. }
  2039. //客户电话
  2040. if (!string.IsNullOrEmpty(phoneNumber))
  2041. {
  2042. sql += " and t.F_CUSTOMERTELEPHONE like '%" + phoneNumber.Trim() + "%'";
  2043. }
  2044. //坐席工号
  2045. if (!string.IsNullOrEmpty(userInfo))
  2046. {
  2047. sql += " and t.F_LINKMAN like '%" + userInfo.Trim() + "%'";
  2048. }
  2049. //业务类别
  2050. if (bussType != null && bussType > 0)
  2051. {
  2052. sql += " and t.F_FILEFLAG =" + bussType;
  2053. }
  2054. //业务类型
  2055. if (detailType != null && detailType > 0)
  2056. {
  2057. sql += " and t.F_REPAIRLEVEL =" + detailType;
  2058. }
  2059. #region
  2060. //定责次数
  2061. //if (F_HASTENCOUNTS != null)
  2062. //{
  2063. // if (F_HASTENCOUNTS == 0)
  2064. // {
  2065. // sql += " AND (t.F_HASTENCOUNTS is null OR t.F_HASTENCOUNTS =0) ";
  2066. // }
  2067. // else
  2068. // {
  2069. // sql += " AND t.F_HASTENCOUNTS >0 ";
  2070. // }
  2071. //}
  2072. #endregion
  2073. //内容
  2074. if (!string.IsNullOrEmpty(Content))
  2075. {
  2076. sql += " and t.F_CONTENT like '%" + Content.Trim() + "%'";
  2077. }
  2078. //查询按钮
  2079. if (types == 0 || types == null)
  2080. {
  2081. if (!string.IsNullOrEmpty(dateParty))
  2082. {
  2083. string startDate = dateParty.Substring(0, 10);
  2084. string endDate = dateParty.Substring(12);
  2085. sql += " and t.F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  2086. sql += " and t.F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  2087. }
  2088. else
  2089. {
  2090. string endDate = DateTime.Now.ToString("yyyy-MM-dd");
  2091. string startDate = DateTime.Now.ToString("yyyy-MM-dd");
  2092. sql += " and t.F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  2093. sql += " and t.F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  2094. }
  2095. }//一周按钮
  2096. else if (types == 1)
  2097. {
  2098. string endDate = DateTime.Now.ToString("yyyy-MM-dd");
  2099. string startDate = DateTime.Now.AddDays(-7).ToString("yyyy-MM-dd");
  2100. sql += " and t.F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  2101. sql += " and t.F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  2102. }//一月按钮
  2103. else if (types == 2)
  2104. {
  2105. string endDate = DateTime.Now.ToString("yyyy-MM-dd");
  2106. string startDate = DateTime.Now.AddMonths(-1).ToString("yyyy-MM-dd");
  2107. sql += " and t.F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  2108. sql += " and t.F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  2109. }//一年按钮
  2110. else if (types == 3)
  2111. {
  2112. string endDate = DateTime.Now.ToString("yyyy-MM-dd");
  2113. string startDate = DateTime.Now.AddYears(-1).ToString("yyyy-MM-dd");
  2114. sql += " and t.F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  2115. sql += " and t.F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  2116. }
  2117. //一天按钮
  2118. else if (types == 4)
  2119. {
  2120. string endDate = DateTime.Now.ToString("yyyy-MM-dd");
  2121. string startDate = DateTime.Now.ToString("yyyy-MM-dd");
  2122. sql += " and t.F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  2123. sql += " and t.F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  2124. }
  2125. string tableNew = "(select DISTINCT t.* ";
  2126. tableNew += ", case WHEN F_SENTORDERTIME IS NULL AND DATEDIFF(minute, DATEADD(day,1,F_CREATEDATE), GETDATE())> 0 THEN 0 WHEN F_SENTORDERTIME IS NULL THEN 1 WHEN DATEDIFF(minute, DATEADD(day,1,F_CREATEDATE), F_SENTORDERTIME)> 0 THEN 0 ELSE 1 END AS turntime ";
  2127. tableNew += " from T_Wo_WorkOrderBase t LEFT JOIN T_Wo_WorkOrderHistory h ON t.F_WORKORDERID=h.F_INSTANCEID LEFT JOIN T_Sys_UserAccount u ON t.F_USERID= u.F_UserId";
  2128. tableNew += " where h.NeedReplayTime is not null AND F_StateName NOT LIKE '%撤回%' AND F_StateName NOT LIKE '%驳回%' and ((h.ReplayTime IS NULL AND DATEDIFF(second, GETDATE(), h.NeedReplayTime)<0) OR (h.ReplayTime IS NOT NULL AND DATEDIFF(second, h.ReplayTime, h.NeedReplayTime)<0))) as t";
  2129. DataTable dt = new DataTable();
  2130. int recordCount = 0;
  2131. Model.PageData<Model.T_Wo_WorkOrderBase> pageModel = new Model.PageData<Model.T_Wo_WorkOrderBase>();
  2132. dt = BLL.PagerBLL.GetListPager(
  2133. tableNew,
  2134. "F_WORKORDERID",
  2135. " t.*,CONVERT(varchar,t.F_CREATEDATE, 120 ) as F_CREATEDATENew"
  2136. + ",dbo.GetOverReplayTime(t.F_WORKORDERID) as F_OVERTIME"
  2137. // + ", CONVERT(VARCHAR(10),ISNULL(CASE WHEN F_REMAINDERTIME IS NULL THEN DATEDIFF(SECOND,F_REQUESTSERVICETIME,GETDATE()) "
  2138. //+ " ELSE DATEDIFF(SECOND,F_REQUESTSERVICETIME,F_REMAINDERTIME) END ,0)/3600)+'时'+CONVERT(VARCHAR(10),ISNULL(CASE WHEN F_REMAINDERTIME IS NULL THEN DATEDIFF(SECOND,F_REQUESTSERVICETIME,GETDATE()) "
  2139. // + " ELSE DATEDIFF(SECOND,F_REQUESTSERVICETIME,F_REMAINDERTIME) END ,0)%3600/60)+'分'+CONVERT(VARCHAR(10),ISNULL(CASE WHEN F_REMAINDERTIME IS NULL THEN DATEDIFF(SECOND,F_REQUESTSERVICETIME,GETDATE()) "
  2140. // + " ELSE DATEDIFF(SECOND,F_REQUESTSERVICETIME,F_REMAINDERTIME) END ,0)%3600%60)+'秒' AS F_OVERTIME"
  2141. + @" , replace(replace(CASE F_WORKORDERFROM WHEN '留言工单' THEN (SELECT top 1 F_RecFileUrl FROM dbo.T_Call_LeaveRecord WHERE F_CallId=t.F_KSHADDRESSCODE) WHEN '语音工单' THEN (SELECT top 1 FilePath FROM dbo.T_Call_CallRecords WHERE CallId=t.F_KSHADDRESSCODE) ELSE NULL END,'\','/'),'" + GetSysconfig("newFilePath") + "','" + GetSysconfig("newPlayPath") + "') as FilePath"
  2142. ,
  2143. sql,
  2144. "ORDER BY t.F_CREATEDATE desc",
  2145. limit,
  2146. page,
  2147. true,
  2148. out recordCount);
  2149. //string tableNew = "( SELECT * FROM dbo.T_Wo_WorkOrderBase WHERE F_WORKORDERID IN ( SELECT DISTINCT a.F_WORKORDERID FROM dbo.T_Wo_WorkOrderBase a LEFT JOIN dbo.T_Wo_WorkOrderHistory h ON a.F_WORKORDERID = h.F_INSTANCEID WHERE F_WORKORDERTYPEID = 1 AND h.NeedReplayTime is not null AND F_StateName NOT LIKE '%撤回%' AND F_StateName NOT LIKE '%驳回%' and((h.ReplayTime IS NULL AND DATEDIFF(second, GETDATE(), h.NeedReplayTime) < 0) OR(h.ReplayTime IS NOT NULL AND DATEDIFF(second, h.ReplayTime, h.NeedReplayTime) < 0)) ) )as t";
  2150. //DataTable dt = new DataTable();
  2151. //int recordCount = 0;
  2152. //Model.PageData<Model.T_Wo_WorkOrderBase> pageModel = new Model.PageData<Model.T_Wo_WorkOrderBase>();
  2153. //dt = BLL.PagerBLL.GetListPager(
  2154. // tableNew,
  2155. // "F_WORKORDERID",
  2156. // "t.*,dbo.GetOverReplayTime(t.F_WORKORDERID) as F_OVERTIME,CONVERT(varchar,t.F_CREATEDATE, 120 ) as F_CREATEDATENew"
  2157. // + @" , replace(replace(CASE F_WORKORDERFROM WHEN '留言工单' THEN (SELECT top 1 F_RecFileUrl FROM dbo.T_Call_LeaveRecord WHERE F_CallId=t.F_KSHADDRESSCODE) WHEN '语音工单' THEN (SELECT top 1 FilePath FROM dbo.T_Call_CallRecords WHERE CallId=t.F_KSHADDRESSCODE) ELSE NULL END,'\','/'),'" + GetSysconfig("newFilePath") + "','" + GetSysconfig("newPlayPath") + "') as FilePath"
  2158. // , sql,
  2159. // "ORDER BY t.F_CREATEDATE desc",
  2160. // limit,
  2161. // page,
  2162. // true,
  2163. // out recordCount);
  2164. dataModel.code = 0;
  2165. dataModel.count = recordCount;
  2166. dataModel.data = dt;
  2167. return JsonConvert.SerializeObject(dataModel);
  2168. }
  2169. #endregion
  2170. public ActionResult WorkOrderDealedList()
  2171. {
  2172. WorkOrderMyModel model = new WorkOrderMyModel();
  2173. //业务类型字典表
  2174. model.WorkOrderTypeModelList = GetWorkTypeModelList();
  2175. //话务标志
  2176. model.SeatFlag = F_SeatFlag;
  2177. return View(model);
  2178. }
  2179. //已处理可撤回的列表
  2180. [ActionName("WorkOrderDealedData")]
  2181. [HttpGet]
  2182. public string WorkOrderDealedData(DateTime? NowDateTime, int page, int limit, int? types, string dateParty,
  2183. string workorderNum, string cusName, string phoneNumber,
  2184. string userInfo, int? bussType, int? detailType, string Content)
  2185. {
  2186. //数据结果集
  2187. ResponseData dataModel = new ResponseData();
  2188. //F_FILEFLAG 业务类型ID
  2189. //F_WORKORDERSTATEID 0未处理 1处理中 2已办结 ,4 待定责status
  2190. //F_WORKORDERTYPEID 处理方式 1转单 3客服处理 GoType
  2191. //F_REPAIRMANID 接入渠道 1语音 2留言 3微信 4微博 FromType
  2192. // string sql = string.Format(" and F_WORKORDERTYPEID=1 and F_WORKORDERSTATEID=1 and F_WORKORDERID in (select F_INSTANCEID from T_Wo_WorkOrderHistory A where F_WORKORDERSTATEID=0 and F_OPTUSERID={0} AND F_OPTDATE= (select TOP 1 F_OPTDATE from T_Wo_WorkOrderHistory WHERE F_INSTANCEID = A.F_INSTANCEID ORDER BY F_OPTDATE DESC) )", F_UserID);
  2193. string sql = string.Format(" and ( F_WORKORDERTYPEID=1 and F_WORKORDERSTATEID=3 and F_WORKORDERID in (select F_INSTANCEID from T_Wo_WorkOrderHistory where F_WORKORDERSTATEID=1 and F_OPTUSERID={0}))", F_UserID);
  2194. //不回访的工单,是待定责状态也可以撤回到已处理
  2195. sql += string.Format(" or ( F_WORKORDERTYPEID=1 and F_WORKORDERSTATEID=4 and F_RETURNVISITFLAG=0 and F_WORKORDERID in (select F_INSTANCEID from T_Wo_WorkOrderHistory where F_WORKORDERSTATEID=1 and F_OPTUSERID={0}))", F_UserID);
  2196. //客服处理的数据
  2197. //sql += " or (F_WORKORDERTYPEID=3 and F_WORKORDERSTATEID=3 and F_LINKMAN='"+F_UserCode+"' ) ";
  2198. //工单编号
  2199. if (!string.IsNullOrEmpty(workorderNum))
  2200. {
  2201. sql += " and F_CODE like '%" + workorderNum.Trim() + "%'";
  2202. }
  2203. //客户姓名
  2204. if (!string.IsNullOrEmpty(cusName))
  2205. {
  2206. sql += " and F_CUSTOMERNAME like '%" + cusName.Trim() + "%'";
  2207. }
  2208. //客户电话
  2209. if (!string.IsNullOrEmpty(phoneNumber))
  2210. {
  2211. sql += " and F_CUSTOMERTELEPHONE like '%" + phoneNumber.Trim() + "%'";
  2212. }
  2213. //坐席工号
  2214. if (!string.IsNullOrEmpty(userInfo))
  2215. {
  2216. sql += " and F_LINKMAN like '%" + userInfo.Trim() + "%'";
  2217. }
  2218. //业务类别
  2219. if (bussType != null && bussType > 0)
  2220. {
  2221. sql += " and F_FILEFLAG =" + bussType;
  2222. }
  2223. //业务类型
  2224. if (detailType != null && detailType > 0)
  2225. {
  2226. sql += " and F_REPAIRLEVEL =" + detailType;
  2227. }
  2228. //内容
  2229. if (!string.IsNullOrEmpty(Content))
  2230. {
  2231. sql += " and F_CONTENT like '%" + Content.Trim() + "%'";
  2232. }
  2233. //查询按钮
  2234. if (types == 0)
  2235. {
  2236. if (!string.IsNullOrEmpty(dateParty))
  2237. {
  2238. string startDate = dateParty.Substring(0, 10);
  2239. string endDate = dateParty.Substring(12);
  2240. sql += " and F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  2241. sql += " and F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  2242. }
  2243. }//一周按钮
  2244. else if (types == 1)
  2245. {
  2246. string endDate = DateTime.Now.ToString();
  2247. string startDate = DateTime.Now.AddDays(-7).ToString();
  2248. sql += " and F_CREATEDATE>= '" + startDate + "'";
  2249. sql += " and F_CREATEDATE<= '" + endDate + "'";
  2250. }//一月按钮
  2251. else if (types == 2)
  2252. {
  2253. string endDate = DateTime.Now.ToString();
  2254. string startDate = DateTime.Now.AddMonths(-1).ToString();
  2255. sql += " and F_CREATEDATE>= '" + startDate + "'";
  2256. sql += " and F_CREATEDATE<= '" + endDate + "'";
  2257. }//一年按钮
  2258. else if (types == 3)
  2259. {
  2260. string endDate = DateTime.Now.ToString();
  2261. string startDate = DateTime.Now.AddYears(-1).ToString();
  2262. sql += " and F_CREATEDATE>= '" + startDate + "'";
  2263. sql += " and F_CREATEDATE<= '" + endDate + "'";
  2264. }
  2265. DataTable dt = new DataTable();
  2266. int recordCount = 0;
  2267. Model.PageData<Model.T_Wo_WorkOrderBase> pageModel = new Model.PageData<Model.T_Wo_WorkOrderBase>();
  2268. dt = BLL.PagerBLL.GetListPager(
  2269. "T_Wo_WorkOrderBase",
  2270. "F_WORKORDERID",
  2271. "*,CONVERT(varchar,F_CREATEDATE, 120 ) as F_CREATEDATENew"
  2272. + string.Format(",(select top 1 F_HISTORYID from T_Wo_WorkOrderHistory where F_INSTANCEID=F_WORKORDERID and F_WORKORDERSTATEID=0 and F_OPTUSERID={0} Order by F_OPTDATE desc) AS F_HISTORYID", F_UserID)
  2273. + @" , replace(replace(CASE F_WORKORDERFROM WHEN '留言工单' THEN (SELECT top 1 F_RecFileUrl FROM dbo.T_Call_LeaveRecord WHERE F_CallId=F_KSHADDRESSCODE) WHEN '语音工单' THEN (SELECT top 1 FilePath FROM dbo.T_Call_CallRecords WHERE CallId=F_KSHADDRESSCODE AND FilePath!='') ELSE NULL END,'\','/'),'" + GetSysconfig("newFilePath") + "','" + GetSysconfig("newPlayPath") + "') as FilePath",
  2274. //+ " ,(CASE F_WORKORDERFROM WHEN '留言工单' THEN (SELECT F_RecFileUrl FROM dbo.T_Call_LeaveRecord WHERE F_CallId=F_KSHADDRESSCODE) WHEN '语音工单' THEN (SELECT FilePath FROM dbo.T_Call_CallRecords WHERE CallId=F_KSHADDRESSCODE AND FilePath!='') ELSE NULL END ) as FilePath",
  2275. sql,
  2276. "ORDER BY F_CREATEDATE desc",
  2277. limit,
  2278. page,
  2279. true,
  2280. out recordCount);
  2281. dataModel.code = 0;
  2282. dataModel.count = recordCount;
  2283. dataModel.data = dt;
  2284. return JsonConvert.SerializeObject(dataModel);
  2285. }
  2286. /// <summary>
  2287. /// 待处理工单总数
  2288. /// </summary>
  2289. /// <returns></returns>
  2290. public int WorkOrderMyDealedDataCount()
  2291. {
  2292. string sql = string.Format(" (F_WORKORDERTYPEID=1 and F_WORKORDERSTATEID=3 and F_WORKORDERID in (select F_INSTANCEID from T_Wo_WorkOrderHistory where F_WORKORDERSTATEID=1 and F_OPTUSERID={0}))", F_UserID);
  2293. sql += string.Format(" or ( F_WORKORDERTYPEID=1 and F_WORKORDERSTATEID=4 and F_RETURNVISITFLAG=0 and F_WORKORDERID in (select F_INSTANCEID from T_Wo_WorkOrderHistory where F_WORKORDERSTATEID=1 and F_OPTUSERID={0}))", F_UserID);
  2294. return orderBLL.GetRecordCount(sql);
  2295. }
  2296. public ActionResult WorkOrderVisitedList()
  2297. {
  2298. WorkOrderMyModel model = new WorkOrderMyModel();
  2299. //业务类型字典表
  2300. model.WorkOrderTypeModelList = GetWorkTypeModelList();
  2301. //话务标志
  2302. model.SeatFlag = F_SeatFlag;
  2303. return View(model);
  2304. }
  2305. //已回访 即待定责的列表(只有登录人的数据)待定责可以撤回
  2306. [ActionName("WorkOrderVisitedData")]
  2307. [HttpGet]
  2308. public string WorkOrderVisitedData(DateTime? NowDateTime, int page, int limit, int? types, string dateParty,
  2309. string workorderNum, string cusName, string phoneNumber,
  2310. string userInfo, int? bussType, int? detailType, string Content)
  2311. {
  2312. //数据结果集
  2313. ResponseData dataModel = new ResponseData();
  2314. //F_FILEFLAG 业务类型ID
  2315. //F_WORKORDERSTATEID 0未处理 1处理中 2已办结 status
  2316. //F_WORKORDERTYPEID 处理方式 1转单 3客服处理 GoType
  2317. //F_REPAIRMANID 接入渠道 1语音 2留言 3微信 4微博 FromType
  2318. //F_RETURNVISITFLAG 1 是要回访 0 是不回访
  2319. // string sql = string.Format(" and F_WORKORDERTYPEID=1 and F_WORKORDERSTATEID=1 and F_WORKORDERID in (select F_INSTANCEID from T_Wo_WorkOrderHistory A where F_WORKORDERSTATEID=0 and F_OPTUSERID={0} AND F_OPTDATE= (select TOP 1 F_OPTDATE from T_Wo_WorkOrderHistory WHERE F_INSTANCEID = A.F_INSTANCEID ORDER BY F_OPTDATE DESC) )", F_UserID);
  2320. string sql = string.Format(" and F_WORKORDERTYPEID=1 and F_WORKORDERSTATEID=4 and F_RETURNVISITFLAG=1 and F_LINKMAN={0}", F_UserCode);
  2321. //工单编号
  2322. if (!string.IsNullOrEmpty(workorderNum))
  2323. {
  2324. sql += " and F_CODE like '%" + workorderNum.Trim() + "%'";
  2325. }
  2326. //客户姓名
  2327. if (!string.IsNullOrEmpty(cusName))
  2328. {
  2329. sql += " and F_CUSTOMERNAME like '%" + cusName.Trim() + "%'";
  2330. }
  2331. //客户电话
  2332. if (!string.IsNullOrEmpty(phoneNumber))
  2333. {
  2334. sql += " and F_CUSTOMERTELEPHONE like '%" + phoneNumber.Trim() + "%'";
  2335. }
  2336. //坐席工号
  2337. if (!string.IsNullOrEmpty(userInfo))
  2338. {
  2339. sql += " and F_LINKMAN like '%" + userInfo.Trim() + "%'";
  2340. }
  2341. //业务类别
  2342. if (bussType != null && bussType > 0)
  2343. {
  2344. sql += " and F_FILEFLAG =" + bussType;
  2345. }
  2346. //业务类型
  2347. if (detailType != null && detailType > 0)
  2348. {
  2349. sql += " and F_REPAIRLEVEL =" + detailType;
  2350. }
  2351. //内容
  2352. if (!string.IsNullOrEmpty(Content))
  2353. {
  2354. sql += " and F_CONTENT like '%" + Content.Trim() + "%'";
  2355. }
  2356. //查询按钮
  2357. if (types == 0)
  2358. {
  2359. if (!string.IsNullOrEmpty(dateParty))
  2360. {
  2361. string startDate = dateParty.Substring(0, 10);
  2362. string endDate = dateParty.Substring(12);
  2363. sql += " and F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  2364. sql += " and F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  2365. }
  2366. }//一周按钮
  2367. else if (types == 1)
  2368. {
  2369. string endDate = DateTime.Now.ToString();
  2370. string startDate = DateTime.Now.AddDays(-7).ToString();
  2371. sql += " and F_CREATEDATE>= '" + startDate + "'";
  2372. sql += " and F_CREATEDATE<= '" + endDate + "'";
  2373. }//一月按钮
  2374. else if (types == 2)
  2375. {
  2376. string endDate = DateTime.Now.ToString();
  2377. string startDate = DateTime.Now.AddMonths(-1).ToString();
  2378. sql += " and F_CREATEDATE>= '" + startDate + "'";
  2379. sql += " and F_CREATEDATE<= '" + endDate + "'";
  2380. }//一年按钮
  2381. else if (types == 3)
  2382. {
  2383. string endDate = DateTime.Now.ToString();
  2384. string startDate = DateTime.Now.AddYears(-1).ToString();
  2385. sql += " and F_CREATEDATE>= '" + startDate + "'";
  2386. sql += " and F_CREATEDATE<= '" + endDate + "'";
  2387. }
  2388. DataTable dt = new DataTable();
  2389. int recordCount = 0;
  2390. Model.PageData<Model.T_Wo_WorkOrderBase> pageModel = new Model.PageData<Model.T_Wo_WorkOrderBase>();
  2391. dt = BLL.PagerBLL.GetListPager(
  2392. "T_Wo_WorkOrderBase",
  2393. "F_WORKORDERID",
  2394. "*,CONVERT(varchar,F_CREATEDATE, 120 ) as F_CREATEDATENew"
  2395. + string.Format(",(select top 1 F_HISTORYID from T_Wo_WorkOrderHistory where F_INSTANCEID=F_WORKORDERID and F_WORKORDERSTATEID=0 and F_OPTUSERID={0} Order by F_OPTDATE desc) AS F_HISTORYID", F_UserID)
  2396. + @" , replace(replace(CASE F_WORKORDERFROM WHEN '留言工单' THEN (SELECT top 1 F_RecFileUrl FROM dbo.T_Call_LeaveRecord WHERE F_CallId=F_KSHADDRESSCODE) WHEN '语音工单' THEN (SELECT top 1 FilePath FROM dbo.T_Call_CallRecords WHERE CallId=F_KSHADDRESSCODE AND FilePath!='') ELSE NULL END,'\','/'),'" + GetSysconfig("newFilePath") + "','" + GetSysconfig("newPlayPath") + "') as FilePath",
  2397. //+ " ,(CASE F_WORKORDERFROM WHEN '留言工单' THEN (SELECT F_RecFileUrl FROM dbo.T_Call_LeaveRecord WHERE F_CallId=F_KSHADDRESSCODE) WHEN '语音工单' THEN (SELECT FilePath FROM dbo.T_Call_CallRecords WHERE CallId=F_KSHADDRESSCODE AND FilePath!='') ELSE NULL END ) as FilePath",
  2398. sql,
  2399. "ORDER BY F_CREATEDATE desc",
  2400. limit,
  2401. page,
  2402. true,
  2403. out recordCount);
  2404. dataModel.code = 0;
  2405. dataModel.count = recordCount;
  2406. dataModel.data = dt;
  2407. return JsonConvert.SerializeObject(dataModel);
  2408. }
  2409. public int WorkOrderMyVisitedDataCount()
  2410. {
  2411. string sql = string.Format(" F_WORKORDERTYPEID=1 and F_WORKORDERSTATEID=4 and F_RETURNVISITFLAG=1 and F_LINKMAN={0}", F_UserCode);
  2412. return orderBLL.GetRecordCount(sql);
  2413. }
  2414. /// <summary>
  2415. /// 处理人撤回自己处理的,工单状态是待回访的工单
  2416. /// </summary>
  2417. /// <param name="workOrderBaseModel"></param>
  2418. /// <returns></returns>
  2419. [AcceptVerbs(HttpVerbs.Get)]
  2420. public bool ResetDealedWorkOrder(int workOrderId,string reason)
  2421. {
  2422. string F_UserCode = "";
  2423. if (Request.Cookies["BaseCallCenter_T_User"] != null)
  2424. {
  2425. F_UserCode = Request.Cookies["BaseCallCenter_T_User"]["F_UserCode"];
  2426. }
  2427. bool result = false;
  2428. string bycode = F_UserCode;
  2429. string byname = F_UserName;
  2430. int bmid = F_DeptId;
  2431. string bmmc = "";
  2432. if (F_UserID > 0)
  2433. {
  2434. YTSoft.BaseCallCenter.BLL.T_Sys_Department depBll = new BLL.T_Sys_Department();
  2435. List<Model.T_Sys_Department> list = new List<T_Sys_Department>();
  2436. list = depBll.GetModelList("F_DeptId=" + bmid);
  2437. if (list.Count > 0)
  2438. {
  2439. bmmc = list[0].F_DeptName.ToString();
  2440. result = orderBLL.CheHuiYCLWorkOrder(workOrderId, F_UserID, F_UserName, F_DeptId, bmmc,reason);
  2441. }
  2442. }
  2443. return result;
  2444. }
  2445. /// 回访人撤回自己回访的,工单状态是待定责的工单 ;客服角色的回访列表里
  2446. [AcceptVerbs(HttpVerbs.Get)]
  2447. public bool ResetVisitedWorkOrder(int workOrderId,string reason)
  2448. {
  2449. string F_UserCode = "";
  2450. if (Request.Cookies["BaseCallCenter_T_User"] != null)
  2451. {
  2452. F_UserCode = Request.Cookies["BaseCallCenter_T_User"]["F_UserCode"];
  2453. }
  2454. bool result = false; ;
  2455. string bycode = F_UserCode;
  2456. string byname = F_UserName;
  2457. int bmid = F_DeptId;
  2458. string bmmc = "";
  2459. if (F_UserID > 0)
  2460. {
  2461. YTSoft.BaseCallCenter.BLL.T_Sys_Department depBll = new BLL.T_Sys_Department();
  2462. List<Model.T_Sys_Department> list = new List<T_Sys_Department>();
  2463. list = depBll.GetModelList("F_DeptId=" + bmid);
  2464. if (list.Count > 0)
  2465. {
  2466. bmmc = list[0].F_DeptName.ToString();
  2467. result = orderBLL.CheHuiDDZWorkOrder(workOrderId, F_UserID, F_UserName, F_DeptId, bmmc,reason);
  2468. }
  2469. }
  2470. return result;
  2471. }
  2472. public ActionResult DepartmentWorkOrderList()
  2473. {
  2474. CallScreenModel callScreenModel = new CallScreenModel();
  2475. //业务类型字典表
  2476. callScreenModel.WorkOrderTypeModelList = GetWorkTypeModelList();
  2477. //业务类型字典表
  2478. callScreenModel.GoTypeModelList = GetCodeType("CLFS");
  2479. //话务标志
  2480. callScreenModel.SeatFlag = F_SeatFlag;
  2481. return View(callScreenModel);
  2482. }
  2483. /// <summary>
  2484. /// 获取工单信息
  2485. /// </summary>
  2486. /// <param name="page">当前页码</param>
  2487. /// <param name="limit">每页数据量</param>
  2488. /// <param name="sqlWhere">查询条件</param>
  2489. /// <returns></returns>
  2490. [ActionName("ReassignmentDeparmentWorkOrderAllData")]
  2491. [HttpGet]
  2492. public string DepartmentWorkOrderList(DateTime? NowDateTime, int page, int limit, int? types, string dateParty,
  2493. string workorderNum, string cusName, string phoneNumber, string userInfo, int? status, int? bussType, int? detailType, string Content, int? GoType, int? FromType, int? F_HASTENCOUNTS, int? turnout)
  2494. {
  2495. //数据结果集
  2496. ResponseData dataModel = new ResponseData();
  2497. string sql = "";
  2498. //未按时转出
  2499. if (turnout.ToInt32() > 0)
  2500. {
  2501. sql += " and t.turntime =0 ";
  2502. }
  2503. //工单编号
  2504. if (!string.IsNullOrEmpty(workorderNum))
  2505. {
  2506. sql += " and t.F_CODE like '%" + workorderNum.Trim() + "%'";
  2507. }
  2508. //客户姓名
  2509. if (!string.IsNullOrEmpty(cusName))
  2510. {
  2511. sql += " and t.F_CUSTOMERNAME like '%" + cusName.Trim() + "%'";
  2512. }
  2513. //客户电话
  2514. if (!string.IsNullOrEmpty(phoneNumber))
  2515. {
  2516. sql += " and t.F_CUSTOMERTELEPHONE like '%" + phoneNumber.Trim() + "%'";
  2517. }
  2518. //坐席工号
  2519. if (!string.IsNullOrEmpty(userInfo))
  2520. {
  2521. sql += " and t.F_LINKMAN like '%" + userInfo.Trim() + "%'";
  2522. }
  2523. //状态 F_WORKORDERSTATEID 0未处理 1处理中 2已办结(结束) 3待回访 4待定责 5已定责
  2524. if (status != null)
  2525. {
  2526. sql += " and t.F_WORKORDERSTATEID =" + status;
  2527. }
  2528. //业务类别
  2529. if (bussType != null && bussType > 0)
  2530. {
  2531. sql += " and t.F_FILEFLAG =" + bussType;
  2532. }
  2533. //业务类型
  2534. if (detailType != null && detailType > 0)
  2535. {
  2536. sql += " and t.F_REPAIRLEVEL =" + detailType;
  2537. }
  2538. //内容
  2539. if (!string.IsNullOrEmpty(Content))
  2540. {
  2541. sql += " and t.F_CONTENT like '%" + Content.Trim() + "%'";
  2542. }
  2543. //处理方式 F_WORKORDERTYPEID 处理方式 1转单 3客服处理
  2544. if (GoType != null && GoType > 0)
  2545. {
  2546. sql += " and t.F_WORKORDERTYPEID =" + GoType;
  2547. }
  2548. //接入渠道 1语音 2留言 3微信 4微博
  2549. if (FromType != null && FromType > 0)
  2550. {
  2551. sql += " and t.F_REPAIRMANID =" + FromType;
  2552. }
  2553. //查询按钮
  2554. if (types == 0 || types == null)
  2555. {
  2556. if (!string.IsNullOrEmpty(dateParty))
  2557. {
  2558. string startDate = dateParty.Substring(0, 10);
  2559. string endDate = dateParty.Substring(12);
  2560. sql += " and t.F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  2561. sql += " and t.F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  2562. }
  2563. else
  2564. {
  2565. string endDate = DateTime.Now.ToString("yyyy-MM-dd");
  2566. string startDate = DateTime.Now.ToString("yyyy-MM-dd");
  2567. sql += " and t.F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  2568. sql += " and t.F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  2569. }
  2570. }//一周按钮
  2571. else if (types == 1)
  2572. {
  2573. string endDate = DateTime.Now.ToString("yyyy-MM-dd");
  2574. string startDate = DateTime.Now.AddDays(-7).ToString("yyyy-MM-dd");
  2575. sql += " and t.F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  2576. sql += " and t.F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  2577. }//一月按钮
  2578. else if (types == 2)
  2579. {
  2580. string endDate = DateTime.Now.ToString("yyyy-MM-dd");
  2581. string startDate = DateTime.Now.AddMonths(-1).ToString("yyyy-MM-dd");
  2582. sql += " and t.F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  2583. sql += " and t.F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  2584. }//一年按钮
  2585. else if (types == 3)
  2586. {
  2587. string endDate = DateTime.Now.ToString("yyyy-MM-dd");
  2588. string startDate = DateTime.Now.AddYears(-1).ToString("yyyy-MM-dd");
  2589. sql += " and t.F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  2590. sql += " and t.F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  2591. }
  2592. //一天按钮
  2593. else if (types == 4)
  2594. {
  2595. string endDate = DateTime.Now.ToString("yyyy-MM-dd");
  2596. string startDate = DateTime.Now.ToString("yyyy-MM-dd");
  2597. sql += " and t.F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  2598. sql += " and t.F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  2599. }
  2600. //string tableNew = "(select DISTINCT t.* ";
  2601. //tableNew += ", case WHEN F_SENTORDERTIME IS NULL AND DATEDIFF(minute, DATEADD(day,1,F_CREATEDATE), GETDATE())> 0 THEN 0 WHEN F_SENTORDERTIME IS NULL THEN 1 WHEN DATEDIFF(minute, DATEADD(day,1,F_CREATEDATE), F_SENTORDERTIME)> 0 THEN 0 ELSE 1 END AS turntime ";
  2602. //tableNew += " from T_Wo_WorkOrderBase t LEFT JOIN T_Wo_WorkOrderHistory h ON t.F_WORKORDERID=h.F_INSTANCEID LEFT JOIN T_Sys_UserAccount u ON t.F_USERID= u.F_UserId";
  2603. //tableNew += " ) as t";
  2604. string tableNew = " (select * from T_Wo_WorkOrderBase WHERE F_WORKORDERID in (SELECT DISTINCT F_WORKORDERID FROM dbo.T_Wo_WorkOrderBase a LEFT JOIN t_wo_workorderhistory b ON a.F_WORKORDERID = b.F_INSTANCEID WHERE a.F_WORKORDERTYPEID = 1 AND b.F_StateName != '已撤回' AND b.F_StateName != '已驳回' AND b.F_OPTUSERID IN( SELECT F_UserId FROM t_sys_useraccount WHERE F_DeptId = " + F_DeptId + "))) as t";
  2605. DataTable dt = new DataTable();
  2606. int recordCount = 0;
  2607. Model.PageData<Model.T_Wo_WorkOrderBase> pageModel = new Model.PageData<Model.T_Wo_WorkOrderBase>();
  2608. dt = BLL.PagerBLL.GetListPager(
  2609. tableNew,
  2610. "F_WORKORDERID",
  2611. " t.*,CONVERT(varchar,t.F_CREATEDATE, 120 ) as F_CREATEDATENew"
  2612. + @" , replace(replace(CASE F_WORKORDERFROM WHEN '留言工单' THEN (SELECT top 1 F_RecFileUrl FROM dbo.T_Call_LeaveRecord WHERE F_CallId=t.F_KSHADDRESSCODE) WHEN '语音工单' THEN (SELECT top 1 FilePath FROM dbo.T_Call_CallRecords WHERE CallId=t.F_KSHADDRESSCODE) ELSE NULL END,'\','/'),'" + GetSysconfig("newFilePath") + "','" + GetSysconfig("newPlayPath") + "') as FilePath"
  2613. ,
  2614. sql,
  2615. "ORDER BY t.F_CREATEDATE desc",
  2616. limit,
  2617. page,
  2618. true,
  2619. out recordCount);
  2620. dataModel.code = 0;
  2621. dataModel.count = recordCount;
  2622. dataModel.data = dt;
  2623. return JsonConvert.SerializeObject(dataModel);
  2624. }
  2625. //审批撤回的工单的页面
  2626. public ActionResult WorkOrderShenPiList()
  2627. {
  2628. WorkOrderMyModel model = new WorkOrderMyModel();
  2629. //业务类型字典表
  2630. model.WorkOrderTypeModelList = GetWorkTypeModelList();
  2631. //话务标志
  2632. model.SeatFlag = F_SeatFlag;
  2633. return View(model);
  2634. }
  2635. //审批撤回的工单的列表
  2636. [ActionName("WorkOrderShenPiData")]
  2637. [HttpGet]
  2638. public string WorkOrderShenPiData(DateTime? NowDateTime, int page, int limit, int? types, string dateParty,
  2639. string workorderNum, string cusName, string phoneNumber,
  2640. string userInfo, int? bussType, int? detailType, string Content)
  2641. {
  2642. //数据结果集
  2643. ResponseData dataModel = new ResponseData();
  2644. //F_FILEFLAG 业务类型ID
  2645. //F_WORKORDERSTATEID 0未处理 1处理中 2已办结 status
  2646. //F_WORKORDERTYPEID 处理方式 1转单 3客服处理 GoType
  2647. //F_REPAIRMANID 接入渠道 1语音 2留言 3微信 4微博 FromType
  2648. //F_RETURNVISITFLAG 1 是要回访 0 是不回访
  2649. // 撤回审批的工单状态是8,9,10
  2650. string sql = " and F_WORKORDERSTATEID in(8,9,10)";
  2651. //工单编号
  2652. if (!string.IsNullOrEmpty(workorderNum))
  2653. {
  2654. sql += " and F_CODE like '%" + workorderNum.Trim() + "%'";
  2655. }
  2656. //客户姓名
  2657. if (!string.IsNullOrEmpty(cusName))
  2658. {
  2659. sql += " and F_CUSTOMERNAME like '%" + cusName.Trim() + "%'";
  2660. }
  2661. //客户电话
  2662. if (!string.IsNullOrEmpty(phoneNumber))
  2663. {
  2664. sql += " and F_CUSTOMERTELEPHONE like '%" + phoneNumber.Trim() + "%'";
  2665. }
  2666. //坐席工号
  2667. if (!string.IsNullOrEmpty(userInfo))
  2668. {
  2669. sql += " and F_LINKMAN like '%" + userInfo.Trim() + "%'";
  2670. }
  2671. //业务类别
  2672. if (bussType != null && bussType > 0)
  2673. {
  2674. sql += " and F_FILEFLAG =" + bussType;
  2675. }
  2676. //业务类型
  2677. if (detailType != null && detailType > 0)
  2678. {
  2679. sql += " and F_REPAIRLEVEL =" + detailType;
  2680. }
  2681. //内容
  2682. if (!string.IsNullOrEmpty(Content))
  2683. {
  2684. sql += " and F_CONTENT like '%" + Content.Trim() + "%'";
  2685. }
  2686. //查询按钮
  2687. if (types == 0)
  2688. {
  2689. if (!string.IsNullOrEmpty(dateParty))
  2690. {
  2691. string startDate = dateParty.Substring(0, 10);
  2692. string endDate = dateParty.Substring(12);
  2693. sql += " and F_CREATEDATE>= '" + startDate + " 00:00:00" + "'";
  2694. sql += " and F_CREATEDATE<= '" + endDate + " 23:59:59" + "'";
  2695. }
  2696. }//一周按钮
  2697. else if (types == 1)
  2698. {
  2699. string endDate = DateTime.Now.ToString();
  2700. string startDate = DateTime.Now.AddDays(-7).ToString();
  2701. sql += " and F_CREATEDATE>= '" + startDate + "'";
  2702. sql += " and F_CREATEDATE<= '" + endDate + "'";
  2703. }//一月按钮
  2704. else if (types == 2)
  2705. {
  2706. string endDate = DateTime.Now.ToString();
  2707. string startDate = DateTime.Now.AddMonths(-1).ToString();
  2708. sql += " and F_CREATEDATE>= '" + startDate + "'";
  2709. sql += " and F_CREATEDATE<= '" + endDate + "'";
  2710. }//一年按钮
  2711. else if (types == 3)
  2712. {
  2713. string endDate = DateTime.Now.ToString();
  2714. string startDate = DateTime.Now.AddYears(-1).ToString();
  2715. sql += " and F_CREATEDATE>= '" + startDate + "'";
  2716. sql += " and F_CREATEDATE<= '" + endDate + "'";
  2717. }
  2718. DataTable dt = new DataTable();
  2719. int recordCount = 0;
  2720. Model.PageData<Model.T_Wo_WorkOrderBase> pageModel = new Model.PageData<Model.T_Wo_WorkOrderBase>();
  2721. dt = BLL.PagerBLL.GetListPager(
  2722. "T_Wo_WorkOrderBase",
  2723. "F_WORKORDERID",
  2724. "*,CONVERT(varchar,F_CREATEDATE, 120 ) as F_CREATEDATENew"
  2725. + string.Format(",(select top 1 F_HISTORYID from T_Wo_WorkOrderHistory where F_INSTANCEID=F_WORKORDERID and F_WORKORDERSTATEID=0 and F_OPTUSERID={0} Order by F_OPTDATE desc) AS F_HISTORYID", F_UserID)
  2726. + @" , replace(replace(CASE F_WORKORDERFROM WHEN '留言工单' THEN (SELECT top 1 F_RecFileUrl FROM dbo.T_Call_LeaveRecord WHERE F_CallId=F_KSHADDRESSCODE) WHEN '语音工单' THEN (SELECT top 1 FilePath FROM dbo.T_Call_CallRecords WHERE CallId=F_KSHADDRESSCODE AND FilePath!='') ELSE NULL END,'\','/'),'" + GetSysconfig("newFilePath") + "','" + GetSysconfig("newPlayPath") + "') as FilePath",
  2727. //+ " ,(CASE F_WORKORDERFROM WHEN '留言工单' THEN (SELECT F_RecFileUrl FROM dbo.T_Call_LeaveRecord WHERE F_CallId=F_KSHADDRESSCODE) WHEN '语音工单' THEN (SELECT FilePath FROM dbo.T_Call_CallRecords WHERE CallId=F_KSHADDRESSCODE AND FilePath!='') ELSE NULL END ) as FilePath",
  2728. sql,
  2729. "ORDER BY F_CREATEDATE desc",
  2730. limit,
  2731. page,
  2732. true,
  2733. out recordCount);
  2734. dataModel.code = 0;
  2735. dataModel.count = recordCount;
  2736. dataModel.data = dt;
  2737. return JsonConvert.SerializeObject(dataModel);
  2738. }
  2739. [AcceptVerbs(HttpVerbs.Post)]
  2740. public bool SubmiShenPiYJ(int workorderid, int shenpiresult, string shenpiopinion)
  2741. {
  2742. //int workorderid, int shenpiresult,string shenpiopinion,int byid,string byname,int bmid )
  2743. //AddAction("t_wo_workorderhistory", workOrderBaseModel.F_HISTORYID.ToMyString(), "提交工单", "数据:" + JsonConvert.SerializeObject(workOrderBaseModel), "关键信息");
  2744. //AddAction("t_wo_workorderhistory", workOrderBaseModel.F_HISTORYID.ToMyString(), "部门提交工单", workOrderBaseModel.F_INSTANCEID.ToMyString());
  2745. return orderBLL.SubmitShenPiYj(workorderid, shenpiresult, shenpiopinion,F_UserID,F_UserName,F_DeptId);
  2746. }
  2747. //审批工单弹框 页面
  2748. public ActionResult OrderShenPiTanKuangList()
  2749. {
  2750. WorkOrderMyModel model = new WorkOrderMyModel();
  2751. //业务类型字典表
  2752. model.WorkOrderTypeModelList = GetWorkTypeModelList();
  2753. //话务标志
  2754. model.SeatFlag = F_SeatFlag;
  2755. return View(model);
  2756. }
  2757. public int WorkOrderShenPiCount()
  2758. {
  2759. // string sql = string.Format(" F_WORKORDERSTATEID=4 and (F_HASTENCOUNTS=0 OR F_HASTENCOUNTS IS NULL) and (F_ROAD='{0}' Or F_ROAD='' Or F_ROAD IS NULL)", F_UserID);
  2760. string sql = " F_WORKORDERSTATEID in(8,9,10) ";
  2761. return orderBLL.GetRecordCount(sql);
  2762. }
  2763. }
  2764. }