123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460 |
-
- Namespace.register("U.MD.F.R"); //好友和群窗口区域命名空间
- //#region 右键菜单
- /**
- * 右键功能 显示[移动至][删除]窗体
- * 参数说明 0 当前元素 1 用户信息
- * @param {element} 右键好友的区域
- * @param {object} 好友信息
- */
- U.MD.F.R.friendsRightClickMenu = function (el, friendinfo) {
- var _friendmenuel = $('#U_MD_F_G_Div')[0], //右键的菜单
- _child = $(_friendmenuel).Child(); //子菜单
- //显示菜单,定位
- $(_friendmenuel).css({ "display": "block", "zIndex": "999" });
- U.UF.C.rightClickMenuLocation(_friendmenuel); //右键菜单定位
- //按钮功能赋值
- _child[0].onclick = function () { U.MD.F.W.popupFriendsForm(friendinfo); }; //发送消息
- _child[1].onclick = function () { U.MD.U.V.ViewOtherUserInfo(friendinfo); }; //查看个人资料
- _child[2].onmouseover = function () { U.MD.F.R.moveFriendForm(friendinfo, el, _child[2]); }; //移动联系人至
- _child[3].onclick = function () { U.MD.F.R.deleteFriendForm(friendinfo); }; //删除
- //点击其它区域隐藏右键菜单
- $(document).bind("click", function () {
- $(_friendmenuel)[0].style.display = "none";
- })
- }
- /**
- * 鼠标移动到 联系人移动至制定的好友分组弹框
- * @param {object} 好友信息
- * @param {element} 右键好友的区域
- * @param {element} onmouseover出发的按钮
- */
- U.MD.F.R.moveFriendForm = function (friendinfo, el, menubootom) {
- var i,
- _friendclassel = $(menubootom).parentElement().Child()[4], //获取好友分组打印的元素
- _friendclassinfo = US.friend.allclass; //获取用户所有的好友分组
- _friendclassel.innerText = ""; //清空之前打印的好友分组
- //如果有好友分组可以移动的情况
- if (_friendclassinfo.length > 1) {
- //循环打印好友分组
- for (i = 0; i < _friendclassinfo.length; i++) {
- //如果是当前用户所在的好友分组不打印,否则都打印
- if (_friendclassinfo[i].FriendsGroupID != friendinfo.FriendsGroupID) {
- //创建好友分组元素
- $$("div", { "class": "U_MD_F_G_Div_Children_A", "innerText": _friendclassinfo[i]["FriendsGroupName"],
- "onclick": U.UF.C.closure(function (i) {
- U.MD.F.R.assignMoveFriend(friendinfo, _friendclassinfo[i], el);
- }, [i])
- }, _friendclassel);
- }
- }
- _friendclassel.style.display = "block";
- }
- }
- /**
- * 触发移动好友
- *
- * @param {object} 好友信息
- * @param {object} 群信息
- * @param {element} 好友元素
- */
- U.MD.F.R.assignMoveFriend = function (friendinfo, groupinfo, el) {
- //只有选择移动了触发
- if (friendinfo) {
- $('#U_MD_F_G_Div')[0].style.display = "none"; //点击后隐藏右键
- $(".U_MD_F_G_Div_Children")[0].style.display = "none"; //隐藏右键后好友分组选择的菜单
- //数据库设置移动好友信息
- U.A.Request(US.CD, [US.DB, "UseStudio_Friends", "MoveFriendToOtherClass", friendinfo.FriendsID, groupinfo["FriendsGroupID"]],
- U.MD.F.R.asynAssignMoveFriend, ["", friendinfo, groupinfo, el]);
- U.alert('修改成功');
- }
- }
- /**
- * 把相应的好友移动到指定的群组里
- */
- U.MD.F.R.asynAssignMoveFriend = function (r) {
- var _child, //好友分组元素
- _context = r.context, //异步传参
- _friendinfo = _context[1], //移动好友实体
- _groupinfo = _context[2], //好友分组字体
- _el = _context[3], //移动的元素
- _friendgroupel = $("#g" + _groupinfo.FriendsGroupID)[0], //移动到的好友分组
- _previousgroupinfo = U.Json.select(US.friend.allclass, { "FriendsGroupID": _friendinfo.FriendsGroupID })[0], //修改前的好友分组
- _friendnum = U.Json.select(US.friend.friends, { "FriendsGroupID": _friendinfo.FriendsGroupID }).length - 1 //好友分组的数量
- ;
- //设置好友原本所在的分组信息
- $(_el).parentElement(2).Child()[0].innerHTML = _previousgroupinfo.FriendsGroupName + "(" + _friendnum + ")"; //移动好友出去后需改数量显示
- //好友实体的id变化FriendsGroupID
- _friendinfo.FriendsGroupID = _groupinfo.FriendsGroupID;
- //判断分组是否显示
- if (_friendgroupel) {
- _child = $(_friendgroupel).Child();
- _friendnum = U.Json.select(US.friend.friends, { "FriendsGroupID": _friendinfo.FriendsGroupID }).length;
- _child[0].innerHTML = _groupinfo["FriendsGroupName"] + "(" + _friendnum + ")"; //新好友分组
- _child[1].appendChild(_el); //添加移动的元素
- }
- }
- /**
- * 鼠标从 联系人移动至 移开
- * 隐藏现有的好友分组 Jude
- */
- U.MD.F.R.moveFriendOver = function (isdisplay, friendgroupmenu, el) {
- //判断是否是冒泡上来的,如果是冒泡的则不处理
- if (!U.UF.EV.stopBubbleMouseOutOrOver(el)) {
- //根据传参设置是否显示隐藏
- friendgroupmenu.style.display = isdisplay ? "none" : "block";
- }
- }
- /**
- * 弹出移动好友分组
- * 参数说明 0 要移动的对象的信息集合 1 右键区域
- * @param {element} 点击移动至区域
- */
- U.MD.F.R.topMoveFriendForm = function (el, friendinfo) {
- var _chooseGroupInfon = null;
- //未创建
- if (!$(".U_MD_F_G_Y_D")[0]) {
- var i, //循环
- _tempel,
- _friendclassel = $$("div", { "className": "U_MD_F_G_Y_D" }), //弹出框内容区域
- _friendclassinfo = US.friend.allclass, //好友分组信息
- _friendclassform = U.UF.UI.confirm(_friendclassel, function () { U.MD.F.R.assignMoveFriend(friendinfo, _chooseGroupInfon, el) }); //好友分组弹框
- $$("div", { "innerText": "选择好友移动至", "className": "U_MD_F_G_Y_DT" }, _friendclassel);
- _tempel = $$("div", { "className": "U_MD_F_G_Y_DS" }, _friendclassel);
- //循环所有可以移动的分组
- for (i = 0; i < _friendclassinfo.length; i++) {
- $$("div", { "innerHTML": _friendclassinfo[i].FriendsGroupName,
- "className": "U_MD_F_G_Div_Q" + (friendinfo.FriendsGroupID == _friendclassinfo[i].FriendsGroupID ? " U_MD_F_G_Div_QO" : ""),
- "onclick": U.UF.C.closure(function (i) {
- U.MD.F.R.topMoveFriendFormSwitch(this, friendinfo, _friendclassinfo[i], _friendclassform, el);
- _chooseGroupInfon = _friendclassinfo[i];
- }, [i])
- }, _tempel);
- }
- //自适应宽度
- $($(_friendclassform.content)[0]).Parent().style.height = "100%";
- } else {//已经创建
- var _formparent = $($($($($($(".U_MD_F_G_Y_D")[0]).Parent()).Parent()).Parent()).Parent()).Parent(); //获取父级窗体元素
- if (_formparent.style.display == "none") {
- _formparent.style.display = "block";
- } else {
- _formparent.style.display = "none"
- }
- }
- }
- /**
- * 右键功能 显示[移动至][删除]窗体
- *
- * @param {element} 选中变化的元素
- * @param {object} 好友信息
- * @param {object} 群信息
- * @param {array} 对话框
- ------------[0] 对话框
- * @param {element} 好友元素
- */
- U.MD.F.R.topMoveFriendFormSwitch = function (groupel, friendinfo, friendclassinfo, friendclassform, el) {
- var i, //用于循环
- _child = $(el).parentElement().Child(); //获取
- _group = $(".U_MD_F_G_Y_DS").Child();
- for (i = 0; i < _group.length; i++) {
- _group[i].className = $(".U_MD_F_G_Y_DS").Child()[i].className == "U_MD_F_G_Div_Q U_MD_F_G_Div_QO" ? "U_MD_F_G_Div_Q" : "U_MD_F_G_Div_Q";
- groupel.className = "U_MD_F_G_Div_Q U_MD_F_G_Div_QO";
- }
- //设置点击的效果
- for (i = 0; i < _child.length; i++) {
- _child[i].className = "U_MD_F_H_ZLZOCO" + (el == _child[i] ? " U_MD_F_G_Div_QQ" : "");
- }
- //设置确定按钮的事件,这里要结合窗体的api
- // friendclassform.AddEvent({ Yes: [U.MD.F.R.assignMoveFriend, [friendinfo, friendclassinfo, el]] });
- }
- //#endregion
- //#region 好友分组
- /**
- * 右键群显示
- * @param object 右键元素的信息集合
- */
- U.MD.F.R.friendClassRightClickMenu = function (friendgroupinfo, el) {
- var _el = $('#U_MD_F_G_Qun')[0], //右键的菜单
- _child = $(_el).Child(); //子菜单
- $(_el).css({ "display": "block", "zIndex": "999" }); //显示右键菜单
- U.UF.C.rightClickMenuLocation(_el); //右键菜单定位
- //修改分组名字的点击处理
- _child[0].onclick = function () { U.MD.F.R.popupUpdateFriendsClassForm(friendgroupinfo, el); };
- _child[1].onclick = function () { U.MD.F.R.popupDeleteFriendsClassForm(friendgroupinfo, el); };
- $(document).bind("click", function () {
- $('#U_MD_F_G_Qun')[0].style.display = "none";
- })
- }
- /**
- * 修改分组昵称 弹框
- * @param object 分组信息集合
- * @param object 当前的el
- */
- U.MD.F.R.popupUpdateFriendsClassForm = function (friendgroupinfo, el) {
- var _tempel,
- _temponeel,
- _temptwoel;
- var _el = $('#U_MD_F_G_Qun')[0]; //右键的菜单
- $(_el).css({ "display": "none" }); //显示右键菜单
- if (friendgroupinfo) {
- //创建好友分组的样式
- _tempel = $$("div", { "className": "U_MD_U_L_Box_I U_MD_F_Add_TNL U_MD_F_G" });
- _temponeel = $$("div", {}, _tempel)
- _temptwoel = $$("input", { "value": friendgroupinfo.FriendsGroupName, "onfocus": function () { U.UF.MR.inputPlaceholder(this, friendgroupinfo.FriendsGroupName, ""); },
- "onblur": function () { U.UF.MR.inputPlaceholder(this, "", friendgroupinfo.FriendsGroupName); }
- }, _temponeel);
- //弹出好友对话框
- U.UF.UI.confirm(_tempel, function () { U.MD.F.R.assignUpdateFriendsClass(friendgroupinfo, _temptwoel, el); }); //创建一个对话框
- }
- else {
- U.alert("暂无群信息");
- }
- }
- /**
- *
- * 参数说明 0 群消息集合 1 更改的分组名称 3对应修改的el
- * @param {object} 群信息
- * @param {element} 输入框
- * @param {object} 对应的el
- */
- U.MD.F.R.assignUpdateFriendsClass = function (friendgroupinfo, formel, el) {
- U.A.Request(US.CD, [US.DB, "UseStudio_Friends", "UpdateClassNameAndDescription", friendgroupinfo["FriendsGroupID"], formel.value, ""],
- function () {
- $(el)[0].innerText = formel.value;
- U.alert("修改成功");
- }, []);
- U.alert("正在修改中");
- }
- /*
- * 删除好友分组弹框
- * @param object 分组信息集合
- * @param object 当前的el
- */
- U.MD.F.R.popupDeleteFriendsClassForm = function (friendgroupinfo, el) {
- var _content;
- var _el = $('#U_MD_F_G_Qun')[0]; //右键的菜单
- $(_el).css({ "display": "none" }); //显示右键菜单
- if (friendgroupinfo) {
- _content = "是否确定删除(" + friendgroupinfo.FriendsGroupName + ")该分组";
- U.UF.UI.confirm(_content, function () { U.MD.F.R.assignDeleteFriendsClass(friendgroupinfo, el); });
- }
- }
- /*
- * 确定删除好友分组
- * @param object 分组信息集合
- * @param object 当前的el
- */
- U.MD.F.R.assignDeleteFriendsClass = function (friendgroupinfo, el) {
- var _friendGroupLength = U.Json.select(US.friend.friends, { "FriendsGroupID": friendgroupinfo.FriendsGroupID }).length;
- if (friendgroupinfo.FriendsGroupDescript != "自动创建") {
- if (_friendGroupLength == 0) {
- U.A.Request(US.CD, [US.DB, "UseStudio_Friends", "DeleteFriendClass", friendgroupinfo.FriendsGroupID],
- function () {
- $(el).Parent().remove()
- U.alert("删除成功");
- //在好友数组的全局变量中删除好友分组的信息
- for (i = 0; i < US.friend.allclass.length; i++) {
- if (US.friend.allclass[i].FriendsGroupID == friendgroupinfo.FriendsGroupID) {
- US.friend.allclass.splice(i, 1);
- }
- }
- }, []);
- U.alert("正在删除中");
- } else {
- U.alert(friendgroupinfo.FriendsGroupName + "该分组下有好友,无法删除");
- }
- } else {
- U.alert("自动创建的分组不可删除");
- }
- }
- //#endregion
- /**
- * 删除确定
- * 参数说明 0 要删除的对象ID 1右键的区域
- * @param {element} 右键好友的区域
- */
- U.MD.F.R.deleteFriendForm = function (friendinfo, callback) {
- var _el;
- //创建删除好友的信息样式
- _el = $$("div", { "class": "U_MD_F_G_D" });
- $$("div", { "class": "U_MD_F_G_DelSpan", "innerText": "删除后对方将从好友列表中消失,无法进行发送以及接收消息。" }, _el);
- //弹出删除好友的框
- U.UF.UI.confirm(_el, function () {
- U.MD.F.M.deleteFriend(friendinfo);
- U.UF.C.isFunction(callback) && callback();
- });
- }
- /**
- * 右上角设置
- * 参数说明 friendinfo对应的好友信息集合
- * @param object 好友信息
- *
- */
- U.MD.F.R.popupRightCornerMenu = function (friendinfo, el) {
- var _tempel,
- _friendclassinfo,
- _isaddfriend,
- _menuel = $(el).Child()[0];
- //如果菜单存在则删除
- if (_menuel) {
- $(_menuel).remove();
- }
- else {
- //好友查看
- if (friendinfo.UserId) {
- _isaddfriend = U.Json.selectOne(US.friend.friends, { "UserId": friendinfo.UserId }); //判断用户是否在好友列表里
- //判断用户是否是自己的好友,是的话则操作好友信息
- if (_isaddfriend) {
- //获取好友分组信息
- _friendclassinfo = $($("#g" + _isaddfriend.FriendsGroupID + " div")[1]).find('[tid="' + _isaddfriend["UserId"] + '"]')[0]; //好友分组信息
- //创建菜单
- _tempel = $$("div", { "class": "U_MD_F_T_B", style: {} }, el);
- $$("div",
- {
- "innerText": "修改备注姓名",
- "onclick": function () {
- U.MD.F.R.updateFriendDescriptForm(_isaddfriend);
- }
- },
- _tempel);
- $$("div",
- {
- "innerText": "修改好友分组",
- "onclick": function () {
- U.MD.F.R.topMoveFriendForm(_friendclassinfo, _isaddfriend);
- }
- },
- _tempel);
- $$("div",
- {
- "innerText": "删除好友",
- "onclick": function () {
- U.MD.F.R.deleteFriendForm(_isaddfriend);
- }
- },
- _tempel);
- }
- //如果好友不是自己的好友,则菜单为添加好友
- else {
- $$("div", { "innerText": "添加该好友" }, _tempel);
- }
- }
- //群菜单查看
- else {
- U.MD.F.J.groupInfoForm(friendinfo); //查看群 操作
- }
- }
- }
- /**
- * 修改好友备注
- * 参数说明 UGE对应的好友信息集合
- * @param object
- */
- U.MD.F.R.updateFriendDescriptForm = function (_friendinfo) {
- var _tempel,
- _temponeel,
- _temptwoel,
- _descript;
- _descript = _friendinfo.FriendsDescript || _friendinfo.UserNickName; //修改的好友昵称
- //创建好友分组的样式
- _tempel = $$("div", { "className": "U_MD_U_L_Box_I U_MD_F_Add_TNL U_MD_F_G" });
- _temponeel = $$("div", {}, _tempel)
- _temptwoel = $$("input",
- {
- "value": _descript,
- "onfocus": function () {
- U.UF.MR.inputPlaceholder(this, _descript, "");
- },
- "onblur": function () {
- U.UF.MR.inputPlaceholder(this, "", _descript);
- }
- }, _temponeel);
- //弹出好友对话框
- U.UF.UI.confirm(_tempel, function () {
- U.MD.F.R.updateFriendDescript(_friendinfo, _temptwoel);
- }); //创建一个对话框
- }
- /**
- * 确认修改备注
- * 参数说明 0 对应好友信息集合 1对应的el 用于静态改变当前的备注
- * @param{object}群信息
- * @{element}对应el
- */
- U.MD.F.R.updateFriendDescript = function (friendinfo, el) {
- U.A.Request(US.CD, [US.DB, "UseStudio_Friends", "UpdateFriendDescription", friendinfo['FriendsID'], el.value],
- U.MD.F.R.asynUpdateFriendDescript, [null, friendinfo, el.value]);
- }
- /**
- * 好友备注修改异步
- * @param{object} 异步服务器返回的信息
- */
- U.MD.F.R.asynUpdateFriendDescript = function (r) {
- var _context = r.context,
- _friendinfo = _context[1],
- _descript = _context[2],
- _el = $($("#g" + _friendinfo.FriendsGroupID + " div")[1]).find('[tid="' + _friendinfo["UserId"] + '"]')[0];
- _friendinfo.FriendsDescript = _descript; //在好友信息集合里修改用户描述
- //在好友列表中修改好友
- if (_el) {
- $("div", _el)[2].innerText = _context[2];
- }
- //在聊天窗口修改好友
- $("div", $('.U_MD_F_TO.U_MD_F_TOT')[0])[1].innerText = _context[2];
- var _obj = $('.U_MD_F_TO.U_MD_F_TOT')[0],
- _tags = $(".U_MD_F_TA")[0].children;
- for (var i = 0, len = _tags.length; i < len; i++) {
- // 找到节点,返回下标
- if (_tags[i] == _obj) {
- $("div", $('.U_MD_F_H')[i])[2].innerText = _context[2];
- }
- }
- }
- //#region 群聊
- /**
- * 右键群聊显示
- * @param object 右键元素的信息集合
- */
- U.MD.F.R.GroupRightClickMenu = function (el, friendgroupinfo) {
- var _el = $('#U_MD_F_G_Group')[0], //右键的菜单
- _child = $(_el).Child(); //子菜单
- $(_el).css({ "display": "block", "zIndex": "999" }); //显示右键菜单
- U.UF.C.rightClickMenuLocation(_el); //右键菜单定位
- //修改分组名字的点击处理
- _child[0].onclick = function () { U.MD.F.J.groupInfoForm(friendgroupinfo, el) };
- _child[1].onclick = function () { U.MD.F.J.groupExit(friendgroupinfo, US.userInfo); };
- $(document).bind("click", function () {
- $('#U_MD_F_G_Group')[0].style.display = "none";
- })
- }
|