Bez popisu

WorkOrderDetails.js 12KB

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