安图前端代码

WorkOrder.js 16KB

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