Нет описания

WorkOrderDetails.js 12KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401
  1. var selid = helper.request.queryString("id");
  2. var type = helper.request.queryString("type");
  3. $(document).ready(function () {
  4. //工单详情
  5. getWorkOrderDetails();
  6. getWorkOrderRecord();
  7. //获取角色
  8. getLoginPerson();
  9. // 工单详情、记录切换
  10. $(".ckxq ul li").click(function() {
  11. $(this).addClass("Active").siblings().removeClass("Active");
  12. var i = $(this).index();
  13. $(".gdxq").hide();
  14. $(".gdxq").eq(i).show();
  15. if(i === 0) {
  16. getWorkOrderDetails();
  17. } else if(i === 1) {
  18. getWorkOrderRecord();
  19. } else if (i === 2) {
  20. getWorkOrderDe();
  21. } else if (i === 3) {
  22. // 催单
  23. $('.customerSubmit').click(function() {
  24. saveCustomer();
  25. });
  26. // } else if (i === 4) {
  27. // //完善
  28. // $('.customerSubmit').click(function() {
  29. // saveCustomer();
  30. // });
  31. }
  32. });
  33. //提交
  34. $(".repeatSubmit").click(function() {
  35. submitRepeatWorkOrder();
  36. })
  37. /*
  38. 判断提交按钮是否显示
  39. type:
  40. 1: 隐藏提交按钮
  41. */
  42. if(type === "1") {
  43. $(".repeatSubmit").hide();
  44. } else {
  45. $(".repeatSubmit").show();
  46. }
  47. })
  48. // 工单详情
  49. function getWorkOrderDetails() {
  50. $.getJSON(huayi.config.callcenter_url + 'WorkOrder/GetDetails', {
  51. id: selid,
  52. token: $.cookie("token")
  53. }, function(result) {
  54. if(result.state.toLowerCase() == "success") {
  55. if(result.rows.length > 0) {
  56. var data = result.rows[0];
  57. $("#detailWorkOrderId").text(data.F_WorkOrderId);
  58. $("#detailSource").text(workOrderDetailsSourceJudge(data)); //工单来源
  59. $("#detailType").text(workOrderDetailsTypeJudge(data)); //工单类别
  60. $("#detailAreaName").html(data.F_AreaName);
  61. $("#detailOfficeName").text(data.F_OfficName);
  62. $("#detailCreateTime").text(data.F_CreateTime);
  63. $("#detailDealTimely").text(data.F_DealTimely); //重要级别
  64. $("#detailReason").text(data.F_Reason); //重要原因
  65. $("#detailCusName").text(data.F_CusName);
  66. $("#detailCusPhone").text(data.F_CusPhone);
  67. $("#detailAddress").text(data.F_AddRess);
  68. $("#detailProductType").text(data.F_ProductType); //产品代码
  69. $("#detailProductName").text(data.F_ProductName);
  70. $('#detailSpecifications').text(data.F_Specifications);
  71. $("#detailPRoductDate").text(data.F_ProductDate); //生产日期
  72. $("#detailBatchNumber").text(data.F_BatchNumber);
  73. $("#detailManufacturer").text(data.F_Manufacturer);
  74. $("#detailProblemCode").text(data.F_ProblemCode); //问题代码
  75. $("#detailQualityProblem").text(data.F_QualityProblem);
  76. $("#detailNotifications").text(data.F_Notifications);
  77. $("#detailReceivingPerson").text(data.F_ReceivingPerson);
  78. $("#detailSerialNumber").text(data.F_SerialNumber);
  79. $("#detailState").text(workOrderDetailsStateJudge(data)); //工单状态
  80. $("#detailContent").text(data.F_Content);
  81. $("#detailDealResult").text(data.F_DealResult); //落实情况
  82. $("#detailDealUser").text(data.F_DealUser);
  83. $("#detailReduction").text(workOrderDetailsReduction(data)); //减免
  84. $("#detailReductionRemarks").text(data.F_RemissionRemarks); //减免备注
  85. $("#detailTransferTime").text(data.F_TransferTime); //转派时间
  86. $("#detailDealTime").text(data.F_DealTime); //处理时间
  87. $("#detailReceiving").text(data.F_Receiving); //接单时间
  88. var processingProgress = data.F_State; //处理进度
  89. getLoginPerson(processingProgress)
  90. }
  91. }
  92. })
  93. }
  94. // 工单记录
  95. function getWorkOrderRecord() {
  96. //先销毁表格
  97. $('#workOrderRecord').bootstrapTable('destroy');
  98. //初始化表格,动态从服务器加载数据
  99. $('#workOrderRecord').bootstrapTable({
  100. method: "get", //使用get请求到服务器获取数据
  101. url: huayi.config.callcenter_url + "WorkOrder/GetItemList", //获取数据的Servlet地址
  102. contentType: 'application/x-www-form-urlencoded',
  103. striped: true, //表格显示条纹
  104. pagination: true, //启动分页
  105. pageSize: 5, //每页显示的记录数
  106. pageNumber: 1, //当前第几页
  107. pageList: [5, 10, 20], //记录数可选列表
  108. search: false, //是否启用查询
  109. showColumns: false, //显示下拉框勾选要显示的列
  110. showRefresh: false, //显示刷新按钮
  111. sidePagination: "server", //表示服务端请求
  112. //设置为undefined可以获取pageNumber,pageSize,searchText,sortName,sortOrder
  113. //设置为limit可以获取limit, offset, search, sort, order
  114. queryParamsType: "undefined",
  115. queryParams: function queryParams(params) { //设置查询参数
  116. var param = {
  117. id: selid, // 工单ID
  118. token: $.cookie("token"),
  119. pageindex: params.pageNumber, //页码
  120. pagesize: params.pageSize, //条数
  121. };
  122. return param;
  123. },
  124. // responseHandler: function(res) {
  125. // return {
  126. // "total": res.itemlasts.length,//总页数
  127. // "rows": res.itemlasts //数据
  128. // };
  129. // },
  130. onLoadSuccess: function() { //加载成功时执行
  131. //layer.msg("加载成功");
  132. },
  133. onLoadError: function() { //加载失败时执行
  134. //layer.msg("加载数据失败", { time: 1500, icon: 2 });
  135. }
  136. });
  137. }
  138. function getWorkOrderDe() {
  139. $.getJSON(huayi.config.callcenter_url + 'WorkOrder/GetDetails', {
  140. id: selid,
  141. "token": $.cookie("token")
  142. }, function(result) {
  143. if(result.state.toLowerCase() == "success") {
  144. var con = result;
  145. if (con) {
  146. $("#fileList").empty();
  147. var proimglist = con.FileUrl;
  148. if (proimglist && proimglist.length > 0) {
  149. $(proimglist).each(function(i, n) {
  150. var fileType = n.F_Type;
  151. var fileType1 = n.F_Type.split("\/")[0];
  152. if (fileType === '.jpg'||fileType === '.png'||fileType1==='image') {
  153. $('<div class="img-box">' +
  154. '<span class="img_mask"><span onclick=downloadFile("'+ n.F_Url + '","' + n.F_Name + '","' + n.F_Type +
  155. '") title="点击下载"><i class="fa fa-download" aria-hidden="true"></i></span></span>' +
  156. '<img layer-src="' + n.F_Url + '" src="' + n.F_Url + '" alt="' + n.F_Name +
  157. '" class="image-item" /><div>').appendTo("#fileList");
  158. } else {
  159. $('<div class="img-box">' +
  160. '<span class="img_mask"><span href="javascript:;" onclick=downloadFile("' + n.F_Url + '","' + n.F_Name +
  161. '","' + n.F_Type +
  162. '") title="点击下载"><i class="fa fa-download" aria-hidden="true"></i></span></span>' +
  163. '<span class="img_filename">'+n.F_OriName + n.F_Name.split(".")[1] + '</span><div>').appendTo("#fileList");
  164. }
  165. });
  166. layer.photos({
  167. photos: '#fileList',
  168. anim: 5, //0-6的选择,指定弹出图片动画类型,默认随机(请注意,3.0之前的版本用shift参数)
  169. title: '查看图片',
  170. move: '.layui-layer-title',
  171. shadeClose: false,
  172. closeBtn: 1,
  173. area: ['60%', '95%'],
  174. tab: function(pic, layero){
  175. // console.log(pic) //当前图片的一些信息
  176. }
  177. });
  178. }
  179. }
  180. }
  181. });
  182. }
  183. function downloadFile(data, strFileName, strMimeType) {
  184. event.preventDefault();
  185. //详细见文档 http://danml.com/download.html
  186. var x = new XMLHttpRequest();
  187. x.open("GET", data, true);
  188. x.responseType = 'blob';
  189. x.onload = function(e) {
  190. download(x.response, strFileName, strMimeType);
  191. }
  192. x.send();
  193. }
  194. // 工单详情中判断工单来源的值
  195. function workOrderDetailsSourceJudge (data) {
  196. if (data.F_Source === 1) {
  197. return 'PC';
  198. } else if (data.F_Source === 2) {
  199. return 'APP';
  200. } else if (data.F_Source === 3) {
  201. return '微信';
  202. } else {
  203. return '';
  204. }
  205. }
  206. // 工单详情中工单类别返回值判断
  207. function workOrderDetailsTypeJudge (data) {
  208. if (data.F_Type === 1) {
  209. return '咨询';
  210. } else if (data.F_Type === 2) {
  211. return '投诉';
  212. } else if (data.F_Type === 3) {
  213. return '重复';
  214. } else {
  215. return '';
  216. }
  217. }
  218. // 工单详情中减免返回值判断
  219. function workOrderDetailsReduction (data) {
  220. if (data.F_IsReduction === 0) {
  221. return '否';
  222. } else if (data.F_IsReduction === 1) {
  223. return '是';
  224. }
  225. }
  226. // 工单详情中工单状态返回值判断
  227. function workOrderDetailsStateJudge (data) {
  228. if (data.F_State === 0) {
  229. return '待提交';
  230. } else if (data.F_State === 1) {
  231. return '待分派';
  232. } else if (data.F_State === 2) {
  233. return '待接单';
  234. } else if (data.F_State === 3) {
  235. return '待处理';
  236. } else if (data.F_State === 4) {
  237. return '处理中';
  238. } else if (data.F_State === 5) {
  239. return '退回待分派';
  240. } else if (data.F_State === 6) {
  241. return '退回待提交';
  242. } else if (data.F_State === 10) {
  243. return '已完成';
  244. } else {
  245. return '';
  246. }
  247. }
  248. // 工单记录中工单状态返回值判断
  249. function formatterWorkOrderRecordStatus(val, row) {
  250. var formatterWorkOrderRecordStatusStr = '';
  251. if (row.F_WoState === 0){
  252. formatterWorkOrderRecordStatusStr = "待提交";
  253. }
  254. if (row.F_WoState === 1){
  255. formatterWorkOrderRecordStatusStr = "待分派";
  256. }
  257. if (row.F_WoState === 2){
  258. formatterWorkOrderRecordStatusStr = "待接单";
  259. }
  260. if (row.F_WoState === 3){
  261. formatterWorkOrderRecordStatusStr = "待处理";
  262. }
  263. if (row.F_WoState === 4){
  264. formatterWorkOrderRecordStatusStr = "处理中";
  265. }
  266. if (row.F_WoState === 5){
  267. formatterWorkOrderRecordStatusStr = "退回待分派";
  268. }
  269. if (row.F_OptType == 6){
  270. formatterWorkOrderRecordStatusStr = "退回待提交";
  271. }
  272. if (row.F_OptType == 10){
  273. formatterWorkOrderRecordStatusStr = "已完成";
  274. }
  275. return formatterWorkOrderRecordStatusStr;
  276. }
  277. // 提交重复工单
  278. function submitRepeatWorkOrder () {
  279. var laye = layer.confirm("您确定要提交重复工单吗?", {
  280. btn: ["确定", "取消"]
  281. }, function () {
  282. $.ajax({
  283. type: "post",
  284. url: huayi.config.callcenter_url + "WorkOrder/Repeat",
  285. async: true,
  286. dataType: "json",
  287. data: {
  288. token: $.cookie("token"),
  289. orderid: selid,
  290. isbj: 1
  291. },
  292. success: function (data) {
  293. if (data.state.toLowerCase() == 'success') {
  294. layer.msg("标记重复工单成功!");
  295. //工单列表
  296. parent.$("#workorderlist").bootstrapTable('refresh');
  297. //工单详情
  298. getWorkOrderDetails();
  299. getWorkOrderRecord();
  300. } else {
  301. layer.msg("标记重复工单失败!");
  302. }
  303. }
  304. });
  305. }, function(){
  306. layer.close(laye)
  307. })
  308. }
  309. // 获取当前登录人
  310. function getLoginPerson(processingProgress) {
  311. $.ajax({
  312. type: "get",
  313. url: huayi.config.callcenter_url + "UserAccount/GetNowUser",
  314. dataType: 'json',
  315. async: true,
  316. data: {
  317. token: $.cookie("token")
  318. },
  319. success: function(data) {
  320. var userRoleCode = data.data.role.F_RoleCode;
  321. // var processingProgress = processingProgress;
  322. // 判断角色权限
  323. rolePermission(userRoleCode, processingProgress)
  324. }
  325. });
  326. }
  327. /*
  328. 催单判断
  329. processingProgress
  330. 1、待分派
  331. 3、待处理
  332. 4、处理中
  333. 5、退回待分派
  334. 10、已处理
  335. userRoleCode
  336. XTGLY:系统维护
  337. CJGLY:超级管理员
  338. CLZY:总部处理专员
  339. */
  340. function rolePermission(userRoleCode, processingProgress) {
  341. if (processingProgress == 1 || processingProgress == 3 || processingProgress == 4 || processingProgress == 5) {
  342. if (userRoleCode == "XTGLY" || userRoleCode == "CJGLY" || userRoleCode == "CLZY") {
  343. $(".reminder-title").show();
  344. }
  345. } else if (processingProgress == 10) {
  346. if (userRoleCode == "XTGLY" || userRoleCode == "CJGLY" || userRoleCode == "CLZY") {
  347. $(".reminder-title").text("完善");
  348. $(".reminder-content-title").text("完善内容:")
  349. $(".reminder-title").show();
  350. }
  351. }
  352. }
  353. //催单
  354. function saveCustomer() {
  355. $.ajax({
  356. type: "post",
  357. url: huayi.config.callcenter_url + "WorkOrder/Reminder",
  358. dataType: 'json',
  359. async: true,
  360. beforeSend: function() { //触发ajax请求开始时执行
  361. $('.customerSubmit').attr("disabled", true);
  362. $('.customerSubmit').text('确定中...');
  363. },
  364. data: {
  365. token: $.cookie("token"),
  366. id: selid,
  367. count: $('#cont').val(), //催单备注
  368. },
  369. success: function(data) {
  370. if (data.state.toLowerCase() == 'success') {
  371. parent.layer.msg("催单成功!");
  372. var index = parent.layer.getFrameIndex(window.name); //先得到当前iframe层的索引
  373. parent.layer.close(index); //再执行关闭
  374. // parent.$("#workorderlist").bootstrapTable('refresh');
  375. } else {
  376. $('.customerSubmit').attr("disabled", false);
  377. $('.customerSubmit').text('确定');
  378. }
  379. }
  380. });
  381. }