portal html css js resource

consult.js 11KB

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