安图前端代码

WorkOrder.js 17KB

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