You cannot select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
	
	
		
			91 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			JavaScript
		
	
			
		
		
	
	
			91 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			JavaScript
		
	
| /* global Whisper, i18n, _ */
 | |
| 
 | |
| // eslint-disable-next-line func-names
 | |
| (function() {
 | |
|   'use strict';
 | |
| 
 | |
|   window.Whisper = window.Whisper || {};
 | |
| 
 | |
|   Whisper.AddServerDialogView = Whisper.View.extend({
 | |
|     templateName: 'add-server-template',
 | |
|     className: 'loki-dialog add-server modal',
 | |
|     initialize(options = {}) {
 | |
|       this.title = i18n('addServerDialogTitle');
 | |
|       this.okText = options.okText || i18n('ok');
 | |
|       this.cancelText = options.cancelText || i18n('cancel');
 | |
|       this.$('input').focus();
 | |
|       this.render();
 | |
|     },
 | |
|     events: {
 | |
|       keyup: 'onKeyup',
 | |
|       'click .ok': 'confirm',
 | |
|       'click .cancel': 'close',
 | |
|     },
 | |
|     render_attributes() {
 | |
|       return {
 | |
|         title: this.title,
 | |
|         ok: this.okText,
 | |
|         cancel: this.cancelText,
 | |
|       };
 | |
|     },
 | |
|     confirm() {
 | |
|       // Remove error if there is one
 | |
|       this.showError(null);
 | |
|       const serverUrl = this.$('#server-url')
 | |
|         .val()
 | |
|         .toLowerCase();
 | |
|       // TODO: Make this not hard coded
 | |
|       const channelId = 1;
 | |
|       const dialog = new Whisper.ConnectingToServerDialogView({
 | |
|         serverUrl,
 | |
|         channelId,
 | |
|       });
 | |
|       const dialogDelayTimer = setTimeout(() => {
 | |
|         this.el.append(dialog.el);
 | |
|       }, 200);
 | |
|       dialog.once('connectionResult', result => {
 | |
|         clearTimeout(dialogDelayTimer);
 | |
|         if (result.cancelled) {
 | |
|           this.showError(null);
 | |
|           return;
 | |
|         }
 | |
|         if (result.errorCode) {
 | |
|           this.showError(result.errorCode);
 | |
|           return;
 | |
|         }
 | |
|         window.Whisper.events.trigger('showToast', {
 | |
|           message: i18n('connectToServerSuccess'),
 | |
|         });
 | |
|         this.close();
 | |
|       });
 | |
|       dialog.trigger('attemptConnection');
 | |
|     },
 | |
|     close() {
 | |
|       this.remove();
 | |
|     },
 | |
|     showError(message) {
 | |
|       if (_.isEmpty(message)) {
 | |
|         this.$('.error').text('');
 | |
|         this.$('.error').hide();
 | |
|       } else {
 | |
|         this.$('.error').text(`Error: ${message}`);
 | |
|         this.$('.error').show();
 | |
|       }
 | |
|       this.$('input').focus();
 | |
|     },
 | |
|     onKeyup(event) {
 | |
|       switch (event.key) {
 | |
|         case 'Enter':
 | |
|           this.confirm();
 | |
|           break;
 | |
|         case 'Escape':
 | |
|         case 'Esc':
 | |
|           this.close();
 | |
|           break;
 | |
|         default:
 | |
|           break;
 | |
|       }
 | |
|     },
 | |
|   });
 | |
| })();
 |