Main.js 37.8 KB
Newer Older
F
fancy 已提交
1 2 3
MWF.require("MWF.widget.UUID", null, false);
MWF.xDesktop.requireApp("Template", "MForm", null, false);
MWF.xDesktop.requireApp("Template", "MPopupForm", null, false);
NoSubject's avatar
NoSubject 已提交
4 5 6 7 8 9 10 11 12
MWF.xApplication.IMV2.Main = new Class({
	Extends: MWF.xApplication.Common.Main,
	Implements: [Options, Events],

	options: {
		"style": "default",
		"name": "IMV2",
		"mvcStyle": "style.css",
		"icon": "icon.png",
F
fancy 已提交
13 14
		"width": "1024",
		"height": "768",
NoSubject's avatar
NoSubject 已提交
15 16
		"isResize": true,
		"isMax": true,
F
fancy 已提交
17
		"title": MWF.xApplication.IMV2.LP.title,
F
fancy 已提交
18
		"conversationId": ""
NoSubject's avatar
NoSubject 已提交
19 20 21
	},
	onQueryLoad: function () {
		this.lp = MWF.xApplication.IMV2.LP;
F
fancy 已提交
22 23
		this.app = this;
		this.conversationNodeItemList = [];
F
fancy 已提交
24 25
		this.conversationId = this.options.conversationId || "";
		this.messageList = [];
F
fancy 已提交
26 27
		this.emojiList = [];
		//添加87个表情
F
fancy 已提交
28
		for (var i = 1; i < 88; i++) {
F
fancy 已提交
29
			var emoji = {
F
fancy 已提交
30 31
				"key": i > 9 ? "[" + i + "]" : "[0" + i + "]",
				"path": i > 9 ? "/x_component_IMV2/$Main/emotions/im_emotion_" + i + ".png" : "/x_component_IMV2/$Main/emotions/im_emotion_0" + i + ".png",
F
fancy 已提交
32 33 34
			};
			this.emojiList.push(emoji);
		}
F
fancy 已提交
35

F
fancy 已提交
36
	},
F
fancy 已提交
37
	onQueryClose: function () {
F
fancy 已提交
38 39 40 41 42 43 44 45 46 47 48 49
		this.closeListening();
	},
	// 获取组件名称
	loadComponentName: function () {
		o2.Actions.load("x_component_assemble_control").ComponentAction.get("IMV2", function (json) {
			var imComponent = json.data;
			if (imComponent && imComponent.title) {
				this.setTitle(imComponent.title);
			}
		}.bind(this), function (err) {
			console.log(err);
		})
NoSubject's avatar
NoSubject 已提交
50
	},
F
fancy 已提交
51
	// 加载应用
NoSubject's avatar
NoSubject 已提交
52 53 54
	loadApplication: function (callback) {
		var url = this.path + this.options.style + "/im.html";
		this.content.loadHtml(url, { "bind": { "lp": this.lp, "data": {} }, "module": this }, function () {
F
fancy 已提交
55
			//设置content
F
fancy 已提交
56
			this.app.content = this.o2ImMainNode;
F
fancy 已提交
57 58
			//启动监听
			this.startListening();
NoSubject's avatar
NoSubject 已提交
59
			//获取会话列表
F
fancy 已提交
60
			this.conversationNodeItemList = [];
NoSubject's avatar
NoSubject 已提交
61 62 63 64 65 66 67
			o2.Actions.load("x_message_assemble_communicate").ImAction.myConversationList(function (json) {
				if (json.data && json.data instanceof Array) {
					this.loadConversationList(json.data);
				}
			}.bind(this));

		}.bind(this));
F
fancy 已提交
68
		this.loadComponentName();
NoSubject's avatar
NoSubject 已提交
69
	},
F
fancy 已提交
70
	// 监听ws消息
F
fancy 已提交
71
	startListening: function () {
F
fancy 已提交
72 73 74 75 76
		if (layout.desktop && layout.desktop.message) {
			this.messageNumber = layout.desktop.message.items.length;
			//查询ws消息 如果增加
			if (this.listener) {
				clearInterval(this.listener);
F
fancy 已提交
77
			}
F
fancy 已提交
78 79 80 81 82 83 84 85 86
			this.listener = setInterval(function () {
				var newNumber = layout.desktop.message.items.length;
				//判断是否有新的ws消息
				if (newNumber > this.messageNumber) {
					this.reciveNewMessage();
					this.messageNumber = newNumber;
				}
			}.bind(this), 1000);
		}
F
fancy 已提交
87
	},
F
fancy 已提交
88
	// 关闭监听
F
fancy 已提交
89
	closeListening: function () {
F
fancy 已提交
90 91 92 93
		if (this.listener) {
			clearInterval(this.listener);
		}
	},
F
fancy 已提交
94
	// 接收新的消息 会话列表更新 或者 聊天窗口更新
F
fancy 已提交
95
	reciveNewMessage: function () {
F
fancy 已提交
96 97 98 99 100
		//查询会话数据
		this._checkConversationMessage();
		//查询聊天数据
		this._checkNewMessage();
	},
NoSubject's avatar
NoSubject 已提交
101 102 103 104
	//加载会话列表
	loadConversationList: function (list) {
		for (var i = 0; i < list.length; i++) {
			var chat = list[i];
F
fancy 已提交
105 106
			var itemNode = this._createConvItemNode(chat);
			this.conversationNodeItemList.push(itemNode);
F
fancy 已提交
107
			if (this.conversationId && this.conversationId == chat.id) {
F
fancy 已提交
108 109
				this.tapConv(chat);
			}
F
fancy 已提交
110
		}
NoSubject's avatar
NoSubject 已提交
111
	},
F
fancy 已提交
112 113 114 115 116 117
	//分页获取会话的消息列表数据
	loadMsgListByConvId: function (page, size, convId) {
		var data = { "conversationId": convId };
		o2.Actions.load("x_message_assemble_communicate").ImAction.msgListByPaging(page, size, data, function (json) {
			var list = json.data;
			for (var i = 0; i < list.length; i++) {
F
fancy 已提交
118 119
				this.messageList.push(list[i]);
				this._buildMsgNode(list[i], true);
F
fancy 已提交
120 121 122 123 124
			}
		}.bind(this), function (error) {
			console.log(error);
		}.bind(this), false);
	},
F
fancy 已提交
125
	//点击会话
F
fancy 已提交
126
	tapConv: function (conv) {
F
fancy 已提交
127
		this._setCheckNode(conv);
NoSubject's avatar
NoSubject 已提交
128
		var url = this.path + this.options.style + "/chat.html";
NoSubject's avatar
NoSubject 已提交
129
		var data = { "convName": conv.title, "lp": this.lp };
F
fancy 已提交
130 131
		this.conversationId = conv.id;
		this.chatNode.empty();
F
fancy 已提交
132
		this.chatNode.loadHtml(url, { "bind": data, "module": this }, function () {
133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148
			var me = layout.session.user.distinguishedName;
			if (conv.type === "group" && me === conv.adminPerson) {
				this.chatTitleMoreBtnNode.setStyle("display", "block");
				this.chatTitleMoreBtnNode.addEvents({
					"click": function (e) {
						var display = this.chatTitleMoreMenuNode.getStyle("display");
						if (display === "none") {
							this.chatTitleMoreMenuNode.setStyle("display", "block");
						} else {
							this.chatTitleMoreMenuNode.setStyle("display", "none");
						}
					}.bind(this)
				});
			} else {
				this.chatTitleMoreBtnNode.setStyle("display", "none");
			}
F
fancy 已提交
149
			//获取聊天信息
F
fancy 已提交
150
			this.messageList = [];
F
fancy 已提交
151 152 153
			this.loadMsgListByConvId(1, 20, conv.id);
			var scrollFx = new Fx.Scroll(this.chatContentNode);
			scrollFx.toBottom();
NoSubject's avatar
NoSubject 已提交
154 155
		}.bind(this));
	},
156
	//修改群名
F
fancy 已提交
157
	tapUpdateConvTitle: function () {
158
		this.chatTitleMoreMenuNode.setStyle("display", "none");
159 160 161 162 163 164 165 166
		var title = "";
		for (var i = 0; i < this.conversationNodeItemList.length; i++) {
			var c = this.conversationNodeItemList[i];
			if (this.conversationId == c.data.id) {
				title = c.data.title;
			}
		}
		var form = new MWF.xApplication.IMV2.UpdateConvTitleForm(this, {}, {"defaultValue": title}, { app: this.app });
167 168 169
		form.create();
	},
	//修改群成员
F
fancy 已提交
170
	tapUpdateConvMembers: function () {
171 172 173 174 175 176 177 178
		this.chatTitleMoreMenuNode.setStyle("display", "none");
		var members = [];
		for (var i = 0; i < this.conversationNodeItemList.length; i++) {
			var c = this.conversationNodeItemList[i];
			if (this.conversationId == c.data.id) {
				members = c.data.personList;
			}
		}
NoSubject's avatar
NoSubject 已提交
179
		var form = new MWF.xApplication.IMV2.CreateConversationForm(this, {}, { "title": this.lp.modifyMember, "personCount": 0, "personSelected": members, "isUpdateMember": true }, { app: this.app });
180 181
		form.create()
	},
F
fancy 已提交
182 183
	//点击发送消息
	sendMsg: function () {
F
fancy 已提交
184
		var text = this.chatBottomAreaTextareaNode.value;
F
fancy 已提交
185 186
		if (text) {
			this.chatBottomAreaTextareaNode.value = "";
F
fancy 已提交
187
			this._newAndSendTextMsg(text, "text");
F
fancy 已提交
188
		} else {
NoSubject's avatar
NoSubject 已提交
189
			console.log(this.lp.noMessage);
F
fancy 已提交
190 191
		}
	},
F
fancy 已提交
192
	//点击表情按钮
F
fancy 已提交
193 194
	showEmojiBox: function () {
		if (!this.emojiBoxNode) {
F
fancy 已提交
195 196
			this.emojiBoxNode = new Element("div", { "class": "chat-emoji-box" }).inject(this.chatNode);
			var _self = this;
F
fancy 已提交
197
			for (var i = 0; i < this.emojiList.length; i++) {
F
fancy 已提交
198
				var emoji = this.emojiList[i];
F
fancy 已提交
199
				var emojiNode = new Element("img", { "src": emoji.path, "class": "chat-emoji-img" }).inject(this.emojiBoxNode);
F
fancy 已提交
200 201 202 203
				emojiNode.addEvents({
					"mousedown": function (ev) {
						_self.sendEmojiMsg(this.emoji);
						_self.hideEmojiBox();
F
fancy 已提交
204
					}.bind({ emoji: emoji })
F
fancy 已提交
205 206 207 208 209 210 211
				});
			}
		}
		this.emojiBoxNode.setStyle("display", "block");
		this.hideFun = this.hideEmojiBox.bind(this);
		document.body.addEvent("mousedown", this.hideFun);
	},
F
fancy 已提交
212
	// 点击发送文件消息
F
fancy 已提交
213 214
	showChooseFile: function () {
		if (!this.uploadFileAreaNode) {
F
fancy 已提交
215 216 217 218 219
			this.createUploadFileNode();
		}
		this.fileUploadNode.click();
	},
	//创建文件选择框
F
fancy 已提交
220
	createUploadFileNode: function () {
F
fancy 已提交
221 222 223 224
		this.uploadFileAreaNode = new Element("div");
		var html = "<input name=\"file\" type=\"file\" multiple/>";
		this.uploadFileAreaNode.set("html", html);
		this.fileUploadNode = this.uploadFileAreaNode.getFirst();
F
fancy 已提交
225 226 227 228 229 230 231 232 233 234 235 236 237 238 239
		this.fileUploadNode.addEvent("change", function () {
			var files = this.fileUploadNode.files;
			if (files.length) {
				var file = files.item(0);
				var formData = new FormData();
				formData.append('file', file);
				formData.append('fileName', file.name);
				var fileExt = file.name.substring(file.name.lastIndexOf("."));
				// 图片消息
				var type = "file"
				if (fileExt.toLowerCase() == ".bmp" || fileExt.toLowerCase() == ".jpeg"
					|| fileExt.toLowerCase() == ".png" || fileExt.toLowerCase() == ".jpg") {
					type = "image"
				} else { // 文件消息
					type = "file"
F
fancy 已提交
240
				}
F
fancy 已提交
241 242 243 244 245 246 247 248 249 250 251 252
				//上传文件
				o2.Actions.load("x_message_assemble_communicate").ImAction.uploadFile(this.conversationId, type, formData, "{}", function (json) {
					if (json.data) {
						var fileId = json.data.id
						var fileExtension = json.data.fileExtension
						var fileName = json.data.fileName
						this._newImageOrFileMsgAndSend(type, fileId, fileName, fileExtension)
					}
				}.bind(this), function (error) {
					console.log(error);
				}.bind(this))
			}
F
fancy 已提交
253 254
		}.bind(this));
	},
F
fancy 已提交
255
	hideEmojiBox: function () {
F
fancy 已提交
256 257 258 259 260
		//关闭emojiBoxNode
		this.emojiBoxNode.setStyle("display", "none");
		document.body.removeEvent("mousedown", this.hideFun);
	},
	//发送表情消息
F
fancy 已提交
261
	sendEmojiMsg: function (emoji) {
F
fancy 已提交
262 263
		this._newAndSendTextMsg(emoji.key, "emoji");
	},
F
fancy 已提交
264
	//点击创建单聊按钮
F
fancy 已提交
265
	tapCreateSingleConv: function () {
266 267
		// var form = new MWF.xApplication.IMV2.SingleForm(this, {}, {}, { app: this.app });
		// form.create()
NoSubject's avatar
NoSubject 已提交
268
		var form = new MWF.xApplication.IMV2.CreateConversationForm(this, {}, { "title": this.lp.createSingle, "personCount": 1 }, { app: this.app });
269 270 271 272
		form.create()
	},
	//点击创建群聊按钮
	tapCreateGroupConv: function () {
NoSubject's avatar
NoSubject 已提交
273
		var form = new MWF.xApplication.IMV2.CreateConversationForm(this, {}, { "title": this.lp.createDroup, "personCount": 0, "personSelected": [] }, { app: this.app });
F
fancy 已提交
274
		form.create()
F
fancy 已提交
275
	},
276
	//更新群名
F
fancy 已提交
277
	updateConversationTitle: function (title, convId) {
278 279 280 281 282 283 284 285
		var conv = {
			id: convId,
			title: title,
		};
		var _self = this;
		o2.Actions.load("x_message_assemble_communicate").ImAction.update(conv, function (json) {
			var newConv = json.data;
			//点击会话 刷新聊天界面
286 287 288 289 290 291 292 293 294 295 296
			// _self.tapConv(newConv);
			// //刷新会话列表的title
			// for (var i = 0; i < this.conversationNodeItemList.length; i++) {
			// 	var cv = this.conversationNodeItemList[i];
			// 	if (cv.data.id == convId) {
			// 		//刷新
			// 		cv.refreshConvTitle(title);
			// 	}
			// }
			// 列表上的数据也要刷新
			_self.reciveNewMessage();
297 298 299 300 301 302

		}.bind(this), function (error) {
			console.log(error);
		}.bind(this))
	},
	//更新群成员
F
fancy 已提交
303
	updateConversationMembers: function (members, convId) {
304 305 306 307 308 309 310
		var conv = {
			id: convId,
			personList: members,
		};
		var _self = this;
		o2.Actions.load("x_message_assemble_communicate").ImAction.update(conv, function (json) {
			var newConv = json.data;
311 312 313
			//_self.tapConv(newConv);
			// 列表上的数据也要刷新
			_self.reciveNewMessage();
314 315 316 317
		}.bind(this), function (error) {
			console.log(error);
		}.bind(this))
	},
F
fancy 已提交
318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333
	/**
	 * 	创建会话
	 * @param {*} persons 人员列表
	 * @param {*} cType 会话类型 "single" "group"
	 */
	newConversation: function (persons, cType) {
		var conv = {
			type: cType,
			personList: persons,
		};
		var _self = this;
		o2.Actions.load("x_message_assemble_communicate").ImAction.create(conv, function (json) {
			var newConv = json.data;
			var isOld = false;
			for (var i = 0; i < _self.conversationNodeItemList.length; i++) {
				var c = _self.conversationNodeItemList[i];
F
fancy 已提交
334
				if (newConv.id == c.data.id) {
F
fancy 已提交
335 336 337 338
					isOld = true;
					_self.tapConv(c);
				}
			}
F
fancy 已提交
339
			if (!isOld) {
F
fancy 已提交
340 341 342 343 344 345 346 347
				var itemNode = _self._createConvItemNode(newConv);
				_self.conversationNodeItemList.push(itemNode);
				_self.tapConv(newConv);
			}
		}.bind(this), function (error) {
			console.log(error);
		}.bind(this))
	},
F
fancy 已提交
348
	//创建会话ItemNode
F
fancy 已提交
349 350 351
	_createConvItemNode: function (conv) {
		return new MWF.xApplication.IMV2.ConversationItem(conv, this);
	},
F
fancy 已提交
352
	//会话ItemNode 点击背景色
F
fancy 已提交
353 354 355 356 357 358 359 360 361 362
	_setCheckNode: function (conv) {
		for (var i = 0; i < this.conversationNodeItemList.length; i++) {
			var item = this.conversationNodeItemList[i];
			if (item.data.id == conv.id) {
				item.addCheckClass();
			} else {
				item.removeCheckClass();
			}
		}
	},
F
fancy 已提交
363
	//创建图片或文件消息
F
fancy 已提交
364
	_newImageOrFileMsgAndSend: function (type, fileId, fileName, fileExt) {
F
fancy 已提交
365 366 367
		var distinguishedName = layout.session.user.distinguishedName;
		var time = this._currentTime();
		var body = {
NoSubject's avatar
NoSubject 已提交
368
			"body": this.lp.file,
F
fancy 已提交
369 370 371
			"type": type,
			"fileId": fileId,
			"fileExtension": fileExt,
F
fancy 已提交
372 373 374 375 376 377 378 379 380 381 382 383 384 385
			"fileName": fileName
		};
		var bodyJson = JSON.stringify(body);
		var uuid = (new MWF.widget.UUID).toString();
		var message = {
			"id": uuid,
			"conversationId": this.conversationId,
			"body": bodyJson,
			"createPerson": distinguishedName,
			"createTime": time,
			"sendStatus": 1
		};
		o2.Actions.load("x_message_assemble_communicate").ImAction.msgCreate(message,
			function (json) {
NoSubject's avatar
NoSubject 已提交
386
				console.log(this.lp.sendSuccess);
F
fancy 已提交
387 388 389 390 391 392 393 394
			}.bind(this),
			function (error) {
				console.log(error);
			}.bind(this));
		this.messageList.push(message);
		this._buildSender(body, distinguishedName, false);
		this._refreshConvMessage(message);
	},
F
fancy 已提交
395
	//创建文本消息 并发送
F
fancy 已提交
396
	_newAndSendTextMsg: function (text, type) {
F
fancy 已提交
397 398
		var distinguishedName = layout.session.user.distinguishedName;
		var time = this._currentTime();
F
fancy 已提交
399
		var body = { "body": text, "type": type };
F
fancy 已提交
400 401 402 403 404 405 406 407 408 409 410 411 412
		var bodyJson = JSON.stringify(body);
		var uuid = (new MWF.widget.UUID).toString();
		var textMessage = {
			"id": uuid,
			"conversationId": this.conversationId,
			"body": bodyJson,
			"createPerson": distinguishedName,
			"createTime": time,
			"sendStatus": 1
		};
		o2.Actions.load("x_message_assemble_communicate").ImAction.msgCreate(textMessage,
			function (json) {
				//data = json.data;
NoSubject's avatar
NoSubject 已提交
413
				console.log(this.lp.sendSuccess);
F
fancy 已提交
414 415 416 417
			}.bind(this),
			function (error) {
				console.log(error);
			}.bind(this));
F
fancy 已提交
418
		this.messageList.push(textMessage);
F
fancy 已提交
419
		this._buildSender(body, distinguishedName, false);
F
fancy 已提交
420 421 422
		this._refreshConvMessage(textMessage);
	},
	//刷新会话Item里面的最后消息内容
F
fancy 已提交
423
	_refreshConvMessage: function (msg) {
F
fancy 已提交
424 425 426
		for (var i = 0; i < this.conversationNodeItemList.length; i++) {
			var node = this.conversationNodeItemList[i];
			if (node.data.id == this.conversationId) {
F
fancy 已提交
427
				node.refreshLastMsg(msg);
F
fancy 已提交
428 429 430
			}
		}
	},
F
fancy 已提交
431
	//检查会话列表是否有更新
F
fancy 已提交
432
	_checkConversationMessage: function () {
F
fancy 已提交
433 434 435 436 437 438 439 440 441 442 443 444
		o2.Actions.load("x_message_assemble_communicate").ImAction.myConversationList(function (json) {
			if (json.data && json.data instanceof Array) {
				var newConList = json.data;
				for (var j = 0; j < newConList.length; j++) {
					var nCv = newConList[j];
					var isNew = true;
					for (var i = 0; i < this.conversationNodeItemList.length; i++) {
						var cv = this.conversationNodeItemList[i];
						if (cv.data.id == nCv.id) {
							isNew = false;
							//刷新
							cv.refreshLastMsg(nCv.lastMessage);
445 446 447 448
							cv.refreshData(nCv);
							if (this.conversationId === nCv.id) {
								this.tapConv(nCv);
							}
F
fancy 已提交
449 450 451
						}
					}
					//新会话 创建
F
fancy 已提交
452
					if (isNew) {
F
fancy 已提交
453 454 455 456 457 458 459 460 461
						var itemNode = this._createConvItemNode(nCv);
						this.conversationNodeItemList.push(itemNode);
					}
				}
				//this.loadConversationList(json.data);
			}
		}.bind(this));
	},
	//检查是否有新消息
F
fancy 已提交
462
	_checkNewMessage: function () {
F
fancy 已提交
463 464 465 466
		if (this.conversationId && this.conversationId != "") {//是否有会话窗口
			var data = { "conversationId": this.conversationId };
			o2.Actions.load("x_message_assemble_communicate").ImAction.msgListByPaging(1, 10, data, function (json) {
				var list = json.data;
F
fancy 已提交
467
				if (list && list.length > 0) {
F
fancy 已提交
468 469 470 471 472 473 474
					var msg = list[0];
					//检查聊天框是否有变化
					if (this.conversationId == msg.conversationId) {
						for (var i = 0; i < list.length; i++) {
							var isnew = true;
							var m = list[i];
							for (var j = 0; j < this.messageList.length; j++) {
F
fancy 已提交
475
								if (this.messageList[j].id == m.id) {
F
fancy 已提交
476 477 478
									isnew = false;
								}
							}
F
fancy 已提交
479
							if (isnew) {
F
fancy 已提交
480 481 482 483 484 485 486
								this.messageList.push(m);
								this._buildMsgNode(m, false);
								// this._refreshConvMessage(m);
							}
						}
					}
				}
F
fancy 已提交
487

F
fancy 已提交
488 489 490 491 492
			}.bind(this), function (error) {
				console.log(error);
			}.bind(this), false);
		}
	},
F
fancy 已提交
493
	//创建消息html节点
F
fancy 已提交
494
	_buildMsgNode: function (msg, isTop) {
F
fancy 已提交
495 496 497 498 499
		var createPerson = msg.createPerson;
		var jsonbody = msg.body;
		var body = JSON.parse(jsonbody);//todo 目前只有一种text类型
		var distinguishedName = layout.session.user.distinguishedName;
		if (createPerson != distinguishedName) {
F
fancy 已提交
500
			this._buildReceiver(body, createPerson, isTop);
F
fancy 已提交
501
		} else {
F
fancy 已提交
502
			this._buildSender(body, createPerson, isTop);
F
fancy 已提交
503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523
		}
	},
	/**
	 * 消息发送体
	 * @param  msgBody 消息体
	 * @param createPerson 消息人员
	 * @param isTop 是否放在顶部
	 */
	_buildSender: function (msgBody, createPerson, isTop) {
		var receiverBodyNode = new Element("div", { "class": "chat-sender" }).inject(this.chatContentNode, isTop ? "top" : "bottom");
		var avatarNode = new Element("div").inject(receiverBodyNode);
		var avatarUrl = this._getIcon(createPerson);
		var name = createPerson;
		if (createPerson.indexOf("@") != -1) {
			name = name.substring(0, createPerson.indexOf("@"));
		}
		var avatarImg = new Element("img", { "src": avatarUrl }).inject(avatarNode);
		var nameNode = new Element("div", { "text": name }).inject(receiverBodyNode);
		var lastNode = new Element("div").inject(receiverBodyNode);
		var lastFirstNode = new Element("div", { "class": "chat-left_triangle" }).inject(lastNode);
		//text
F
fancy 已提交
524 525
		if (msgBody.type == "emoji") { // 表情
			var img = "";
F
fancy 已提交
526 527
			for (var i = 0; i < this.emojiList.length; i++) {
				if (msgBody.body == this.emojiList[i].key) {
F
fancy 已提交
528
					img = this.emojiList[i].path;
F
fancy 已提交
529
				}
F
fancy 已提交
530
			}
F
fancy 已提交
531 532 533 534 535 536
			new Element("img", { "src": img, "class": "chat-content-emoji" }).inject(lastNode);
		} else if (msgBody.type == "image") {//image
			var imgBox = new Element("div", { "class": "img-chat" }).inject(lastNode);
			var url = this._getFileUrlWithWH(msgBody.fileId, 144, 192);
			new Element("img", { "src": url }).inject(imgBox);
			imgBox.addEvents({
537
				"click": function (e) {
F
fancy 已提交
538 539 540 541 542 543
					var downloadUrl = this._getFileDownloadUrl(msgBody.fileId);
					window.open(downloadUrl);
				}.bind(this)
			});
		} else if (msgBody.type == "audio") {
			var url = this._getFileDownloadUrl(msgBody.fileId);
544
			new Element("audio", { "src": url, "controls": "controls", "preload": "preload" }).inject(lastNode);
F
fancy 已提交
545 546
		} else if (msgBody.type == "location") {
			var mapBox = new Element("span").inject(lastNode);
547
			new Element("img", { "src": "../x_component_IMV2/$Main/default/icons/location.png", "width": 24, "height": 24 }).inject(mapBox);
F
fancy 已提交
548
			var url = this._getBaiduMapUrl(msgBody.latitude, msgBody.longitude, msgBody.address, msgBody.addressDetail);
549
			new Element("a", { "href": url, "target": "_blank", "text": msgBody.address }).inject(mapBox);
F
fancy 已提交
550 551 552
		} else if (msgBody.type == "file") { //文件
			var mapBox = new Element("span").inject(lastNode);
			var fileIcon = this._getFileIcon(msgBody.fileExtension);
F
fancy 已提交
553
			new Element("img", { "src": "../x_component_IMV2/$Main/file_icons/" + fileIcon, "width": 48, "height": 48 }).inject(mapBox);
F
fancy 已提交
554 555
			var downloadUrl = this._getFileDownloadUrl(msgBody.fileId);
			new Element("a", { "href": downloadUrl, "target": "_blank", "text": msgBody.fileName }).inject(mapBox);
F
fancy 已提交
556
		} else {//text
F
fancy 已提交
557 558 559
			new Element("span", { "text": msgBody.body }).inject(lastNode);
		}

F
fancy 已提交
560
		if (!isTop) {
F
fancy 已提交
561 562 563
			var scrollFx = new Fx.Scroll(this.chatContentNode);
			scrollFx.toBottom();
		}
F
fancy 已提交
564 565 566 567 568 569 570 571 572 573 574 575 576 577 578 579 580 581 582
	},
	/**
	 * 消息接收体
	 * @param  msgBody 
	 * @param createPerson 消息人员
	 * @param isTop 是否放在顶部
	 */
	_buildReceiver: function (msgBody, createPerson, isTop) {
		var receiverBodyNode = new Element("div", { "class": "chat-receiver" }).inject(this.chatContentNode, isTop ? "top" : "bottom");
		var avatarNode = new Element("div").inject(receiverBodyNode);
		var avatarUrl = this._getIcon(createPerson);
		var name = createPerson;
		if (createPerson.indexOf("@") != -1) {
			name = name.substring(0, createPerson.indexOf("@"));
		}
		var avatarImg = new Element("img", { "src": avatarUrl }).inject(avatarNode);
		var nameNode = new Element("div", { "text": name }).inject(receiverBodyNode);
		var lastNode = new Element("div").inject(receiverBodyNode);
		var lastFirstNode = new Element("div", { "class": "chat-right_triangle" }).inject(lastNode);
F
fancy 已提交
583

F
fancy 已提交
584 585
		if (msgBody.type == "emoji") { // 表情
			var img = "";
F
fancy 已提交
586 587
			for (var i = 0; i < this.emojiList.length; i++) {
				if (msgBody.body == this.emojiList[i].key) {
F
fancy 已提交
588
					img = this.emojiList[i].path;
F
fancy 已提交
589
				}
F
fancy 已提交
590
			}
F
fancy 已提交
591 592 593 594 595 596
			new Element("img", { "src": img, "class": "chat-content-emoji" }).inject(lastNode);
		} else if (msgBody.type == "image") {//image
			var imgBox = new Element("div", { "class": "img-chat" }).inject(lastNode);
			var url = this._getFileUrlWithWH(msgBody.fileId, 144, 192);
			new Element("img", { "src": url }).inject(imgBox);
			imgBox.addEvents({
597
				"click": function (e) {
F
fancy 已提交
598 599 600 601 602 603
					var downloadUrl = this._getFileDownloadUrl(msgBody.fileId);
					window.open(downloadUrl);
				}.bind(this)
			});
		} else if (msgBody.type == "audio") {
			var url = this._getFileDownloadUrl(msgBody.fileId);
604
			new Element("audio", { "src": url, "controls": "controls", "preload": "preload" }).inject(lastNode);
F
fancy 已提交
605 606
		} else if (msgBody.type == "location") {
			var mapBox = new Element("span").inject(lastNode);
607
			new Element("img", { "src": "../x_component_IMV2/$Main/default/icons/location.png", "width": 24, "height": 24 }).inject(mapBox);
F
fancy 已提交
608
			var url = this._getBaiduMapUrl(msgBody.latitude, msgBody.longitude, msgBody.address, msgBody.addressDetail);
609
			new Element("a", { "href": url, "target": "_blank", "text": msgBody.address }).inject(mapBox);
F
fancy 已提交
610 611 612
		} else if (msgBody.type == "file") { //文件
			var mapBox = new Element("span").inject(lastNode);
			var fileIcon = this._getFileIcon(msgBody.fileExtension);
F
fancy 已提交
613
			new Element("img", { "src": "../x_component_IMV2/$Main/file_icons/" + fileIcon, "width": 48, "height": 48 }).inject(mapBox);
F
fancy 已提交
614 615
			var downloadUrl = this._getFileDownloadUrl(msgBody.fileId);
			new Element("a", { "href": downloadUrl, "target": "_blank", "text": msgBody.fileName }).inject(mapBox);
F
fancy 已提交
616
		} else {//text
F
fancy 已提交
617 618
			new Element("span", { "text": msgBody.body }).inject(lastNode);
		}
F
fancy 已提交
619 620

		if (!isTop) {
F
fancy 已提交
621 622 623
			var scrollFx = new Fx.Scroll(this.chatContentNode);
			scrollFx.toBottom();
		}
F
fancy 已提交
624
	},
F
fancy 已提交
625
	//图片 根据大小 url
626
	_getFileUrlWithWH: function (id, width, height) {
F
fancy 已提交
627
		var action = MWF.Actions.get("x_message_assemble_communicate").action;
F
fancy 已提交
628
		var url = action.getAddress() + action.actions.imgFileDownloadWithWH.uri;
F
fancy 已提交
629 630 631 632 633 634
		url = url.replace("{id}", encodeURIComponent(id));
		url = url.replace("{width}", encodeURIComponent(width));
		url = url.replace("{height}", encodeURIComponent(height));
		return url;
	},
	//file 下载的url
635
	_getFileDownloadUrl: function (id) {
F
fancy 已提交
636
		var action = MWF.Actions.get("x_message_assemble_communicate").action;
F
fancy 已提交
637
		var url = action.getAddress() + action.actions.imgFileDownload.uri;
F
fancy 已提交
638 639 640 641
		url = url.replace("{id}", encodeURIComponent(id));
		return url;
	},
	//百度地图打开地址
642 643
	_getBaiduMapUrl: function (lat, longt, address, content) {
		var url = "https://api.map.baidu.com/marker?location=" + lat + "," + longt + "&title=" + address + "&content=" + content + "&output=html&src=net.o2oa.map";
F
fancy 已提交
644 645
		return url;
	},
F
fancy 已提交
646
	//用户头像
NoSubject's avatar
NoSubject 已提交
647 648
	_getIcon: function (id) {
		var orgAction = MWF.Actions.get("x_organization_assemble_control")
649
		var url = (id) ? orgAction.getPersonIcon(id) : "../x_component_IMV2/$Main/default/icons/group.png";
NoSubject's avatar
NoSubject 已提交
650 651
		return url + "?" + (new Date().getTime());
	},
F
fancy 已提交
652 653 654 655 656 657 658 659 660 661 662 663 664 665 666 667 668 669 670 671 672 673 674 675 676 677 678 679 680 681 682 683 684 685 686 687 688 689 690 691 692 693 694 695 696 697 698 699 700 701 702 703 704 705 706 707 708 709 710 711 712 713 714
	// 文件类型icon图
	_getFileIcon: function (ext) {
		if (ext) {
			if (ext === "jpg" || ext === "jpeg") {
				return "icon_file_jpeg.png";
			} else if (ext === "gif") {
				return "icon_file_gif.png";
			} else if (ext === "png") {
				return "icon_file_png.png";
			} else if (ext === "tiff") {
				return "icon_file_tiff.png";
			} else if (ext === "bmp" || ext === "webp") {
				return "icon_file_img.png";
			} else if (ext === "ogg" || ext === "mp3" || ext === "wav" || ext === "wma") {
				return "icon_file_mp3.png";
			} else if (ext === "mp4") {
				return "icon_file_mp4.png";
			} else if (ext === "avi") {
				return "icon_file_avi.png";
			} else if (ext === "mov" || ext === "rm" || ext === "mkv") {
				return "icon_file_rm.png";
			} else if (ext === "doc" || ext === "docx") {
				return "icon_file_word.png";
			} else if (ext === "xls" || ext === "xlsx") {
				return "icon_file_excel.png";
			} else if (ext === "ppt" || ext === "pptx") {
				return "icon_file_ppt.png";
			} else if (ext === "html") {
				return "icon_file_html.png";
			} else if (ext === "pdf") {
				return "icon_file_pdf.png";
			} else if (ext === "txt" || ext === "json") {
				return "icon_file_txt.png";
			} else if (ext === "zip") {
				return "icon_file_zip.png";
			} else if (ext === "rar") {
				return "icon_file_rar.png";
			} else if (ext === "7z") {
				return "icon_file_arch.png";
			} else if (ext === "ai") {
				return "icon_file_ai.png";
			} else if (ext === "att") {
				return "icon_file_att.png";
			} else if (ext === "au") {
				return "icon_file_au.png";
			} else if (ext === "cad") {
				return "icon_file_cad.png";
			} else if (ext === "cdr") {
				return "icon_file_cdr.png";
			} else if (ext === "eps") {
				return "icon_file_eps.png";
			} else if (ext === "exe") {
				return "icon_file_exe.png";
			} else if (ext === "iso") {
				return "icon_file_iso.png";
			} else if (ext === "link") {
				return "icon_file_link.png";
			} else if (ext === "swf") {
				return "icon_file_flash.png";
			} else if (ext === "psd") {
				return "icon_file_psd.png";
			} else if (ext === "tmp") {
				return "icon_file_tmp.png";
F
fancy 已提交
715
			} else {
F
fancy 已提交
716 717
				return "icon_file_unkown.png";
			}
F
fancy 已提交
718
		} else {
F
fancy 已提交
719 720 721
			return "icon_file_unkown.png";
		}
	},
NoSubject's avatar
NoSubject 已提交
722 723 724 725 726 727 728 729 730 731 732 733 734 735 736 737 738 739 740
	//输出特殊的时间格式
	_friendlyTime: function (date) {
		var day = date.getDate();
		var monthIndex = date.getMonth();
		var year = date.getFullYear();
		var time = date.getTime();
		var today = new Date();
		var todayDay = today.getDate();
		var todayMonthIndex = today.getMonth();
		var todayYear = today.getFullYear();
		var todayTime = today.getTime();

		var retTime = "";
		//同一天
		if (day === todayDay && monthIndex === todayMonthIndex && year === todayYear) {
			var hour = 0;
			if (todayTime > time) {
				hour = parseInt((todayTime - time) / 3600000);
				if (hour == 0) {
NoSubject's avatar
NoSubject 已提交
741
					retTime = Math.max(parseInt((todayTime - time) / 60000), 1) + this.lp.minutesBefore
NoSubject's avatar
NoSubject 已提交
742
				} else {
NoSubject's avatar
NoSubject 已提交
743
					retTime = hour + this.lp.hoursBefore
NoSubject's avatar
NoSubject 已提交
744 745 746 747 748 749 750 751 752 753
				}

			}
			return retTime;
		}
		var dates = parseInt(time / 86400000);
		var todaydates = parseInt(todayTime / 86400000);
		if (todaydates > dates) {
			var days = (todaydates - dates);
			if (days == 1) {
NoSubject's avatar
NoSubject 已提交
754
				retTime = this.lp.yesterday;
NoSubject's avatar
NoSubject 已提交
755
			} else if (days == 2) {
NoSubject's avatar
NoSubject 已提交
756
				retTime = this.lp.beforeYesterday;
NoSubject's avatar
NoSubject 已提交
757
			} else if (days > 2 && days < 31) {
NoSubject's avatar
NoSubject 已提交
758
				retTime = days + this.lp.daysBefore;
NoSubject's avatar
NoSubject 已提交
759
			} else if (days >= 31 && days <= 2 * 31) {
NoSubject's avatar
NoSubject 已提交
760
				retTime = this.lp.monthAgo;
NoSubject's avatar
NoSubject 已提交
761
			} else if (days > 2 * 31 && days <= 3 * 31) {
NoSubject's avatar
NoSubject 已提交
762
				retTime = this.lp.towMonthAgo;
NoSubject's avatar
NoSubject 已提交
763
			} else if (days > 3 * 31 && days <= 4 * 31) {
NoSubject's avatar
NoSubject 已提交
764
				retTime = this.lp.threeMonthAgo;
NoSubject's avatar
NoSubject 已提交
765 766 767 768 769 770 771 772 773 774 775 776 777 778 779
			} else {
				retTime = this._formatDate(date);
			}
		}

		return retTime;

	},
	//yyyy-MM-dd
	_formatDate: function (date) {
		var month = date.getMonth() + 1;
		var day = date.getDate();
		month = (month.toString().length == 1) ? ("0" + month) : month;
		day = (day.toString().length == 1) ? ("0" + day) : day;
		return date.getFullYear() + '-' + month + '-' + day;
F
fancy 已提交
780
	},
F
fancy 已提交
781
	//当前时间 yyyy-MM-dd HH:mm:ss
F
fancy 已提交
782 783 784 785 786 787 788 789 790 791 792 793 794 795 796
	_currentTime: function () {
		var today = new Date();
		var year = today.getFullYear(); //得到年份
		var month = today.getMonth();//得到月份
		var date = today.getDate();//得到日期
		var hour = today.getHours();//得到小时
		var minu = today.getMinutes();//得到分钟
		var sec = today.getSeconds();//得到秒
		month = month + 1;
		if (month < 10) month = "0" + month;
		if (date < 10) date = "0" + date;
		if (hour < 10) hour = "0" + hour;
		if (minu < 10) minu = "0" + minu;
		if (sec < 10) sec = "0" + sec;
		return year + "-" + month + "-" + date + " " + hour + ":" + minu + ":" + sec;
NoSubject's avatar
NoSubject 已提交
797 798 799 800
	}


});
F
fancy 已提交
801 802 803 804 805 806 807 808 809 810 811 812 813 814 815 816 817

//会话对象
MWF.xApplication.IMV2.ConversationItem = new Class({
	initialize: function (data, main) {
		this.data = data;
		this.main = main;
		this.container = this.main.chatItemListNode;

		this.load();
	},
	load: function () {
		var avatarDefault = this.main._getIcon();
		var convData = {
			"id": this.data.id,
			"avatarUrl": avatarDefault,
			"title": this.data.title,
			"time": "",
F
fancy 已提交
818 819
			"lastMessage": "",
			"lastMessageType": "text"
F
fancy 已提交
820 821 822 823 824 825 826 827 828 829 830 831 832 833 834 835 836 837 838 839 840 841 842 843 844 845 846
		};
		var distinguishedName = layout.session.user.distinguishedName;
		if (this.data.type && this.data.type === "single") {
			var chatPerson = "";
			if (this.data.personList && this.data.personList instanceof Array) {
				for (var j = 0; j < this.data.personList.length; j++) {
					var person = this.data.personList[j];
					if (person !== distinguishedName) {
						chatPerson = person;
					}
				}
			}
			convData.avatarUrl = this.main._getIcon(chatPerson);
			var name = chatPerson;
			if (chatPerson.indexOf("@") != -1) {
				name = name.substring(0, chatPerson.indexOf("@"));
			}
			convData.title = name;
		}
		if (this.data.lastMessage) {
			//todo 其它消息类型
			var mBody = JSON.parse(this.data.lastMessage.body);
			convData.lastMessage = mBody.body;
			if (this.data.lastMessage.createTime) {
				var time = this.main._friendlyTime(o2.common.toDate(this.data.lastMessage.createTime));
				convData.time = time;
			}
F
fancy 已提交
847 848 849
			if (mBody.type) {
				convData.lastMessageType = mBody.type;
			}
F
fancy 已提交
850 851 852 853 854 855 856
		}
		this.node = new Element("div", { "class": "item" }).inject(this.container);
		this.nodeBaseItem = new Element("div", { "class": "base" }).inject(this.node);
		var avatarNode = new Element("div", { "class": "avatar" }).inject(this.nodeBaseItem);
		new Element("img", { "src": convData.avatarUrl, "class": "img" }).inject(avatarNode);
		var bodyNode = new Element("div", { "class": "body" }).inject(this.nodeBaseItem);
		var bodyUpNode = new Element("div", { "class": "body_up" }).inject(bodyNode);
857
		this.titleNode = new Element("div", { "class": "body_title", "text": convData.title }).inject(bodyUpNode);
F
fancy 已提交
858
		this.messageTimeNode = new Element("div", { "class": "body_time", "text": convData.time }).inject(bodyUpNode);
F
fancy 已提交
859
		if (convData.lastMessageType == "emoji") {
F
fancy 已提交
860
			this.lastMessageNode = new Element("div", { "class": "body_down" }).inject(bodyNode);
F
fancy 已提交
861
			var imgPath = "";
F
fancy 已提交
862
			for (var i = 0; i < this.main.emojiList.length; i++) {
F
fancy 已提交
863 864 865 866 867
				var emoji = this.main.emojiList[i];
				if (emoji.key == convData.lastMessage) {
					imgPath = emoji.path;
				}
			}
F
fancy 已提交
868 869
			new Element("img", { "src": imgPath, "style": "width: 16px;height: 16px;" }).inject(this.lastMessageNode);
		} else {
F
fancy 已提交
870 871
			this.lastMessageNode = new Element("div", { "class": "body_down", "text": convData.lastMessage }).inject(bodyNode);
		}
F
fancy 已提交
872

F
fancy 已提交
873 874 875 876 877 878 879 880
		var _self = this;
		this.node.addEvents({
			"click": function () {
				_self.main.tapConv(_self.data);
			}
		});
	},
	/**
F
fancy 已提交
881
	 *
F
fancy 已提交
882 883 884
	 * 刷新会话列表的最后消息内容 
	 * @param {*} lastMessage 
	 */
F
fancy 已提交
885
	refreshLastMsg: function (lastMessage) {
F
fancy 已提交
886 887 888 889
		if (lastMessage) {
			//目前是text 类型的消息
			var jsonbody = lastMessage.body;
			var body = JSON.parse(jsonbody);
F
fancy 已提交
890

F
fancy 已提交
891 892 893 894 895 896 897 898
			if (this.lastMessageNode) {
				if (body.type == "emoji") { //表情 消息
					var imgPath = "";
					for (var i = 0; i < this.main.emojiList.length; i++) {
						var emoji = this.main.emojiList[i];
						if (emoji.key == body.body) {
							imgPath = emoji.path;
						}
F
fancy 已提交
899
					}
F
fancy 已提交
900 901 902 903 904
					this.lastMessageNode.empty();
					new Element("img", { "src": imgPath, "style": "width: 16px;height: 16px;" }).inject(this.lastMessageNode);
				} else { //文本消息
					this.lastMessageNode.empty();
					this.lastMessageNode.set('text', body.body);
F
fancy 已提交
905 906
				}
			}
F
fancy 已提交
907 908 909 910
			var time = this.main._friendlyTime(o2.common.toDate(lastMessage.createTime));
			if (this.messageTimeNode) {
				this.messageTimeNode.set("text", time);
			}
F
fancy 已提交
911 912
		}
	},
913
	// 更新聊天窗口上的标题 修改标题的时候使用 @Disuse 使用refreshData
F
fancy 已提交
914
	refreshConvTitle: function (title) {
915 916
		this.titleNode.set("text", title);
	},
917 918 919 920 921 922
	// 更新会话数据
	refreshData: function (data) {
		this.data = data;
		// 更新聊天窗口上的标题 修改标题的时候使用
		this.titleNode.set("text", data.title);
	},
F
fancy 已提交
923 924 925 926 927 928 929 930 931 932 933 934 935 936 937 938 939 940 941 942 943 944 945 946 947 948 949 950 951
	addCheckClass: function () {
		if (this.nodeBaseItem) {
			if (!this.nodeBaseItem.hasClass("check")) {
				this.nodeBaseItem.addClass("check");
			}
		}
	},
	removeCheckClass: function () {
		if (this.nodeBaseItem) {
			if (this.nodeBaseItem.hasClass("check")) {
				this.nodeBaseItem.removeClass("check");
			}
		}
	}

});

//弹出窗 表单 单聊创建的form
MWF.xApplication.IMV2.SingleForm = new Class({
	Extends: MPopupForm,
	Implements: [Options, Events],
	options: {
		"style": "minder",
		"width": 700,
		//"height": 300,
		"height": "200",
		"hasTop": true,
		"hasIcon": false,
		"draggable": true,
NoSubject's avatar
NoSubject 已提交
952
		"title": MWF.xApplication.IMV2.LP.createSingle
F
fancy 已提交
953 954 955 956 957 958 959 960 961 962 963 964 965 966 967 968 969
	},
	_createTableContent: function () {
		var html = "<table width='100%' bordr='0' cellpadding='7' cellspacing='0' styles='formTable' style='margin-top: 20px; '>" +
			"<tr><td styles='formTableTitle' lable='person' width='25%'></td>" +
			"    <td styles='formTableValue14' item='person' colspan='3'></td></tr>" +
			"</table>";
		this.formTableArea.set("html", html);
		var me = layout.session.user.distinguishedName;
		var exclude = [];
		if (me) {
			exclude = [me];
		}
		this.form = new MForm(this.formTableArea, this.data || {}, {
			isEdited: true,
			style: "minder",
			hasColon: true,
			itemTemplate: {
NoSubject's avatar
NoSubject 已提交
970
				person: { text: MWF.xApplication.IMV2.LP.selectPerson, type: "org", orgType: "person", count: 0, notEmpty: true, exclude: exclude },
F
fancy 已提交
971 972 973 974 975 976 977 978 979
			}
		}, this.app);
		this.form.load();

	},
	_createBottomContent: function () {
		if (this.isNew || this.isEdited) {
			this.okActionNode = new Element("button.inputOkButton", {
				"styles": this.css.inputOkButton,
NoSubject's avatar
NoSubject 已提交
980
				"text": MWF.xApplication.IMV2.LP.ok
F
fancy 已提交
981 982 983 984 985 986 987
			}).inject(this.formBottomNode);
			this.okActionNode.addEvent("click", function (e) {
				this.save(e);
			}.bind(this));
		}
		this.cancelActionNode = new Element("button.inputCancelButton", {
			"styles": (this.isEdited || this.isNew || this.getEditPermission()) ? this.css.inputCancelButton : this.css.inputCancelButton_long,
NoSubject's avatar
NoSubject 已提交
988
			"text": MWF.xApplication.IMV2.LP.close
F
fancy 已提交
989 990 991 992 993 994 995 996 997 998 999 1000 1001
		}).inject(this.formBottomNode);
		this.cancelActionNode.addEvent("click", function (e) {
			this.close(e);
		}.bind(this));

	},
	save: function () {
		var data = this.form.getResult(true, null, true, false, true);
		if (data) {
			this.app.newConversation(data.person, "single");
			this.close();
		}
	}
1002 1003 1004 1005 1006 1007 1008 1009 1010 1011 1012 1013 1014 1015
});


//创建聊天 弹出窗表单
MWF.xApplication.IMV2.CreateConversationForm = new Class({
	Extends: MPopupForm,
	Implements: [Options, Events],
	options: {
		"style": "minder",
		"width": 700,
		"height": "200",
		"hasTop": true,
		"hasIcon": false,
		"draggable": true,
NoSubject's avatar
NoSubject 已提交
1016
		"title": MWF.xApplication.IMV2.LP.createSingle,
1017 1018 1019 1020 1021 1022 1023 1024 1025 1026 1027 1028 1029 1030 1031 1032 1033 1034 1035 1036
		"personCount": 1, //1 是单选  0 是多选,
		"personSelected": [],
		"isUpdateMember": false
	},
	_createTableContent: function () {
		var html = "<table width='100%' bordr='0' cellpadding='7' cellspacing='0' styles='formTable' style='margin-top: 20px; '>" +
			"<tr><td styles='formTableTitle' lable='person' width='25%'></td>" +
			"    <td styles='formTableValue14' item='person' colspan='3'></td></tr>" +
			"</table>";
		this.formTableArea.set("html", html);
		var me = layout.session.user.distinguishedName;
		var exclude = [];
		if (me) {
			exclude = [me];
		}
		this.form = new MForm(this.formTableArea, this.data || {}, {
			isEdited: true,
			style: "minder",
			hasColon: true,
			itemTemplate: {
NoSubject's avatar
NoSubject 已提交
1037
				person: { text: MWF.xApplication.IMV2.LP.selectPerson, type: "org", orgType: "person", count: this.options["personCount"], notEmpty: true, exclude: exclude, value: this.options["personSelected"] },
1038 1039 1040 1041 1042 1043 1044 1045 1046
			}
		}, this.app);
		this.form.load();

	},
	_createBottomContent: function () {
		if (this.isNew || this.isEdited) {
			this.okActionNode = new Element("button.inputOkButton", {
				"styles": this.css.inputOkButton,
NoSubject's avatar
NoSubject 已提交
1047
				"text": MWF.xApplication.IMV2.LP.ok
1048 1049 1050 1051 1052 1053 1054
			}).inject(this.formBottomNode);
			this.okActionNode.addEvent("click", function (e) {
				this.save(e);
			}.bind(this));
		}
		this.cancelActionNode = new Element("button.inputCancelButton", {
			"styles": (this.isEdited || this.isNew || this.getEditPermission()) ? this.css.inputCancelButton : this.css.inputCancelButton_long,
NoSubject's avatar
NoSubject 已提交
1055
			"text": MWF.xApplication.IMV2.LP.close
1056 1057 1058 1059 1060 1061 1062 1063 1064 1065 1066
		}).inject(this.formBottomNode);
		this.cancelActionNode.addEvent("click", function (e) {
			this.close(e);
		}.bind(this));

	},
	save: function () {
		var data = this.form.getResult(true, null, true, false, true);
		if (data) {
			if (this.options["isUpdateMember"] === true) {
				this.app.updateConversationMembers(data.person, this.app.conversationId);
F
fancy 已提交
1067 1068
			} else {
				this.app.newConversation(data.person, this.options["personCount"] === 1 ? "single" : "group");
1069
			}
F
fancy 已提交
1070

1071 1072 1073 1074 1075 1076 1077 1078 1079 1080 1081 1082 1083 1084 1085 1086 1087 1088
			this.close();
		}
	}
});



//修改群名
MWF.xApplication.IMV2.UpdateConvTitleForm = new Class({
	Extends: MPopupForm,
	Implements: [Options, Events],
	options: {
		"style": "minder",
		"width": 500,
		"height": "200",
		"hasTop": true,
		"hasIcon": false,
		"draggable": true,
1089
		"defaultValue": "", // 默认值
NoSubject's avatar
NoSubject 已提交
1090
		"title": MWF.xApplication.IMV2.LP.modifyGroupName
1091 1092 1093 1094 1095 1096 1097
	},
	_createTableContent: function () {
		var html = "<table width='100%' bordr='0' cellpadding='7' cellspacing='0' styles='formTable' style='margin-top: 20px; '>" +
			"<tr><td styles='formTableTitle' lable='title' width='25%'></td>" +
			"    <td styles='formTableValue14' item='title' colspan='3'></td></tr>" +
			"</table>";
		this.formTableArea.set("html", html);
F
fancy 已提交
1098

1099 1100 1101 1102 1103
		this.form = new MForm(this.formTableArea, this.data || {}, {
			isEdited: true,
			style: "minder",
			hasColon: true,
			itemTemplate: {
1104
				title: { text: MWF.xApplication.IMV2.LP.groupName, type: "text", notEmpty: true, value:  this.options["defaultValue"] },
1105 1106 1107 1108 1109 1110 1111 1112 1113
			}
		}, this.app);
		this.form.load();

	},
	_createBottomContent: function () {
		if (this.isNew || this.isEdited) {
			this.okActionNode = new Element("button.inputOkButton", {
				"styles": this.css.inputOkButton,
NoSubject's avatar
NoSubject 已提交
1114
				"text": MWF.xApplication.IMV2.LP.ok
1115 1116 1117 1118 1119 1120 1121
			}).inject(this.formBottomNode);
			this.okActionNode.addEvent("click", function (e) {
				this.save(e);
			}.bind(this));
		}
		this.cancelActionNode = new Element("button.inputCancelButton", {
			"styles": (this.isEdited || this.isNew || this.getEditPermission()) ? this.css.inputCancelButton : this.css.inputCancelButton_long,
NoSubject's avatar
NoSubject 已提交
1122
			"text": MWF.xApplication.IMV2.LP.close
1123 1124 1125 1126 1127 1128 1129 1130 1131 1132 1133 1134
		}).inject(this.formBottomNode);
		this.cancelActionNode.addEvent("click", function (e) {
			this.close(e);
		}.bind(this));
	},
	save: function () {
		var data = this.form.getResult(true, null, true, false, true);
		if (data) {
			this.app.updateConversationTitle(data.title, this.app.conversationId);
			this.close();
		}
	}
NoSubject's avatar
NoSubject 已提交
1135
});