Nessuna descrizione

WorkOrderDetails.js 12KB

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