安图前端代码

WorkOrder.js 16KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655
  1. $(document).ready(function() {
  2. initTable();
  3. initTables();
  4. $(".ss").click(function() {
  5. stype = 1;
  6. initTable();
  7. initTables();
  8. })
  9. $('.plasechoce').click(function() {
  10. $(this).parent().siblings('input').val('');
  11. })
  12. /*高级查询*/
  13. $(".gjss").click(function() {
  14. $(".t-shade").addClass("cx");
  15. $(".gjsu").addClass("cx");
  16. });
  17. $("#gjss").click(function() {
  18. stype = 2;
  19. initTable();
  20. initTables();
  21. $(".t-shade").removeClass("cx");
  22. $(".gjsu").removeClass("cx");
  23. })
  24. $(".setwin").click(function() {
  25. $(".t-shade").removeClass("cx");
  26. $(".gjsu").removeClass("cx");
  27. $(".cbgd").removeClass("cx");
  28. })
  29. //详情
  30. $(".ckxq ul li").click(function() {
  31. $(this).addClass("Active").siblings().removeClass("Active");
  32. var i = $(this).index();
  33. $(".gdxq").hide();
  34. $(".gdxq").eq(i).show();
  35. if(i > 0) {
  36. cljl(i);
  37. }
  38. });
  39. $(".Closed").click(function() {
  40. $(".ckxq").addClass("Hidens");
  41. });
  42. /*tree下拉框效果*/
  43. $(".inpBox .tree").click(function() {
  44. if($(this).parent().find(".addTree").is(":hidden")) {
  45. $(this).parent().find(".addTree").show();
  46. } else {
  47. $(this).parent().find(".addTree").hide();
  48. }
  49. });
  50. /*普通下拉框效果*/
  51. $(".inpBox .select").click(function() {
  52. if($(this).parent().find(".xl_common").is(":hidden")) {
  53. $(this).parent().find(".xl_common").show();
  54. } else {
  55. $(this).parent().find(".xl_common").hide();
  56. }
  57. });
  58. $(".xl").click(function() {
  59. if($(this).parent().find(".addTree").is(":hidden")) {
  60. $(this).parent().find(".addTree").show();
  61. } else {
  62. $(this).parent().find(".addTree").hide();
  63. }
  64. if($(this).parent().find(".xl_common").is(":hidden")) {
  65. $(this).parent().find(".xl_common").show();
  66. } else {
  67. $(this).parent().find(".xl_common").hide();
  68. }
  69. });
  70. $(".inpBox").mouseleave(function() {
  71. $(this).children(".addTree").hide();
  72. $(this).children(".xl_common").hide();
  73. })
  74. $(".xl_box").on("click", "li", function() {
  75. var obj = $(this).parent().parent().parent();
  76. obj.find("input").eq(0).val($(this).text());
  77. obj.find("input").eq(1).val($(this).attr("itemid"));
  78. obj.find(".xl_common").hide();
  79. })
  80. $("input[name='ltype']").click(function() {
  81. var val = $("input[name='ltype']:checked").val();
  82. if(val == '0') {
  83. $(".js").show();
  84. } else if(val == '1') {
  85. $(".js").hide();
  86. }
  87. })
  88. if($("#zrbmtree")) {
  89. getBM($("#zrbmtree"));
  90. }
  91. laydate.render({
  92. elem: '#greetingTimes',
  93. range: '~',
  94. // type: 'datetime',
  95. //max : 31,
  96. // min: 0,
  97. theme: '#1ab394',
  98. });
  99. //坐席
  100. getSeating()
  101. //工单类型
  102. getOrderType();
  103. //工单来源
  104. getOrderSource()
  105. // //反馈单位 、来电单位
  106. $('#comeCall_dep').comboSelect();
  107. $('#comeCall_deps').comboSelect();
  108. getAccount();
  109. function getOrderType() {
  110. $.get(huayi.config.callcenter_url + 'WorkType/GetTreeList', {
  111. "token": $.cookie("token"),
  112. }, function(result) {
  113. result = $.parseJSON(result);
  114. $.fn.zTree.init($("#TreeDemo"), setting3, result.data); //实例化树形图
  115. });
  116. }
  117. var setting3 = {
  118. data: {
  119. key: {
  120. name: "text"
  121. },
  122. simpleData: {
  123. enable: true,
  124. idKey: "id",
  125. rootPId: 0
  126. }
  127. },
  128. callback: {
  129. onClick: changeTreeClick
  130. }
  131. }
  132. function changeTreeClick(event, treeId, treeNode) {
  133. var chanId = treeNode.id;
  134. var changeName = treeNode.text;
  135. $('#typeclass').val(changeName);
  136. $('#typeclassId').val(chanId);
  137. var pidnode = treeNode.getParentNode();
  138. };
  139. $('.down').click(function() {
  140. if($('.treeList').css('display') == 'block') {
  141. $('.treeList').css('display', 'none')
  142. } else {
  143. $('.treeList').css('display', 'block')
  144. }
  145. })
  146. $('#typeclass').click(function() {
  147. $('.treeList').css('display', 'block')
  148. })
  149. $('.treeList').mouseleave(function() {
  150. $(this).css('display', 'none')
  151. })
  152. function getSeating() {
  153. $.ajax({
  154. type: "get",
  155. url: huayi.config.callcenter_url + "CallInScreen/GetUsers",
  156. dataType: 'json',
  157. async: true,
  158. data: {
  159. token: $.cookie("token")
  160. },
  161. success: function(data) {
  162. var Count = data.data.user;
  163. $(Count).each(function(i, n) {
  164. $("<option value='" + n.F_UserCode + "'>" + n.F_UserName + "</option>").appendTo($("#userid"));
  165. })
  166. $('#userid').selectpicker('refresh');
  167. }
  168. });
  169. }
  170. })
  171. // //反馈单位 、来电单位
  172. function getAccount() {
  173. $.ajax({
  174. type: "get",
  175. url: huayi.config.callcenter_url + "Customer/BindLDdep",
  176. dataType: 'json',
  177. async: true,
  178. data: {
  179. token: $.cookie("token")
  180. },
  181. success: function(data) {
  182. var Count = data.data.dep;
  183. $(Count).each(function(i, n) {
  184. $("<option value='" + n + "'>" + n + "</option>").appendTo($("#comeCall_dep"));
  185. $("<option value='" + n + "'>" + n + "</option>").appendTo($("#comeCall_deps"));
  186. })
  187. $('#comeCall_dep').comboSelect();
  188. $('#comeCall_deps').comboSelect();
  189. }
  190. });
  191. }
  192. //工单来源
  193. function getOrderSource() {
  194. $.ajax({
  195. type: "get",
  196. url: huayi.config.callcenter_url + "Dictionary/GetDicValueListByFlag",
  197. dataType: 'json',
  198. async: true,
  199. data: {
  200. token: $.cookie("token"),
  201. flag: "GDLY"
  202. },
  203. success: function(data) {
  204. var Count = data.data;
  205. $(Count).each(function(i, n) {
  206. $("<option value='" + n.F_DictionaryValueId + "'>" + n.F_Name + "</option>").appendTo($("#orderSource"));
  207. })
  208. $('#orderSource').selectpicker('refresh');
  209. }
  210. });
  211. }
  212. //编辑器配置
  213. KindEditor.ready(function(K) {
  214. window.changeEditor = K.create('#cl_gdnr'); //修改弹出框编辑器
  215. });
  216. var F_UserCode = localStorage.getItem('F_UserCode');
  217. function View(val, row) {
  218. return '<div class="imgs" ><a class="xg" index="' + row.CreateUser + '" onclick= ck("' + val + '") >' + val + '</a></div>';
  219. $("#F_UserCode").val(row.CreateUser);
  220. }
  221. function forMaterDepart(val, row) {
  222. var str = "";
  223. if(val == '' || val == null) {
  224. str = "未知"
  225. } else {
  226. str = val
  227. }
  228. return str
  229. }
  230. function OverTime(val, row) {
  231. var cs = 'Ctime';
  232. if(row.LimitTime || row.State == 1) {
  233. if(row.totalhour * 1 > row.LimitTime * 1) {
  234. cs = 'overTime_';
  235. }
  236. }
  237. return '<div class="' + cs + '" ><a class="xg" ></a></div>';
  238. }
  239. function ck(val) {
  240. selid = val;
  241. $('.modify').attr('index', selid)
  242. $(".ckxq").removeClass("Hidens");
  243. $(".ckxq ul li").eq(0).trigger("click");
  244. xq();
  245. }
  246. function Detail(val) {
  247. // if(val) {
  248. // //var strD = decodeURIComponent(val);
  249. // var strD = val;
  250. // strD = helper.filter.filterHTMLTag(strD);
  251. // if(strD.length > 10) {
  252. // strD = strD.substring(0, 10) + '...';
  253. // }
  254. // return strD;
  255. // }
  256. if(val) {
  257. var str = '<div'
  258. str = str + ' title="' + val + '" ';
  259. if(val.length > 10){
  260. str =str + '>' + val.substring(0, 10) + '...</div>';
  261. }
  262. else{
  263. str = str + '>' + val + '</div>';
  264. }
  265. return str
  266. }
  267. }
  268. function xq() {
  269. $.getJSON(huayi.config.callcenter_url + 'WorkOrder/GetWorkOrder', {
  270. "orderid": selid,
  271. "token": $.cookie("token")
  272. }, function(result) {
  273. if(result.state.toLowerCase() == "success") {
  274. if(result.data.data.length > 0) {
  275. var data = result.data.data[0];
  276. $("#xq_gdbh").text(data.WorkOrderID);
  277. $("#xq_gdlx").text(data.GDLXName);
  278. $("#xq_cjsj").text(data.CreateTime);
  279. $("#xq_gdzt").html(GetStateName(data.State));
  280. $("#xq_khxm").text(data.Customer);
  281. $("#xq_khdh").text(data.CustomerTel);
  282. if(data.Address != null || data.Address != "") {
  283. $("#xq_wtlx").text(data.Address);
  284. } else {
  285. $("#xq_wtlx").text('未知');
  286. }
  287. $("#xq_zxgh").text(data.Source);
  288. // $("#xq_gdnr").html(decodeURIComponent(data.Detail)); //工单详情
  289. $("#xq_gdnr").html(data.Detail); //工单详情
  290. $('#bz-1').text(data.County);
  291. $("#bz-2").text(data.Province);
  292. $("#bz-3").text(data.City);
  293. $("#xq_kdxx").text(data.Files);
  294. $(".gdxq").eq(0).find(".allbc").remove();
  295. if(result.data.item.length > 0) {
  296. var html = '<div class="allbc">补充记录' +
  297. '<table class="table table-hover table-striped"><thead><tr><th><div class="th-inner">补充人</div></th>' +
  298. '<th><div class="th-inner">补充详情</div></th><th><div class="th-inner">创建时间</div></th></tr></thead><tbody>';
  299. $(result.data.item).each(function(i, n) {
  300. html += '<td>' + n.CreateUserName + '</td><td>' + n.Detail + '</td><td>' + n.CreateTime + '</td>';
  301. })
  302. html += '</tbody></table></div>';
  303. $(".gdxq").eq(0).append($(html));
  304. }
  305. }
  306. }
  307. })
  308. }
  309. function cljl(type) {
  310. //先销毁表格
  311. var table = $(".gdxq").eq(type).find("table");
  312. table.bootstrapTable('destroy');
  313. //初始化表格,动态从服务器加载数据
  314. table.bootstrapTable({
  315. method: "get", //使用get请求到服务器获取数据
  316. url: huayi.config.callcenter_url + "WorkOrder/GetItemList", //获取数据的Servlet地址
  317. contentType: 'application/x-www-form-urlencoded',
  318. striped: true, //表格显示条纹
  319. pagination: true, //启动分页
  320. pageSize: 10, //每页显示的记录数
  321. pageNumber: 1, //当前第几页
  322. pageList: [10, 20, 50, 100], //记录数可选列表
  323. search: false, //是否启用查询
  324. showColumns: false, //显示下拉框勾选要显示的列
  325. showRefresh: false, //显示刷新按钮
  326. sidePagination: "server", //表示服务端请求
  327. //设置为undefined可以获取pageNumber,pageSize,searchText,sortName,sortOrder
  328. //设置为limit可以获取limit, offset, search, sort, order
  329. queryParamsType: "undefined",
  330. queryParams: function queryParams(params) { //设置查询参数
  331. var param = {
  332. page: params.pageNumber,
  333. pagesize: params.pageSize,
  334. type: type,
  335. id: selid,
  336. token: $.cookie("token")
  337. };
  338. return param;
  339. },
  340. onLoadSuccess: function() { //加载成功时执行
  341. //layer.msg("加载成功");
  342. },
  343. onLoadError: function() { //加载失败时执行
  344. //layer.msg("加载数据失败", { time: 1500, icon: 2 });
  345. }
  346. });
  347. }
  348. function GetTypeName(val) {
  349. var str = '';
  350. switch(val + '') {
  351. case '1':
  352. str = "咨询";
  353. break;
  354. case '2':
  355. str = "报修服务";
  356. break;
  357. case '3':
  358. str = "投诉建议";
  359. break;
  360. }
  361. return str;
  362. }
  363. function GetStateName(val) {
  364. // var str = '';
  365. // switch (val + '') {
  366. // case '0': str = "待指派"; break;
  367. // case '1': str = "处理中"; break;
  368. // case '2': str = "已完结"; break;
  369. // }
  370. //if(val==0){
  371. // return '<div class="warning">待指派</div>'
  372. //}else if(val==1){
  373. // return '<div class="primary">处理中</div>'
  374. //}else if(val==2){
  375. // return '<div class="defauli">已完结</div>'
  376. // }
  377. if(val == 0) {
  378. return '<div class="warning">待处理</div> '
  379. } else {
  380. return '<div class="defauli">已处理</div>'
  381. }
  382. return str;
  383. }
  384. function ComXQ(val, row) {
  385. var str = '';
  386. if(row.IsLast) {
  387. str = str + row.CreateUser + " 完结工单。" + "<br>";
  388. }
  389. if(row.DealTime) {
  390. str = str + row.CreateUser + " 处理工单:" + "<br>";
  391. str = str + row.Detail + "<br>";
  392. }
  393. if(row.SureUserName) {
  394. str = str + row.SureUserName + " 接单。" + "<br>";
  395. }
  396. if(row.ToDeptName) {
  397. str = str + row.CreateUserName + " 指派工单给 " + row.ToDeptName + " ";
  398. if(row.ToUserName) {
  399. str = str + row.ToUserName;
  400. }
  401. str = str + "<br>";
  402. }
  403. if(row.IsStart) {
  404. str = str + row.CreateUserName + " 重新开启工单。" + "<br>";
  405. }
  406. return str;
  407. }
  408. //获取部门
  409. var setting = {
  410. data: {
  411. key: {
  412. name: "F_DeptName"
  413. },
  414. simpleData: {
  415. enable: true,
  416. idKey: "F_DeptId",
  417. pIdKey: "F_ParentId",
  418. rootPId: 0
  419. }
  420. },
  421. callback: {
  422. onClick: zTreeOnClick
  423. }
  424. };
  425. function getBM(obj) {
  426. $.getJSON(huayi.config.callcenter_url + 'Department/GetAllList', {
  427. "token": $.cookie("token")
  428. }, function(result) {
  429. if(result.state.toLowerCase() == "success") {
  430. $.fn.zTree.init(obj, setting, result.data);
  431. }
  432. })
  433. }
  434. function zTreeOnClick(event, treeId, treeNode) {
  435. if(event) {
  436. event.stopPropagation();
  437. }
  438. var obj = $("#" + event.data.treeId).parent();
  439. obj.parent().find("input").eq(0).val(treeNode.F_DeptName);
  440. obj.parent().find("input").eq(1).val(treeNode.F_DeptId);
  441. obj.hide();
  442. getRY($(".clid"), $("#clbm").val());
  443. };
  444. //获取人员
  445. function getRY(obj, deptid) {
  446. obj.empty();
  447. obj.append('<li itemid="">--请选择--</li>');
  448. obj.parent().parent().find("input").eq(0).val("--请选择--");
  449. obj.parent().parent().find("input").eq(1).val("");
  450. $.getJSON(huayi.config.callcenter_url + 'UserAccount/GetDeptUserList', {
  451. "deptid": deptid,
  452. "token": $.cookie("token")
  453. }, function(result) {
  454. if(result.state.toLowerCase() == "success") {
  455. $(result.data).each(function(i, n) {
  456. obj.append('<li itemid="' + n.F_UserCode + '">' + n.F_UserName + '</li>');
  457. })
  458. obj.find("li").click(function(event) {
  459. if(event) {
  460. event.stopPropagation();
  461. }
  462. $(this).parent().parent().parent().find("input").eq(0).val($(this).text());
  463. $(this).parent().parent().parent().find("input").eq(1).val($(this).attr("itemid"));
  464. $(this).parent().parent().hide();
  465. });
  466. }
  467. })
  468. }
  469. function Appoint(val, row) {
  470. return czhtml(val, row, "处理");
  471. }
  472. function Dispose(val, row) {
  473. return czhtml(val, row, "处理");
  474. }
  475. function czhtml(val, row, str) {
  476. if(row.CreateUser == F_UserCode) {
  477. return '<div class="imgs" ><a class="xg" onclick="getOrderDetail(\'' + val + '\',\'' + row.TypeClassName + '\')">' + str + '</a></div>';
  478. }
  479. }
  480. function oper(val, obj) {
  481. zpid = val;
  482. var zp = JSON.parse($(obj).attr("itemstr"));
  483. $("#cl_gdbh").text(zp.WorkOrderID);
  484. $("#cl_gdlx").text(zp.TypeClassName);
  485. $("#cl_khxm").text(zp.Customer);
  486. $("#cl_khdh").text(zp.CustomerTel);
  487. changeEditor.html(zp.Detail_2)
  488. $("#clbmname").val("");
  489. $("#clbm").val("");
  490. $("#clidname").val("");
  491. $("#clid").val("");
  492. $(".clid").empty();
  493. $("#cont").val("");
  494. $(".t-shade").addClass("cx");
  495. $(".clgd").addClass("cx");
  496. }
  497. //获取详情
  498. function getOrderDetail(orderid, typeName) {
  499. zpid = orderid;
  500. $.ajax({
  501. type: "get",
  502. url: huayi.config.callcenter_url + "WorkOrder/GetWorkOrder",
  503. dataType: 'json',
  504. async: true,
  505. cache: false,
  506. data: {
  507. orderid: orderid,
  508. token: $.cookie("token")
  509. },
  510. success: function(result) {
  511. if(result.data.data.length > 0) {
  512. var data = result.data.data[0];
  513. if(data) {
  514. $("#cl_gdbh").text(data.WorkOrderID);
  515. $("#cl_gdlx").text(typeName);
  516. $("#cl_khxm").text(data.Customer);
  517. $("#cl_khdh").text(data.CustomerTel);
  518. changeEditor.html(data.Detail)
  519. $("#clbmname").val("");
  520. $("#clbm").val("");
  521. $("#clidname").val("");
  522. $("#clid").val("");
  523. $(".clid").empty();
  524. $("#cont").val("");
  525. $(".t-shade").addClass("cx");
  526. $(".clgd").addClass("cx");
  527. }
  528. }
  529. }
  530. });
  531. }
  532. //点解
  533. $('.modify').click(function() {
  534. var id = $(this).attr('index');
  535. layer.open({
  536. type: 2,
  537. title: '修改工单',
  538. maxmin: true, //开启最大化最小化按钮
  539. area: ['80%', '90%'],
  540. content: '../WorkOrder/Xga.html?id=' + id
  541. // content: 'addZhiShiKuManger.html?addId=' + id + '&addPid='+ pid +'&addName='+ name +''
  542. });
  543. })
  544. //
  545. function TZ(val) {
  546. var id = val;
  547. layer.open({
  548. type: 2,
  549. title: '修改工单',
  550. maxmin: true, //开启最大化最小化按钮
  551. area: ['80%', '90%'],
  552. content: '../WorkOrder/Xga.html?id=' + id
  553. // content: 'addZhiShiKuManger.html?addId=' + id + '&addPid='+ pid +'&addName='+ name +''
  554. });
  555. }
  556. function Remove(val, row) {
  557. if(row.CreateUser == F_UserCode) {
  558. return '<div class="imgs RemoveC" ><a onclick= remove("' + val + '") >删除</a> <a onclick= TZ("' + row.WorkOrderID + '") >修改</a> </div>';
  559. }
  560. }
  561. function remove(str, row) {
  562. var type = $('#orderSource').val(); //工单来源
  563. var typeclass = $('#typeclassId').val(); //工单类型
  564. var starttime = $('#greetingTimes').val() && $('#greetingTimes').val().split(' ~ ')[0]; //开始时间
  565. var endtime = $('#greetingTimes').val() && $('#greetingTimes').val().split(' ~ ')[1]; //结束时间
  566. var lddep = $('#comeCall_dep_input').val(); //来电单位
  567. var fkdep = $('#comeCall_deps_input').val(); //来电单位
  568. var userid = $('#userid').val(); //坐席
  569. layer.confirm('确定删除当前记录?', {
  570. btn: ['是', '否'] //按钮
  571. }, function(index) {
  572. /*执行删除*/
  573. $.ajax({
  574. type: "get",
  575. url: huayi.config.callcenter_url + "WorkOrder/DelWorkOrder",
  576. dataType: 'json',
  577. async: true,
  578. data: {
  579. ids: str,
  580. token: $.cookie("token")
  581. },
  582. success: function(data) {
  583. layer.msg("删除成功!");
  584. // initTable(type, typeclass, starttime, endtime, lddep, fkdep, userid);
  585. $('#workorderlist').bootstrapTable('refresh');
  586. $('#workorderlist_').bootstrapTable('refresh');
  587. // initTables(type, typeclass, starttime, endtime, lddep, fkdep, userid);
  588. layer.close(index);
  589. }
  590. });
  591. });
  592. }
  593. //受理人判断
  594. function GetState(val, row) {
  595. if(val == 0) {
  596. return '<div class="defauli">' + IsNull(row.CreateUserNameRel) + '</div>'
  597. } else {
  598. return '<div class="defauli">' + IsNull(row.LastDealUserNameRel) + '</div>'
  599. }
  600. }
  601. //判断是否为null
  602. function IsNull(str){
  603. if(str){
  604. str =str;
  605. }else{
  606. str=" ";
  607. }
  608. return str
  609. }