123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226 |
- (function(window) {
- function ajaxRequist(url, obj, type, fn) {
- $.ajax({
- url: url,
- data: obj,
- dataType: 'json',
- type: type,
- traditional: true,
- success: function(data) {
- if(data.success) {
- fn(data.data)
- }
- },
- error: function(xhr, type, errorThrown) {
- $.MsgBox.Alert('提示', '服务器请求失败');
- }
- });
- }
- var LeaveWord = function() {
- var self = this;
- self.addHtml();
- self.bindEvent();
- }
- function lgin() {
- if($.cookie('userid')) {
- return true;
- }
- location.href = "login.html";
- return false;
- }
- LeaveWord.prototype.addHtml = function() {
- $("body").append('<textarea class="txtArea" id="tt" style="position:absolute;top:0;left:-999px;"></textarea>')
- var str='<div class="blackcover resAreaCover displayNone"><div class="resAreaBox"><div class="researchArea" id="subArea" style="text-align:center;">留言详情</div><div class="form-item" style="padding:0px 30px 30px;"><ul class="commentList" style="min-height: 100px;"></ul></div><span class="workclose" id="workclose"></span></div></div>'
- $("body").prepend(str);
- }
- LeaveWord.prototype.init = function(obj) {
- var id = $.cookie('userid');
- var self = this;
- this.id=obj.id;
- console.log(self)
- ajaxRequist("/ajax/leavemsg/dialog", obj, "GET", function(data) {
- if(data.length == 0) {
- return;
- $(".commentList").html("").append("<div class='con-kong displayNone'>暂无留言</div>");
- }
- $(".commentList").html("");
- for(var i = 0; i < data.length; i++) {
- var reply = "";
- if(data[i].reciver) {
- reply = '<span class="huifu">回复 </span><a href="userInforShow.html?professorId=' + data[i].reciver + '" class="userhref"><span class="h2Font messageName">张某某</span><em class="authiconNew" title="科袖认证专家"></em></a>'
- }
- if(data[i].state =="0") {
- data[i].cnt="<span style='color:#888'>该留言已被其本人删除。</span>";
- }
- var itemlist = '<li class="li-item">';
- itemlist += '<a class="madiaHead useHead useHeadMsg userhref" href="userInforShow.html?professorId=' + data[i].sender + '"></a>';
- itemlist += '<div class="madiaInfo">';
- itemlist += '<p><a href="userInforShow.html?professorId=' + data[i].sender + '" class="userhref"><span class="h2Font messageName">张某某</span><em class="authiconNew" title="科袖认证专家"></em></a>' + reply + '<span class="commenttime" style="float:right;">' + commenTime(data[i].createTime) + '</span></p>';
- itemlist += '<p class="h2Font messageContent">' + data[i].cnt + '</p>';
- itemlist += '<div class="operateSpan">'
- itemlist += '<span class="dzthumb dzthumbCan"><em class="hold-icon icon-zan"></em><em class="agreeCount" style="margin-left: 6px;">'+data[i].agreeCount+'</em></span>'
- itemlist += '<span class="callBack">回复</span>'
- itemlist += '<span class="messageDel displayNone">删除</span></div>';
- itemlist += '<div class="displayNone replyLeword"><textarea class="txtArea"></textarea><p class="pTxt"><span class="qCancel">取消</span><button class="hReply btnModel" disabled>回复</button></p></div></div></li>';
- $itemlist = $(itemlist);
- $(".commentList").append($itemlist);
- $itemlist.attr('data-obj',JSON.stringify(data[i]));
- if(id == data[i].sender) {
- $itemlist.find(".dzthumb").removeClass("dzthumbCan");
- $itemlist.find(".messageDel").removeClass("displayNone").end().find(".callBack").hide();
- }
- if(data[i].state =="0") {
- $itemlist.find(".dzthumb").removeClass("dzthumbCan");
-
- $itemlist.find(".operateSpan").remove()
- }
- if(data[i].reciver) {
- self.userInfo(data[i].sender, $itemlist, 0);
- self.userInfo(data[i].reciver, $itemlist, 1)
- } else {
- self.userInfo(data[i].sender, $itemlist, 0);
- }
- if(data[i].agreeCount)
- self.referThup(data[i].id, $itemlist, data[i].agreeCount);
- }
- })
- }
- LeaveWord.prototype.userInfo = function(uId, li, parNum) {
- ajaxRequist("/ajax/professor/editBaseInfo/" + uId, {}, "GET", function($data) {
- if(parNum == 0) {
- if($data.hasHeadImage == 1) {
- li.find(".useHead")[0].style.backgroundImage = "url(../images/head/" + $data.id + "_l.jpg" + ")";
- }
- li.find("textarea").attr("placeholder", "回复 " + $data.name + ":")
- }
- var userType = autho($data.authType, $data.orgAuth, $data.authStatus);
- li.find(".messageName").eq(parNum).html($data.name).end().end().find(".authiconNew").eq(parNum).addClass(userType.sty).attr("title", userType.title);
- })
- }
- LeaveWord.prototype.size = function() {
- if(this.val().length > 200) {
- $.MsgBox.Alert('提示', '留言不得超过200个字');
- return false;
- }
- return true;
- }
- LeaveWord.prototype.autoGrow = function() {
- document.getElementById("tt").style.width = this.scrollWidth + "px";
- document.getElementById("tt").value = this.value;
- this.style.height = this.scrollHeight + "px";
- }
- LeaveWord.prototype.bindEvent = function() {
- var self = this;
- $(".commentList").on("click", "li", function(e) {
- if(!lgin()) {
- return;
- }
- var obj=JSON.parse($(this).attr("data-obj")),
- target=e.target;
- switch (target.className){
- case "dzthumb dzthumbCan":self.thub.call(target, obj.id,obj.agreeCount);
- break;
- case "callBack":self.LwordBack(target, obj);
- break;
- case "messageDel":self.LwordDel(target, obj.id);
- break;
- case "hReply btnModel":self.replyLword(target,obj.id)
- break;
- case "qCancel": $(target).parent().siblings("textarea").val("").parents(".replyLeword").addClass("displayNone").siblings(".operateSpan").removeClass("displayNone");$(target).parent().siblings("textarea").style.height='38px';
- break;
- }
- });
- $(".msgCont").on("input", function() {
- if($.trim($(this).val()).length > 0) {
- $("#meSendtt").removeAttr("disabled");
- } else {
- $("#meSendtt").attr("disabled", "disabled");
- }
- })
- $(".commentList").on("input", "textarea", function(e) {
- if($.trim($(this).val()).length > 0) {
- $(this).siblings().find(".btnModel").removeAttr("disabled");
- self.autoGrow.call(this);
- } else {
- $(this).siblings().find(".btnModel").attr("disabled", "disabled");
- }
- })
- $("#workclose").click(function(){
- $(".blackcover").addClass("displayNone").find("ul").html("");
- })
- }
- LeaveWord.prototype.referThup = function(lid, li, num) {
- ajaxRequist("/ajax/leavemsg/agree", {
- id: lid,
- uid: $.cookie('userid')
- }, "GET", function(data) {
- if(data) {
- li.find(".dzthumbCan").addClass("dzthumbed");
-
- }
- })
- }
- LeaveWord.prototype.thub = function(lid, num) {
- var self = this;
- ajaxRequist("/ajax/leavemsg/agree", {
- id: lid,
- uid: $.cookie('userid'),
- uname: $.cookie('userName')
- }, "POST", function(data) {
- $(self).addClass('dzthumbed').find(".agreeCount").html(num+1)
-
- })
- }
- LeaveWord.prototype.replyLword = function($th, lid) {
- var self = this;
- if(!self.size.call($($th).parents(".pTxt").siblings("textarea"))) {
- return;
- }
- $.ajax({
- url:"/ajax/leavemsg/reply",
- data: {
- cnt: $($th).parents(".pTxt").siblings("textarea").val(),
- id: lid,
- uid: $.cookie('userid'),
- uname: $.cookie('userName')
- },
- dataType: 'json',
- type: "POST",
- beforeSend: function() {
- $($th).attr("disabled","true");
- },
- complete:function () {
- },
- traditional: true,
- success: function (data) {
- if (data.success) {
- $($th).parents(".pTxt").siblings("textarea").val("").parents(".replyLeword").addClass("displayNone").siblings(".operateSpan").removeClass("displayNone")
- self.init({
- id: self.id
- });
-
- }
- }
- });
- }
- LeaveWord.prototype.LwordDel = function($this, lid) {
- var self = this;
- ajaxRequist("/ajax/leavemsg/del", {
- id: lid
- }, "GET", function(data) {
- $($this).parents(".li-item").remove();
- })
- }
- LeaveWord.prototype.LwordBack = function($this, lid) {
- $(".replyLeword").each(function(item){
- $(".replyLeword").eq(item).addClass("displayNone").siblings(".operateSpan").removeClass("displayNone");
- })
- $($this).parents(".operateSpan").addClass("displayNone").siblings(".replyLeword").removeClass("displayNone")
- }
- var module = {
- lWord: new LeaveWord()
- }
- window.module = module;
- })(window)
|