|  |  |  | /* global Whisper, i18n, _ */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // eslint-disable-next-line func-names
 | 
					
						
							|  |  |  | (function() { | 
					
						
							|  |  |  |   'use strict'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   window.Whisper = window.Whisper || {}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   Whisper.NicknameDialogView = Whisper.View.extend({ | 
					
						
							|  |  |  |     className: 'nickname-dialog modal', | 
					
						
							|  |  |  |     templateName: 'nickname-dialog', | 
					
						
							|  |  |  |     initialize(options) { | 
					
						
							|  |  |  |       this.message = options.message; | 
					
						
							|  |  |  |       this.name = options.name || ''; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       this.resolve = options.resolve; | 
					
						
							|  |  |  |       this.okText = options.okText || i18n('ok'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       this.reject = options.reject; | 
					
						
							|  |  |  |       this.cancelText = options.cancelText || i18n('cancel'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       this.clear = options.clear; | 
					
						
							|  |  |  |       this.clearText = options.clearText || i18n('clear'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       this.title = options.title; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       this.render(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       this.$input = this.$('input'); | 
					
						
							|  |  |  |       this.$input.val(this.name); | 
					
						
							|  |  |  |       this.$input.focus(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       this.validateNickname(); | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     events: { | 
					
						
							|  |  |  |       keyup: 'onKeyup', | 
					
						
							|  |  |  |       'click .ok': 'ok', | 
					
						
							|  |  |  |       'click .cancel': 'cancel', | 
					
						
							|  |  |  |       'click .clear': 'clear', | 
					
						
							|  |  |  |       change: 'validateNickname', | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     validateNickname() { | 
					
						
							|  |  |  |       const nickname = this.$input.val(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (_.isEmpty(nickname)) { | 
					
						
							|  |  |  |         this.$('.clear').hide(); | 
					
						
							|  |  |  |       } else { | 
					
						
							|  |  |  |         this.$('.clear').show(); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     render_attributes() { | 
					
						
							|  |  |  |       return { | 
					
						
							|  |  |  |         message: this.message, | 
					
						
							|  |  |  |         showCancel: !this.hideCancel, | 
					
						
							|  |  |  |         cancel: this.cancelText, | 
					
						
							|  |  |  |         ok: this.okText, | 
					
						
							|  |  |  |         clear: this.clearText, | 
					
						
							|  |  |  |         title: this.title, | 
					
						
							|  |  |  |       }; | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     ok() { | 
					
						
							|  |  |  |       const nickname = this.$input.val().trim(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       this.remove(); | 
					
						
							|  |  |  |       if (this.resolve) { | 
					
						
							|  |  |  |         this.resolve(nickname); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     cancel() { | 
					
						
							|  |  |  |       this.remove(); | 
					
						
							|  |  |  |       if (this.reject) { | 
					
						
							|  |  |  |         this.reject(); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     clear() { | 
					
						
							|  |  |  |       this.$input.val('').trigger('change'); | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     onKeyup(event) { | 
					
						
							|  |  |  |       this.validateNickname(); | 
					
						
							|  |  |  |       switch (event.key) { | 
					
						
							|  |  |  |         case 'Enter': | 
					
						
							|  |  |  |           this.ok(); | 
					
						
							|  |  |  |           break; | 
					
						
							|  |  |  |         case 'Escape': | 
					
						
							|  |  |  |         case 'Esc': | 
					
						
							|  |  |  |           this.cancel(); | 
					
						
							|  |  |  |           break; | 
					
						
							|  |  |  |         default: | 
					
						
							|  |  |  |           return; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       event.preventDefault(); | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     focusCancel() { | 
					
						
							|  |  |  |       this.$('.cancel').focus(); | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | })(); |