[Common] Bug in rendering chat and header panel when user id contains special characters.
This commit is contained in:
parent
d04a61933e
commit
1b75d2035e
|
@ -40,21 +40,29 @@
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
if (Common === undefined)
|
||||||
|
var Common = {};
|
||||||
|
|
||||||
|
Common.Models = Common.Models || {};
|
||||||
|
|
||||||
define([
|
define([
|
||||||
'backbone'
|
'underscore',
|
||||||
], function(Backbone){
|
'backbone',
|
||||||
|
'common/main/lib/component/BaseView'
|
||||||
|
], function(_, Backbone){
|
||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
Common.Models = Common.Models || {};
|
|
||||||
|
|
||||||
Common.Models.User = Backbone.Model.extend({
|
Common.Models.User = Backbone.Model.extend({
|
||||||
defaults: {
|
defaults: function() {
|
||||||
id : undefined,
|
return {
|
||||||
username : 'Guest',
|
iid : Common.UI.getId(), // internal id for rendering
|
||||||
color : '#fff',
|
id : undefined,
|
||||||
colorval : null,
|
username : 'Guest',
|
||||||
online : false,
|
color : '#fff',
|
||||||
view : false
|
colorval : null,
|
||||||
|
online : false,
|
||||||
|
view : false
|
||||||
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
|
@ -59,7 +59,7 @@ define([
|
||||||
storeUsers: undefined,
|
storeUsers: undefined,
|
||||||
storeMessages: undefined,
|
storeMessages: undefined,
|
||||||
|
|
||||||
tplUser: ['<li id="chat-user-<%= user.get("id") %>"<% if (!user.get("online")) { %> class="offline"<% } %>>',
|
tplUser: ['<li id="<%= user.get("iid") %>"<% if (!user.get("online")) { %> class="offline"<% } %>>',
|
||||||
'<div class="color" style="background-color: <%= user.get("color") %>;" >',
|
'<div class="color" style="background-color: <%= user.get("color") %>;" >',
|
||||||
'<label class="name"><%= scope.getUserName(user.get("username")) %></label>',
|
'<label class="name"><%= scope.getUserName(user.get("username")) %></label>',
|
||||||
'</div>',
|
'</div>',
|
||||||
|
@ -169,7 +169,7 @@ define([
|
||||||
|
|
||||||
_onUsersChanged: function(m) {
|
_onUsersChanged: function(m) {
|
||||||
if (m.changed.online != undefined && this.panelUsers) {
|
if (m.changed.online != undefined && this.panelUsers) {
|
||||||
this.panelUsers.find('#chat-user-'+ m.get('id'))[m.changed.online?'removeClass':'addClass']('offline');
|
this.panelUsers.find('#' + m.get('iid'))[m.changed.online?'removeClass':'addClass']('offline');
|
||||||
this.panelUsers.scroller.update({minScrollbarLength : 25, alwaysVisibleY: true});
|
this.panelUsers.scroller.update({minScrollbarLength : 25, alwaysVisibleY: true});
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
|
@ -56,7 +56,7 @@ define([
|
||||||
var $saveStatus;
|
var $saveStatus;
|
||||||
|
|
||||||
var templateUserItem =
|
var templateUserItem =
|
||||||
'<li id="status-chat-user-<%= user.get("id") %>" class="<% if (!user.get("online")) { %> offline <% } if (user.get("view")) {%> viewmode <% } %>">' +
|
'<li id="<%= user.get("iid") %>" class="<% if (!user.get("online")) { %> offline <% } if (user.get("view")) {%> viewmode <% } %>">' +
|
||||||
'<div class="color" style="background-color: <%= user.get("color") %>;" >' +
|
'<div class="color" style="background-color: <%= user.get("color") %>;" >' +
|
||||||
'<label class="name"><%= fnEncode(user.get("username")) %></label>' +
|
'<label class="name"><%= fnEncode(user.get("username")) %></label>' +
|
||||||
'</div>' +
|
'</div>' +
|
||||||
|
@ -127,7 +127,7 @@ define([
|
||||||
|
|
||||||
function onUsersChanged(model, collection) {
|
function onUsersChanged(model, collection) {
|
||||||
if (model.changed.online != undefined && $userList) {
|
if (model.changed.online != undefined && $userList) {
|
||||||
$userList.find('#status-chat-user-'+ model.get('id'))[model.changed.online ? 'removeClass' : 'addClass']('offline');
|
$userList.find('#'+ model.get('iid'))[model.changed.online ? 'removeClass' : 'addClass']('offline');
|
||||||
$userList.scroller && $userList.scroller.update({minScrollbarLength : 40, alwaysVisibleY: true});
|
$userList.scroller && $userList.scroller.update({minScrollbarLength : 40, alwaysVisibleY: true});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue