安图前端代码

WorkOrder.js 15KB

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