Main.js 36.6 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";
F
fancy 已提交
129 130 131
		var data = { "convName": conv.title };
		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 159 160 161 162
		this.chatTitleMoreMenuNode.setStyle("display", "none");
		var form = new MWF.xApplication.IMV2.UpdateConvTitleForm(this, {}, {}, { app: this.app });
		form.create();
	},
	//修改群成员
F
fancy 已提交
163
	tapUpdateConvMembers: function () {
164 165 166 167 168 169 170 171 172 173 174
		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;
			}
		}
		var form = new MWF.xApplication.IMV2.CreateConversationForm(this, {}, { "title": "修改成员", "personCount": 0, "personSelected": members, "isUpdateMember": true }, { app: this.app });
		form.create()
	},
F
fancy 已提交
175 176
	//点击发送消息
	sendMsg: function () {
F
fancy 已提交
177
		var text = this.chatBottomAreaTextareaNode.value;
F
fancy 已提交
178 179
		if (text) {
			this.chatBottomAreaTextareaNode.value = "";
F
fancy 已提交
180
			this._newAndSendTextMsg(text, "text");
F
fancy 已提交
181 182 183 184
		} else {
			console.log("没有消息内容!");
		}
	},
F
fancy 已提交
185
	//点击表情按钮
F
fancy 已提交
186 187
	showEmojiBox: function () {
		if (!this.emojiBoxNode) {
F
fancy 已提交
188 189
			this.emojiBoxNode = new Element("div", { "class": "chat-emoji-box" }).inject(this.chatNode);
			var _self = this;
F
fancy 已提交
190
			for (var i = 0; i < this.emojiList.length; i++) {
F
fancy 已提交
191
				var emoji = this.emojiList[i];
F
fancy 已提交
192
				var emojiNode = new Element("img", { "src": emoji.path, "class": "chat-emoji-img" }).inject(this.emojiBoxNode);
F
fancy 已提交
193 194 195 196
				emojiNode.addEvents({
					"mousedown": function (ev) {
						_self.sendEmojiMsg(this.emoji);
						_self.hideEmojiBox();
F
fancy 已提交
197
					}.bind({ emoji: emoji })
F
fancy 已提交
198 199 200 201 202 203 204
				});
			}
		}
		this.emojiBoxNode.setStyle("display", "block");
		this.hideFun = this.hideEmojiBox.bind(this);
		document.body.addEvent("mousedown", this.hideFun);
	},
F
fancy 已提交
205
	// 点击发送文件消息
F
fancy 已提交
206 207
	showChooseFile: function () {
		if (!this.uploadFileAreaNode) {
F
fancy 已提交
208 209 210 211 212
			this.createUploadFileNode();
		}
		this.fileUploadNode.click();
	},
	//创建文件选择框
F
fancy 已提交
213
	createUploadFileNode: function () {
F
fancy 已提交
214 215 216 217
		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 已提交
218 219 220 221 222 223 224 225 226 227 228 229 230 231 232
		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 已提交
233
				}
F
fancy 已提交
234 235 236 237 238 239 240 241 242 243 244 245
				//上传文件
				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 已提交
246 247
		}.bind(this));
	},
F
fancy 已提交
248
	hideEmojiBox: function () {
F
fancy 已提交
249 250 251 252 253
		//关闭emojiBoxNode
		this.emojiBoxNode.setStyle("display", "none");
		document.body.removeEvent("mousedown", this.hideFun);
	},
	//发送表情消息
F
fancy 已提交
254
	sendEmojiMsg: function (emoji) {
F
fancy 已提交
255 256
		this._newAndSendTextMsg(emoji.key, "emoji");
	},
F
fancy 已提交
257
	//点击创建单聊按钮
F
fancy 已提交
258
	tapCreateSingleConv: function () {
259 260 261 262 263 264 265 266
		// var form = new MWF.xApplication.IMV2.SingleForm(this, {}, {}, { app: this.app });
		// form.create()
		var form = new MWF.xApplication.IMV2.CreateConversationForm(this, {}, { "title": "创建单聊", "personCount": 1 }, { app: this.app });
		form.create()
	},
	//点击创建群聊按钮
	tapCreateGroupConv: function () {
		var form = new MWF.xApplication.IMV2.CreateConversationForm(this, {}, { "title": "创建群聊", "personCount": 0, "personSelected": [] }, { app: this.app });
F
fancy 已提交
267
		form.create()
F
fancy 已提交
268
	},
269
	//更新群名
F
fancy 已提交
270
	updateConversationTitle: function (title, convId) {
271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293
		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;
			//点击会话 刷新聊天界面
			_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);
				}
			}

		}.bind(this), function (error) {
			console.log(error);
		}.bind(this))
	},
	//更新群成员
F
fancy 已提交
294
	updateConversationMembers: function (members, convId) {
295 296 297 298 299 300 301 302 303 304 305 306
		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;
			_self.tapConv(newConv);
		}.bind(this), function (error) {
			console.log(error);
		}.bind(this))
	},
F
fancy 已提交
307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322
	/**
	 * 	创建会话
	 * @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 已提交
323
				if (newConv.id == c.data.id) {
F
fancy 已提交
324 325 326 327
					isOld = true;
					_self.tapConv(c);
				}
			}
F
fancy 已提交
328
			if (!isOld) {
F
fancy 已提交
329 330 331 332 333 334 335 336
				var itemNode = _self._createConvItemNode(newConv);
				_self.conversationNodeItemList.push(itemNode);
				_self.tapConv(newConv);
			}
		}.bind(this), function (error) {
			console.log(error);
		}.bind(this))
	},
F
fancy 已提交
337
	//创建会话ItemNode
F
fancy 已提交
338 339 340
	_createConvItemNode: function (conv) {
		return new MWF.xApplication.IMV2.ConversationItem(conv, this);
	},
F
fancy 已提交
341
	//会话ItemNode 点击背景色
F
fancy 已提交
342 343 344 345 346 347 348 349 350 351
	_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 已提交
352
	//创建图片或文件消息
F
fancy 已提交
353
	_newImageOrFileMsgAndSend: function (type, fileId, fileName, fileExt) {
F
fancy 已提交
354 355 356
		var distinguishedName = layout.session.user.distinguishedName;
		var time = this._currentTime();
		var body = {
F
fancy 已提交
357 358 359 360
			"body": "[文件]",
			"type": type,
			"fileId": fileId,
			"fileExtension": fileExt,
F
fancy 已提交
361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383
			"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) {
				console.log("消息发送成功!");
			}.bind(this),
			function (error) {
				console.log(error);
			}.bind(this));
		this.messageList.push(message);
		this._buildSender(body, distinguishedName, false);
		this._refreshConvMessage(message);
	},
F
fancy 已提交
384
	//创建文本消息 并发送
F
fancy 已提交
385
	_newAndSendTextMsg: function (text, type) {
F
fancy 已提交
386 387
		var distinguishedName = layout.session.user.distinguishedName;
		var time = this._currentTime();
F
fancy 已提交
388
		var body = { "body": text, "type": type };
F
fancy 已提交
389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406
		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;
				console.log("消息发送成功!");
			}.bind(this),
			function (error) {
				console.log(error);
			}.bind(this));
F
fancy 已提交
407
		this.messageList.push(textMessage);
F
fancy 已提交
408
		this._buildSender(body, distinguishedName, false);
F
fancy 已提交
409 410 411
		this._refreshConvMessage(textMessage);
	},
	//刷新会话Item里面的最后消息内容
F
fancy 已提交
412
	_refreshConvMessage: function (msg) {
F
fancy 已提交
413 414 415
		for (var i = 0; i < this.conversationNodeItemList.length; i++) {
			var node = this.conversationNodeItemList[i];
			if (node.data.id == this.conversationId) {
F
fancy 已提交
416
				node.refreshLastMsg(msg);
F
fancy 已提交
417 418 419
			}
		}
	},
F
fancy 已提交
420
	//检查会话列表是否有更新
F
fancy 已提交
421
	_checkConversationMessage: function () {
F
fancy 已提交
422 423 424 425 426 427 428 429 430 431 432 433 434 435 436
		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);
						}
					}
					//新会话 创建
F
fancy 已提交
437
					if (isNew) {
F
fancy 已提交
438 439 440 441 442 443 444 445 446
						var itemNode = this._createConvItemNode(nCv);
						this.conversationNodeItemList.push(itemNode);
					}
				}
				//this.loadConversationList(json.data);
			}
		}.bind(this));
	},
	//检查是否有新消息
F
fancy 已提交
447
	_checkNewMessage: function () {
F
fancy 已提交
448 449 450 451
		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 已提交
452
				if (list && list.length > 0) {
F
fancy 已提交
453 454 455 456 457 458 459
					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 已提交
460
								if (this.messageList[j].id == m.id) {
F
fancy 已提交
461 462 463
									isnew = false;
								}
							}
F
fancy 已提交
464
							if (isnew) {
F
fancy 已提交
465 466 467 468 469 470 471
								this.messageList.push(m);
								this._buildMsgNode(m, false);
								// this._refreshConvMessage(m);
							}
						}
					}
				}
F
fancy 已提交
472

F
fancy 已提交
473 474 475 476 477
			}.bind(this), function (error) {
				console.log(error);
			}.bind(this), false);
		}
	},
F
fancy 已提交
478
	//创建消息html节点
F
fancy 已提交
479
	_buildMsgNode: function (msg, isTop) {
F
fancy 已提交
480 481 482 483 484
		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 已提交
485
			this._buildReceiver(body, createPerson, isTop);
F
fancy 已提交
486
		} else {
F
fancy 已提交
487
			this._buildSender(body, createPerson, isTop);
F
fancy 已提交
488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508
		}
	},
	/**
	 * 消息发送体
	 * @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 已提交
509 510
		if (msgBody.type == "emoji") { // 表情
			var img = "";
F
fancy 已提交
511 512
			for (var i = 0; i < this.emojiList.length; i++) {
				if (msgBody.body == this.emojiList[i].key) {
F
fancy 已提交
513
					img = this.emojiList[i].path;
F
fancy 已提交
514
				}
F
fancy 已提交
515
			}
F
fancy 已提交
516 517 518 519 520 521
			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({
522
				"click": function (e) {
F
fancy 已提交
523 524 525 526 527 528
					var downloadUrl = this._getFileDownloadUrl(msgBody.fileId);
					window.open(downloadUrl);
				}.bind(this)
			});
		} else if (msgBody.type == "audio") {
			var url = this._getFileDownloadUrl(msgBody.fileId);
529
			new Element("audio", { "src": url, "controls": "controls", "preload": "preload" }).inject(lastNode);
F
fancy 已提交
530 531
		} else if (msgBody.type == "location") {
			var mapBox = new Element("span").inject(lastNode);
532
			new Element("img", { "src": "../x_component_IMV2/$Main/default/icons/location.png", "width": 24, "height": 24 }).inject(mapBox);
F
fancy 已提交
533
			var url = this._getBaiduMapUrl(msgBody.latitude, msgBody.longitude, msgBody.address, msgBody.addressDetail);
534
			new Element("a", { "href": url, "target": "_blank", "text": msgBody.address }).inject(mapBox);
F
fancy 已提交
535 536 537
		} else if (msgBody.type == "file") { //文件
			var mapBox = new Element("span").inject(lastNode);
			var fileIcon = this._getFileIcon(msgBody.fileExtension);
F
fancy 已提交
538
			new Element("img", { "src": "../x_component_IMV2/$Main/file_icons/" + fileIcon, "width": 48, "height": 48 }).inject(mapBox);
F
fancy 已提交
539 540
			var downloadUrl = this._getFileDownloadUrl(msgBody.fileId);
			new Element("a", { "href": downloadUrl, "target": "_blank", "text": msgBody.fileName }).inject(mapBox);
F
fancy 已提交
541
		} else {//text
F
fancy 已提交
542 543 544
			new Element("span", { "text": msgBody.body }).inject(lastNode);
		}

F
fancy 已提交
545
		if (!isTop) {
F
fancy 已提交
546 547 548
			var scrollFx = new Fx.Scroll(this.chatContentNode);
			scrollFx.toBottom();
		}
F
fancy 已提交
549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567
	},
	/**
	 * 消息接收体
	 * @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 已提交
568

F
fancy 已提交
569 570
		if (msgBody.type == "emoji") { // 表情
			var img = "";
F
fancy 已提交
571 572
			for (var i = 0; i < this.emojiList.length; i++) {
				if (msgBody.body == this.emojiList[i].key) {
F
fancy 已提交
573
					img = this.emojiList[i].path;
F
fancy 已提交
574
				}
F
fancy 已提交
575
			}
F
fancy 已提交
576 577 578 579 580 581
			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({
582
				"click": function (e) {
F
fancy 已提交
583 584 585 586 587 588
					var downloadUrl = this._getFileDownloadUrl(msgBody.fileId);
					window.open(downloadUrl);
				}.bind(this)
			});
		} else if (msgBody.type == "audio") {
			var url = this._getFileDownloadUrl(msgBody.fileId);
589
			new Element("audio", { "src": url, "controls": "controls", "preload": "preload" }).inject(lastNode);
F
fancy 已提交
590 591
		} else if (msgBody.type == "location") {
			var mapBox = new Element("span").inject(lastNode);
592
			new Element("img", { "src": "../x_component_IMV2/$Main/default/icons/location.png", "width": 24, "height": 24 }).inject(mapBox);
F
fancy 已提交
593
			var url = this._getBaiduMapUrl(msgBody.latitude, msgBody.longitude, msgBody.address, msgBody.addressDetail);
594
			new Element("a", { "href": url, "target": "_blank", "text": msgBody.address }).inject(mapBox);
F
fancy 已提交
595 596 597
		} else if (msgBody.type == "file") { //文件
			var mapBox = new Element("span").inject(lastNode);
			var fileIcon = this._getFileIcon(msgBody.fileExtension);
F
fancy 已提交
598
			new Element("img", { "src": "../x_component_IMV2/$Main/file_icons/" + fileIcon, "width": 48, "height": 48 }).inject(mapBox);
F
fancy 已提交
599 600
			var downloadUrl = this._getFileDownloadUrl(msgBody.fileId);
			new Element("a", { "href": downloadUrl, "target": "_blank", "text": msgBody.fileName }).inject(mapBox);
F
fancy 已提交
601
		} else {//text
F
fancy 已提交
602 603
			new Element("span", { "text": msgBody.body }).inject(lastNode);
		}
F
fancy 已提交
604 605

		if (!isTop) {
F
fancy 已提交
606 607 608
			var scrollFx = new Fx.Scroll(this.chatContentNode);
			scrollFx.toBottom();
		}
F
fancy 已提交
609
	},
F
fancy 已提交
610
	//图片 根据大小 url
611
	_getFileUrlWithWH: function (id, width, height) {
F
fancy 已提交
612
		var action = MWF.Actions.get("x_message_assemble_communicate").action;
F
fancy 已提交
613
		var url = action.getAddress() + action.actions.imgFileDownloadWithWH.uri;
F
fancy 已提交
614 615 616 617 618 619
		url = url.replace("{id}", encodeURIComponent(id));
		url = url.replace("{width}", encodeURIComponent(width));
		url = url.replace("{height}", encodeURIComponent(height));
		return url;
	},
	//file 下载的url
620
	_getFileDownloadUrl: function (id) {
F
fancy 已提交
621
		var action = MWF.Actions.get("x_message_assemble_communicate").action;
F
fancy 已提交
622
		var url = action.getAddress() + action.actions.imgFileDownload.uri;
F
fancy 已提交
623 624 625 626
		url = url.replace("{id}", encodeURIComponent(id));
		return url;
	},
	//百度地图打开地址
627 628
	_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 已提交
629 630
		return url;
	},
F
fancy 已提交
631
	//用户头像
NoSubject's avatar
NoSubject 已提交
632 633
	_getIcon: function (id) {
		var orgAction = MWF.Actions.get("x_organization_assemble_control")
634
		var url = (id) ? orgAction.getPersonIcon(id) : "../x_component_IMV2/$Main/default/icons/group.png";
NoSubject's avatar
NoSubject 已提交
635 636
		return url + "?" + (new Date().getTime());
	},
F
fancy 已提交
637 638 639 640 641 642 643 644 645 646 647 648 649 650 651 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
	// 文件类型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 已提交
700
			} else {
F
fancy 已提交
701 702
				return "icon_file_unkown.png";
			}
F
fancy 已提交
703
		} else {
F
fancy 已提交
704 705 706
			return "icon_file_unkown.png";
		}
	},
NoSubject's avatar
NoSubject 已提交
707 708 709 710 711 712 713 714 715 716 717 718 719 720 721 722 723 724 725 726 727 728 729 730 731 732 733 734 735 736 737 738 739 740 741 742 743 744 745 746 747 748 749 750 751 752 753 754 755 756 757 758 759 760 761 762 763 764
	//输出特殊的时间格式
	_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) {
					retTime = Math.max(parseInt((todayTime - time) / 60000), 1) + "分钟前"
				} else {
					retTime = hour + "小时前"
				}

			}
			return retTime;
		}
		var dates = parseInt(time / 86400000);
		var todaydates = parseInt(todayTime / 86400000);
		if (todaydates > dates) {
			var days = (todaydates - dates);
			if (days == 1) {
				retTime = "昨天";
			} else if (days == 2) {
				retTime = "前天 ";
			} else if (days > 2 && days < 31) {
				retTime = days + "天前";
			} else if (days >= 31 && days <= 2 * 31) {
				retTime = "一个月前";
			} else if (days > 2 * 31 && days <= 3 * 31) {
				retTime = "2个月前";
			} else if (days > 3 * 31 && days <= 4 * 31) {
				retTime = "3个月前";
			} 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 已提交
765
	},
F
fancy 已提交
766
	//当前时间 yyyy-MM-dd HH:mm:ss
F
fancy 已提交
767 768 769 770 771 772 773 774 775 776 777 778 779 780 781
	_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 已提交
782 783 784 785
	}


});
F
fancy 已提交
786 787 788 789 790 791 792 793 794 795 796 797 798 799 800 801 802

//会话对象
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 已提交
803 804
			"lastMessage": "",
			"lastMessageType": "text"
F
fancy 已提交
805 806 807 808 809 810 811 812 813 814 815 816 817 818 819 820 821 822 823 824 825 826 827 828 829 830 831
		};
		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 已提交
832 833 834
			if (mBody.type) {
				convData.lastMessageType = mBody.type;
			}
F
fancy 已提交
835 836 837 838 839 840 841
		}
		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);
842
		this.titleNode = new Element("div", { "class": "body_title", "text": convData.title }).inject(bodyUpNode);
F
fancy 已提交
843
		this.messageTimeNode = new Element("div", { "class": "body_time", "text": convData.time }).inject(bodyUpNode);
F
fancy 已提交
844
		if (convData.lastMessageType == "emoji") {
F
fancy 已提交
845
			this.lastMessageNode = new Element("div", { "class": "body_down" }).inject(bodyNode);
F
fancy 已提交
846
			var imgPath = "";
F
fancy 已提交
847
			for (var i = 0; i < this.main.emojiList.length; i++) {
F
fancy 已提交
848 849 850 851 852
				var emoji = this.main.emojiList[i];
				if (emoji.key == convData.lastMessage) {
					imgPath = emoji.path;
				}
			}
F
fancy 已提交
853 854
			new Element("img", { "src": imgPath, "style": "width: 16px;height: 16px;" }).inject(this.lastMessageNode);
		} else {
F
fancy 已提交
855 856
			this.lastMessageNode = new Element("div", { "class": "body_down", "text": convData.lastMessage }).inject(bodyNode);
		}
F
fancy 已提交
857

F
fancy 已提交
858 859 860 861 862 863 864 865
		var _self = this;
		this.node.addEvents({
			"click": function () {
				_self.main.tapConv(_self.data);
			}
		});
	},
	/**
F
fancy 已提交
866
	 *
F
fancy 已提交
867 868 869
	 * 刷新会话列表的最后消息内容 
	 * @param {*} lastMessage 
	 */
F
fancy 已提交
870
	refreshLastMsg: function (lastMessage) {
F
fancy 已提交
871 872
		//目前是text 类型的消息
		var jsonbody = lastMessage.body;
F
fancy 已提交
873 874
		var body = JSON.parse(jsonbody);

F
fancy 已提交
875
		if (this.lastMessageNode) {
F
fancy 已提交
876 877
			if (body.type == "emoji") { //表情 消息
				var imgPath = "";
F
fancy 已提交
878
				for (var i = 0; i < this.main.emojiList.length; i++) {
F
fancy 已提交
879 880 881 882 883 884
					var emoji = this.main.emojiList[i];
					if (emoji.key == body.body) {
						imgPath = emoji.path;
					}
				}
				this.lastMessageNode.empty();
F
fancy 已提交
885 886
				new Element("img", { "src": imgPath, "style": "width: 16px;height: 16px;" }).inject(this.lastMessageNode);
			} else { //文本消息
F
fancy 已提交
887 888 889
				this.lastMessageNode.empty();
				this.lastMessageNode.set('text', body.body);
			}
F
fancy 已提交
890 891
		}
		var time = this.main._friendlyTime(o2.common.toDate(lastMessage.createTime));
F
fancy 已提交
892
		if (this.messageTimeNode) {
F
fancy 已提交
893 894 895
			this.messageTimeNode.set("text", time);
		}
	},
F
fancy 已提交
896
	refreshConvTitle: function (title) {
897 898
		this.titleNode.set("text", title);
	},
F
fancy 已提交
899 900 901 902 903 904 905 906 907 908 909 910 911 912 913 914 915 916 917 918 919 920 921 922 923 924 925 926 927 928 929 930 931 932 933 934 935 936 937 938 939 940 941 942 943 944 945
	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,
		"title": "创建单聊"
	},
	_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: {
946
				person: { text: "选择人员", type: "org", orgType: "person", count: 0, notEmpty: true, exclude: exclude },
F
fancy 已提交
947 948 949 950 951 952 953 954 955 956 957 958 959 960 961 962 963 964 965 966 967 968 969 970 971 972 973 974 975 976 977
			}
		}, this.app);
		this.form.load();

	},
	_createBottomContent: function () {
		if (this.isNew || this.isEdited) {
			this.okActionNode = new Element("button.inputOkButton", {
				"styles": this.css.inputOkButton,
				"text": "确定"
			}).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,
			"text": "关闭"
		}).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();
		}
	}
978 979 980 981 982 983 984 985 986 987 988 989 990 991 992 993 994 995 996 997 998 999 1000 1001 1002 1003 1004 1005 1006 1007 1008 1009 1010 1011 1012 1013 1014 1015 1016 1017 1018 1019 1020 1021 1022 1023 1024 1025 1026 1027 1028 1029 1030 1031 1032 1033 1034 1035 1036 1037 1038 1039 1040 1041 1042
});


//创建聊天 弹出窗表单
MWF.xApplication.IMV2.CreateConversationForm = new Class({
	Extends: MPopupForm,
	Implements: [Options, Events],
	options: {
		"style": "minder",
		"width": 700,
		"height": "200",
		"hasTop": true,
		"hasIcon": false,
		"draggable": true,
		"title": "创建单聊",
		"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: {
				person: { text: "选择人员", type: "org", orgType: "person", count: this.options["personCount"], notEmpty: true, exclude: exclude, value: this.options["personSelected"] },
			}
		}, this.app);
		this.form.load();

	},
	_createBottomContent: function () {
		if (this.isNew || this.isEdited) {
			this.okActionNode = new Element("button.inputOkButton", {
				"styles": this.css.inputOkButton,
				"text": "确定"
			}).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,
			"text": "关闭"
		}).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 已提交
1043 1044
			} else {
				this.app.newConversation(data.person, this.options["personCount"] === 1 ? "single" : "group");
1045
			}
F
fancy 已提交
1046

1047 1048 1049 1050 1051 1052 1053 1054 1055 1056 1057 1058 1059 1060 1061 1062 1063 1064 1065 1066 1067 1068 1069 1070 1071 1072
			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,
		"title": "修改群名"
	},
	_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 已提交
1073

1074 1075 1076 1077 1078
		this.form = new MForm(this.formTableArea, this.data || {}, {
			isEdited: true,
			style: "minder",
			hasColon: true,
			itemTemplate: {
F
fancy 已提交
1079
				title: { text: "群名", type: "text", notEmpty: true },
1080 1081 1082 1083 1084 1085 1086 1087 1088 1089 1090 1091 1092 1093 1094 1095 1096 1097 1098 1099 1100 1101 1102 1103 1104 1105 1106 1107 1108 1109
			}
		}, this.app);
		this.form.load();

	},
	_createBottomContent: function () {
		if (this.isNew || this.isEdited) {
			this.okActionNode = new Element("button.inputOkButton", {
				"styles": this.css.inputOkButton,
				"text": "确定"
			}).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,
			"text": "关闭"
		}).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();
		}
	}
F
fancy 已提交
1110
});