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.
		
		
		
		
		
			
		
			
				
	
	
		
			41 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			JavaScript
		
	
			
		
		
	
	
			41 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			JavaScript
		
	
| /*
 | |
|  * vim: ts=4:sw=4:expandtab
 | |
|  */
 | |
| (function () {
 | |
|     'use strict';
 | |
|     window.Whisper = window.Whisper || {};
 | |
| 
 | |
|     Whisper.PhoneInputView = Whisper.View.extend({
 | |
|         tagName: 'div',
 | |
|         className: 'phone-input',
 | |
|         templateName: 'phone-number',
 | |
|         render: function() {
 | |
|             this.$el.html($(Mustache.render(this.template)));
 | |
|             this.$('input.number').intlTelInput();
 | |
|             return this;
 | |
|         },
 | |
| 
 | |
|         events: {
 | |
|             'change': 'validateNumber',
 | |
|             'keyup': 'validateNumber'
 | |
|         },
 | |
| 
 | |
|         validateNumber: function() {
 | |
|             var input = this.$('input.number');
 | |
|             var regionCode = this.$('li.active').attr('data-country-code').toUpperCase();
 | |
|             var number = input.val();
 | |
| 
 | |
|             var parsedNumber = libphonenumber.util.parseNumber(number, regionCode);
 | |
|             if (parsedNumber.isValidNumber) {
 | |
|                 this.$('.number-container').removeClass('invalid');
 | |
|                 this.$('.number-container').addClass('valid');
 | |
|             } else {
 | |
|                 this.$('.number-container').removeClass('valid');
 | |
|             }
 | |
|             input.trigger('validation');
 | |
| 
 | |
|             return parsedNumber.e164;
 | |
|         }
 | |
|     });
 | |
| })();
 |