/* vim: ts=4:sw=4:expandtab * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with this program. If not, see . */ var Whisper = Whisper || {}; (function () { 'use strict'; Whisper.PhoneInputView = Backbone.View.extend({ tagName: 'div', className: 'phone-input', initialize: function() { this.template = $('#phone-number').html(); Mustache.parse(this.template); this.render(); }, render: function() { this.$el.html($(Mustache.render(this.template))); this.$el.find('input.number').intlTelInput(); return this; }, events: { 'change': 'validateNumber', 'keyup': 'validateNumber' }, validateNumber: function() { var input = this.$el.find('input.number'); try { var regionCode = this.$el.find('li.active').attr('data-country-code').toUpperCase(); var number = input.val(); var parsedNumber = libphonenumber.util.verifyNumber(number, regionCode); this.$el.find('.number-container').removeClass('invalid'); this.$el.find('.number-container').addClass('valid'); return parsedNumber; } catch(e) { this.$el.find('.number-container').removeClass('valid'); } finally { input.trigger('validation'); } } }); })();