[Common] Bug in rendering chat and header panel when user id contains special characters.

This commit is contained in:
Julia Radzhabova 2018-03-02 17:48:24 +03:00
parent d04a61933e
commit 1b75d2035e
3 changed files with 23 additions and 15 deletions

View file

@ -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
}
} }
}); });
}); });

View file

@ -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});
} }
}, },

View file

@ -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});
} }