portal html css js resource

consult.js 11KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345
  1. $(function(){
  2. $(".onlogin .headnavbtn li").eq(0).addClass("navcurrent");
  3. loginStatus();//判断个人是否登录
  4. valUser();
  5. })
  6. //用户id
  7. var userid = $.cookie("userid");
  8. //getConsultData参数
  9. var pageSize = 5;
  10. var pageNo, isbind, status, timeType, sortType;
  11. getConsultData(pageSize, 1, true, 0, 1, 0);
  12. consultPullDownMenu();
  13. function getConsultData(pageSize, pageNo, isbind, status, timeType, sortType) {
  14. var params = {
  15. "professorId": userid, //专家ID
  16. "status": status, //查询状态 0-全部,1-进行中,2-未感谢,3-未评价,4-已完成, 可以不传,默认为0
  17. "timeType": timeType, //排序目的 0-按发起时间,1-按最后回复时间,2-按完成时间 默认为0
  18. "sortType": sortType, //排序目的 0-倒序,1-正序 默认为0
  19. "pageSize": pageSize, //每页记录数 默认为5
  20. "pageNo": pageNo //当前页码 默认为1
  21. };
  22. // console.log(params);
  23. $.ajax({
  24. url: "/ajax/consult/pqPro",
  25. type: "get",
  26. //传值:登陆人id:咨询id
  27. data: params,
  28. async: false,
  29. dataType: "json",
  30. contentType: "application/x-www-form-urlencoded",
  31. success: function(response) {
  32. // console.log(response);
  33. //数据为空时
  34. if(response.success) {
  35. if(response["data"]["data"] == null || response["data"]["data"] == undefined || response["data"]["data"] == "") {
  36. return;
  37. } else {
  38. var consultStr;
  39. var allData = response.data;
  40. var myData = allData["data"];
  41. // console.log(myData);
  42. //拿到收到咨询数据
  43. $("#workContainer").html(""); //清空数据
  44. if(myData.length != 0 && myData.length != null) {
  45. consultStr = handleData(myData, "professorId", "lookBtn");
  46. // console.log(consultStr)
  47. $("#workContainer").append(consultStr);
  48. } else {
  49. return;
  50. }
  51. //分页
  52. if(isbind == true) {
  53. $(".getConsultPage").createPage({
  54. pageCount: Math.ceil(allData.total / pageSize),
  55. current: allData.pageNo,
  56. backFn: function(p) {
  57. getConsultData(pageSize, p, false, status, timeType, sortType);
  58. }
  59. });
  60. }
  61. }
  62. }
  63. },
  64. error: function(response) {
  65. $.MsgBox.Alert('提示', "收到咨询数据请求失败");
  66. },
  67. complete: function() {
  68. }
  69. });
  70. };
  71. //data:需要处理的数据,htmlStr:页面中需要的html字符串拼接,
  72. //attrParams:数据中不同的参数比如:收到咨询是professorId,收到答复:consultantId
  73. function handleData(data, attrParams, btnCls) {
  74. var htmlStr = '';
  75. var title,
  76. office,
  77. orgName,
  78. department,
  79. address;
  80. for(var i = 0; i < data.length; i++) {
  81. //text:回复/查看,state:进行中/已完成/未评价,photoUrl:头像地址,proModify:专家认证
  82. var text, state, stateStyle, photoUrl, proModify;
  83. var modifyclass = '';
  84. if(data[i]["professor"]) { //过滤没有专家对象的数据
  85. if(data[i]["consultStatus"] == 0) {
  86. state = "进行中";
  87. stateStyle = 'status-1';
  88. text = '回复';
  89. } else if(data[i]["consultStatus"] == 1) {
  90. text = "查看";
  91. state = "已完成";
  92. stateStyle = 'status-3';
  93. if(attrParams == 'consultId') {
  94. if(data[i]["assessStatus"] == 0) {
  95. state = "待评价";
  96. stateStyle = 'status-2';
  97. }
  98. }
  99. } else if(data[i]["consultStatus"] == 2) {
  100. text = "查看";
  101. state = "新咨询";
  102. stateStyle = 'status-2';
  103. } else if(data[i]["consultStatus"] == 3) {
  104. text = "查看";
  105. state = "已谢绝";
  106. stateStyle = 'status-5';
  107. } else if(data[i]["consultStatus"] == undefined) {
  108. text = "";
  109. state = "";
  110. }
  111. //专家头像
  112. if(data[i]["professor"]["hasHeadImage"] == 0) {
  113. photoUrl = "images/default-photo.jpg"
  114. } else {
  115. photoUrl = "images/head/" + data[i]["professor"]["id"] + "_l.jpg"
  116. };
  117. //认证
  118. var oSty=autho(data[i]["professor"].authType,data[i]["professor"].orgAuth,data[i]["professor"].authStatus);
  119. modifyclass = oSty.sty;
  120. //未读消息
  121. var unread = unreadConsultFn(userid, data[i]["consultId"], i);
  122. htmlStr += "<div class='workselectitem' id='" + data[i]["consultId"] + "' >" +
  123. "<table width='100%'><tbody><tr><td width='14%' class='messagebox'>" +
  124. "<a class='workhead workitimg userRadius'>" +
  125. "<img class='headPhoto' src='" + photoUrl + "' width='100%' height='100%'>" +
  126. "</a>" +
  127. "<span class='msgprompt showUnreadMsg' style='" + unread.style + "' id='" + data[i]["consultId"] + "'>" + unread.unreadCount + "</span>" +
  128. "</td>" +
  129. "<td style='position:relative;top:20px;' width='86%'>" +
  130. "<div class='workinfor worksitcon'><h4><a class='named' id='nameS'> " + data[i]["professor"]["name"] + " </a>" +
  131. "<a class='authiconNew " + modifyclass + "' title='"+oSty.title+"' style='top:9px;'></a><input type='text' class='assessStar' value='" + data[i]["assessStar"] + "' style='display: none;'></h4><h6 class='h3Font'>";
  132. if(data[i]["professor"]["title"]) {
  133. htmlStr += "<span>" + data[i]["professor"]["title"] + "</span>, ";
  134. };
  135. if(data[i]["professor"]["office"]) {
  136. if(data[i]["professor"]["orgName"] || data[i]["professor"]["department"]) {
  137. htmlStr += "<span>" + data[i]["professor"]["office"] + "</span>, ";
  138. } else {
  139. htmlStr += "<span>" + data[i]["professor"]["office"] + "</span>";
  140. }
  141. };
  142. if(data[i]["professor"]["orgName"]) {
  143. if(data[i]["professor"]["department"]) {
  144. htmlStr += "<span>" + data[i]["professor"]["orgName"] + "</span>, ";
  145. } else {
  146. htmlStr += "<span>" + data[i]["professor"]["orgName"] + "</span>";
  147. }
  148. };
  149. if(data[i]["professor"]["department"]) {
  150. htmlStr += "<span>" + data[i]["professor"]["department"] + "</span>";
  151. };
  152. if(data[i]["professor"]["address"]) {
  153. htmlStr += ' | ' + "<span>" + data[i]["professor"]["address"] + "</span>";
  154. };
  155. htmlStr += "</h6><h6 style='position:relative;'>" +
  156. "<div class='titList'>咨询主题:<em class='h4Font'> " + data[i]["consultTitle"] + " </em></div>" +
  157. "<span class='lasttime rightTime'>" + lastReplyFn(userid, data[i]["consultId"])["lastReplyTime"] + "</span>" +
  158. "<div style='height:70px;'><p class='rebackcon lastReplyCon' >" + lastReplyFn(userid, data[i]["consultId"])["lastReplyCon"] + "</p></div>" +
  159. "</h6></div>" +
  160. "<div class='workhandle'>" +
  161. "<div class='rightopert floatR'>" +
  162. "<span attrP='" + attrParams + "' class='replybtn " + btnCls + "' id='" + data[i]["consultId"] + "' consultStatus='" + data[i]["consultStatus"] + "' assess='" + data[i]["assessStatus"] + "' thanks='" + data[i]["thanksStatus"] +
  163. "' onclick='clickLookBtn2(\"" + userid + "\",\"" + attrParams + "\",\"" + data[i]["consultId"] + "\"," + data[i]["consultStatus"] + "," + data[i]["assessStatus"] + "," + data[i]["thanksStatus"] + ");'>" +
  164. text +
  165. "</span>" +
  166. "<span class='moreopert complain'>...</span>" +
  167. "<ul class='moreopertbtn'>" +
  168. "<li>投诉</li>" +
  169. "</ul>" +
  170. "</div>" +
  171. "<div class='leftstate floatR'>" +
  172. "<span class='coultstate " + stateStyle + "'><i>" + state + "</i></span>" +
  173. "</div>" +
  174. "<div class='leftstate floatR'>" +
  175. "<span class='coultstate coulstAim status-4'><i>" + data[i]["consultType"] + "</i></span>" +
  176. "</div>" +
  177. "</div>" +
  178. "</td>" +
  179. "</tr></tbody></table>" +
  180. "</div>";
  181. }
  182. };
  183. return htmlStr;
  184. };
  185. //未读信息接口
  186. function unreadConsultFn(senderId, consultId, i) {
  187. var unreadCount, style;
  188. var params = {
  189. "senderId": senderId, //发送者ID
  190. "consultId": consultId //咨询ID
  191. };
  192. $.ajax({
  193. url: "/ajax/tidings/qaNotReadTidings",
  194. type: "get",
  195. async: false,
  196. data: params,
  197. success: function(response) {
  198. unreadCount = response["data"];
  199. if(unreadCount == 0) {
  200. style = "display:none;"
  201. } else {
  202. style = "display:block;"
  203. }
  204. },
  205. error: function(error) {
  206. $.MsgBox.Alert('提示', "未读消息请求失败");
  207. }
  208. });
  209. return {
  210. "unreadCount": unreadCount,
  211. "style": style
  212. }
  213. };
  214. //列表最后回复
  215. function lastReplyFn(sendId, consultId) {
  216. var lastReplyTimeData, lastReplyTime, lastReplyCon;
  217. $.ajax({
  218. url: "/ajax/tidings/qaLastRevovery",
  219. async: false,
  220. data: {
  221. "consultId": consultId, //咨询ID
  222. "senderId": sendId //登录者ID
  223. },
  224. success: function(response) {
  225. // console.log(response)
  226. if(response["data"] == null || response["data"] == "" || response["data"] == undefined) {
  227. lastReplyTimeData = '';
  228. lastReplyTime = '';
  229. lastReplyCon = '';
  230. } else {
  231. lastReplyTimeData = response["data"]["createTime"];
  232. lastReplyTime = lastReplyTimeData.substr(0, 4) + "-" + lastReplyTimeData.substr(4, 2) + "-" + lastReplyTimeData.substr(6, 2) + " " + lastReplyTimeData.substr(8, 2) + ":" + lastReplyTimeData.substr(10, 2)
  233. lastReplyCon = response["data"]["tidingsContant"];
  234. }
  235. },
  236. error: function(error) {
  237. $.MsgBox.Alert('提示', "最后回复数据失败");
  238. }
  239. });
  240. return {
  241. "lastReplyTime": lastReplyTime,
  242. "lastReplyCon": lastReplyCon
  243. };
  244. };
  245. //咨询下拉菜单顺序处理函数
  246. function consultPullDownMenu() { //点击下拉菜单
  247. $(".consultOption ul").find("li").click(function() {
  248. status = $(this).attr("tip");
  249. timeType = $("#showTimeSort").attr("tim");
  250. sortType = $("#timeSortId").val();
  251. $("#workContainer").remove();
  252. $("#shoudao").append('<div id="workContainer"></div>')
  253. $(".getConsultPage").remove();
  254. $("#shoudao").append('<div class="tcdPageCode getConsultPage"></div>');
  255. //console.log(status + timeType + sortType);
  256. getConsultData(pageSize, 1, true, status, timeType, sortType);
  257. });
  258. $(".timeOption ul").find("li").click(function() {
  259. status = $("#showStatus").attr("tip");
  260. timeType = $(this).attr("tim");
  261. sortType = $("#timeSortId").val();
  262. $("#workContainer").remove();
  263. $("#shoudao").append('<div id="workContainer"></div>')
  264. $(".getConsultPage").remove();
  265. $("#shoudao").append('<div class="tcdPageCode getConsultPage"></div>');
  266. //console.log(status + timeType + sortType);
  267. getConsultData(pageSize, 1, true, status, timeType, sortType);
  268. });
  269. var sortFlag = true;
  270. $("#consultArrow").click(function() {
  271. if(sortFlag == true) {
  272. $(this).find("div").css("background-position", "-20px 1px");
  273. $("#timeSortId").val("1");
  274. sortFlag = false;
  275. } else {
  276. $(this).find("div").css("background-position", "0px 1px");
  277. $("#timeSortId").val("0");
  278. sortFlag = true;
  279. }
  280. status = $("#showStatus").attr("tip");
  281. timeType = $("#showTimeSort").attr("tim");
  282. sortType = $("#timeSortId").val();
  283. $("#workContainer").remove();
  284. $("#shoudao").append('<div id="workContainer"></div>')
  285. $(".getConsultPage").remove();
  286. $("#shoudao").append('<div class="tcdPageCode getConsultPage"></div>');
  287. //console.log(status + timeType + sortType);
  288. getConsultData(pageSize, 1, true, status, timeType, sortType);
  289. });
  290. };
  291. //咨询和回复中点击查看或者回复
  292. function clickLookBtn2(sendId, attrParams, consultId, consultStatus, assessStatus, thanksStatus) {
  293. if(consultStatus == 2) {
  294. window.location.href = "consultSure.html?consultId=" + consultId
  295. } else {
  296. window.location.href = "diloags.html?sendId=" + sendId + "&attrParams=" + attrParams + "&consultId=" + consultId + "&consultStatus=" + consultStatus + "&assessStatus=" + assessStatus + "&thanksStatus=" + thanksStatus;
  297. }
  298. }