2015-09-07 23:53:43 +02:00
|
|
|
/*
|
|
|
|
* vim: ts=4:sw=4:expandtab
|
2015-02-18 03:03:05 +01:00
|
|
|
*/
|
|
|
|
(function () {
|
|
|
|
'use strict';
|
|
|
|
|
|
|
|
window.Whisper = window.Whisper || {};
|
|
|
|
|
2015-12-26 06:42:47 +01:00
|
|
|
var ErrorView = Whisper.View.extend({
|
2015-02-18 03:03:05 +01:00
|
|
|
className: 'error',
|
2015-12-26 06:42:47 +01:00
|
|
|
templateName: 'generic-error',
|
|
|
|
render_attributes: function() {
|
|
|
|
return this.model;
|
2015-02-18 03:03:05 +01:00
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
var KeyConflictView = ErrorView.extend({
|
|
|
|
className: 'key-conflict',
|
2015-12-26 06:42:47 +01:00
|
|
|
templateName: 'key-conflict',
|
2015-02-18 03:03:05 +01:00
|
|
|
initialize: function(options) {
|
|
|
|
this.message = options.message;
|
|
|
|
},
|
|
|
|
events: {
|
|
|
|
'click': 'select'
|
|
|
|
},
|
2015-12-26 06:42:47 +01:00
|
|
|
render_attributes: function() {
|
|
|
|
var errorMessage;
|
|
|
|
if (this.message.isIncoming()) {
|
|
|
|
errorMessage = 'incomingKeyConflict';
|
|
|
|
} else {
|
|
|
|
errorMessage = 'outgoingKeyConflict';
|
|
|
|
}
|
|
|
|
return { message: i18n(errorMessage) };
|
|
|
|
},
|
2015-02-18 03:03:05 +01:00
|
|
|
select: function() {
|
|
|
|
this.$el.trigger('select', {message: this.message});
|
|
|
|
},
|
|
|
|
});
|
|
|
|
|
|
|
|
Whisper.MessageErrorView = Backbone.View.extend({
|
|
|
|
className: 'error',
|
|
|
|
initialize: function(options) {
|
|
|
|
if (this.model.name === 'IncomingIdentityKeyError' ||
|
|
|
|
this.model.name === 'OutgoingIdentityKeyError') {
|
|
|
|
this.view = new KeyConflictView({
|
|
|
|
model : this.model,
|
|
|
|
message : options.message
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
this.view = new ErrorView({ model: this.model });
|
|
|
|
}
|
|
|
|
this.$el.append(this.view.el);
|
|
|
|
this.view.render();
|
|
|
|
},
|
|
|
|
render: function() {
|
|
|
|
this.view.render();
|
|
|
|
return this;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
})();
|