(function(window) { if (!Array.isArray) { Array.isArray = function(arg) { return Object.prototype.toString.call(arg) === '[object Array]'; }; } if (!Object.isSimpleObject) { Object.isSimpleObject = function(arg) { return arg != null && typeof arg === 'object'; }; } function isFunction(func) { return func && {}.toString.call(func) === '[object Function]'; } function getEl(elOrId) { if (elOrId.nodeType) return elOrId; return document.getElementById(elOrId); } function preventDefault(event) { if (window.event) { window.event.returnValue = false; } else if (event.preventDefault) { event.preventDefault(); } else { event.returnValue = false; } } function addEvent(el, event, handler) { var events = event.split(/\s+/); for (var i = 0; i < events.length; i++) { if (el.addEventListener) { el.addEventListener(events[i], handler, false); } else { el.attachEvent('on' + events[i], handler); } } } var UA = window.navigator.userAgent || ''; var ScopeAliases = { personal_details: 'pd', passport: 'pp', driver_license: 'dl', identity_card: 'ic', internal_passport: 'ip', id_document: 'idd', address: 'ad', utility_bill: 'ub', bank_statement: 'bs', rental_agreement: 'ra', passport_registration: 'pr', temporary_registration: 'tr', address_document: 'add', phone_number: 'pn', email: 'em', }; function openDeepLink(url, tooltipToggle) { var is_ios = /ios|iphone os|iphone|ipod|ipad/i.test(UA); var is_firefox = /firefox/i.test(UA); var use_iframe = (is_ios || is_firefox); var use_once = (!is_ios && is_firefox); var timeOpen; var ttNeedHide = false; var pageShown = true; var onPageHide = function() { pageShown = false; }; tooltipToggle = tooltipToggle || function(){}; var onPageShow = function() { pageShown = true; if (ttNeedHide && (+(new Date) - timeOpen) > 5000) { tooltipToggle(false); } }; addEvent(window, 'pagehide', onPageHide); addEvent(window, 'pageshow', onPageShow); addEvent(window, 'blur', onPageHide); addEvent(window, 'focus', onPageShow); var showTooltip = function() { tooltipToggle(true); if (!pageShown) { ttNeedHide = true; } }; if (use_iframe) { var iframeEl = document.createElement('iframe'); iframeEl.style.position = 'absolute'; iframeEl.style.left = '-10000px'; iframeEl.style.top = '-10000px'; document.body.appendChild(iframeEl); if (iframeEl !== null) { timeOpen = +(new Date); iframeEl.src = url; setTimeout(showTooltip, 2500); } if (!use_once) { setTimeout(function() { if (pageShown) { timeOpen = +(new Date); window.location = url; } }, 2000); } } else { setTimeout(function() { timeOpen = +(new Date); window.location = url; }, 100); setTimeout(showTooltip, 1500); } } function packScope(scope) { if (scope.data) { scope.d = scope.data; delete scope.data; } if (!scope.d) { throw new TypeError('scope data is required'); } if (!scope.v) { throw new TypeError('scope version is required'); } for (var i = 0; i < scope.d.length; i++) { scope.d[i] = packScopeField(scope.d[i]); } return JSON.stringify(scope); } function packScopeField(field) { if (field.one_of) { field._ = field.one_of; delete field.one_of; } else if (field.type) { field._ = field.type; delete field.type; } if (Array.isArray(field._)) { for (var j = 0; j < field._.length; j++) { field._[j] = packScopeField(field._[j]); } field = packScopeOpts(field); } else if (field._) { if (ScopeAliases[field._]) { field._ = ScopeAliases[field._]; } field = packScopeOpts(field); } else if (ScopeAliases[field]) { field = ScopeAliases[field]; } return field; } function packScopeOpts(scope) { if (scope.selfie) { scope.s = 1; delete scope.selfie; } if (scope.translation) { scope.t = 1; delete scope.translation; } if (scope.native_names) { scope.n = 1; delete scope.native_names; } return scope; } function passportAuth(options, tooltipToggle) { if (!options.bot_id) { throw new Error('bot_id is required'); } if (!options.scope) { throw new Error('scope is required'); } if (!Object.isSimpleObject(options.scope)) { throw new TypeError('scope should be an object'); } if (!options.public_key) { throw new Error('public_key is required'); } if (!options.nonce) { throw new Error('nonce is required'); } if (options.payload) { throw new Error('payload is deprecated, use nonce instead'); } var is_android = /android/i.test(UA); var url = (is_android ? 'tg:' : 'tg://') + 'resolve?domain=telegrampassport' + '&bot_id=' + encodeURIComponent(options.bot_id) + '&scope=' + encodeURIComponent(packScope(options.scope)) + '&public_key=' + encodeURIComponent(options.public_key) + '&nonce=' + encodeURIComponent(options.nonce); if (options.callback_url) { url += '&callback_url=' + encodeURIComponent(options.callback_url); } url += '&payload=nonce'; // legacy for outdated apps openDeepLink(url, tooltipToggle); } function createAuthButton(contEl, authDataOrFunc, options) { contEl = getEl(contEl); if (!contEl) { return false; } options = options || {}; var btnText = options.text || 'Log In With Telegram'; var btnRadius = parseInt(options.radius, 10) || 23; var tooltipText = options.tooltip_text || 'Please <u>install Telegram</u> to use this option.'; var tooltipForce = options.tooltip_force || false; var tooltipPos = options.tooltip_position; if (tooltipPos == 'top') { var tooltipWrapClass = 'tooltip-top'; } else if (tooltipPos == 'left') { var tooltipWrapClass = 'tooltip-left'; } else if (tooltipPos == 'right') { var tooltipWrapClass = 'tooltip-right'; } else { var tooltipWrapClass = 'tooltip-bottom'; } var btnStyle = '' + '.telegram-passport {' + 'display: inline-block;' + 'position: relative;' + 'max-width: 100%;' + '}' + 'button.telegram-passport-button {' + 'display: inline-block;' + 'vertical-align: top;' + 'font-family: "Lucida Grande", Arial, Helvetica, sans-serif;' + 'font-size: 16px;' + 'font-weight: 500;' + 'line-height: 20px;' + 'text-align: left;' + 'border-radius: ' + btnRadius + 'px;' + 'background-color: #54a9eb;' + 'text-decoration: none;' + 'padding: 12px 21px 14px;' + 'margin: 0;' + 'white-space: nowrap;' + 'text-overflow: ellipsis;' + 'overflow: hidden;' + 'border: none;' + 'color: #fff;' + 'cursor: pointer;' + 'max-width: 100%;' + '}' + 'button.telegram-passport-button:focus {' + 'outline: none;' + '}' + '.telegram-passport-tooltip-wrap {' + 'position: absolute;' + 'pointer-events: none;' + 'text-align: center;' + 'z-index: 100;' + '}' + '.telegram-passport-tooltip-wrap.tooltip-bottom {' + 'left: -500px;' + 'right: -500px;' + 'top: 100%;' + '}' + '.telegram-passport-tooltip-wrap.tooltip-top {' + 'left: -500px;' + 'right: -500px;' + 'bottom: 100%;' + '}' + '.telegram-passport-tooltip-wrap.tooltip-left {' + 'right: 100%;' + 'top: 7px;' + 'bottom: 7px;' + '}' + '.telegram-passport-tooltip-wrap.tooltip-right {' + 'left: 100%;' + 'top: 7px;' + 'bottom: 7px;' + '}' + '.telegram-passport-tooltip {' + 'position: relative;' + 'font-family: "Lucida Grande", Arial, Helvetica, sans-serif;' + 'background: #949494;' + 'color: #fff;' + 'white-space: nowrap;' + 'border-radius: ' + btnRadius + 'px;' + 'padding: 7px 16px;' + 'display: inline-block;' + 'font-size: 14px;' + 'line-height: 18px;' + 'text-decoration: none;' + 'pointer-events: none;' + 'visibility: hidden;' + 'opacity: 0;' + '}' + '.telegram-passport-tooltip-wrap.tooltip-bottom .telegram-passport-tooltip {' + 'margin-top: 32px;' + '}' + '.telegram-passport-tooltip-wrap.tooltip-top .telegram-passport-tooltip {' + 'margin-bottom: 32px;' + '}' + '.telegram-passport-tooltip-wrap.tooltip-left .telegram-passport-tooltip {' + 'margin-right: 32px;' + '}' + '.telegram-passport-tooltip-wrap.tooltip-right .telegram-passport-tooltip {' + 'margin-left: 32px;' + '}' + '.telegram-passport-tooltip:hover {' + 'color: #fff;' + 'text-decoration: none;' + '}' + '.telegram-passport-tooltip-shown {' + 'transition: all .2s ease;' + 'pointer-events: auto;' + 'visibility: visible;' + 'opacity: 1;' + '}' + '.telegram-passport-tooltip-wrap.tooltip-bottom .telegram-passport-tooltip-shown {' + 'margin-top: 16px;' + '}' + '.telegram-passport-tooltip-wrap.tooltip-top .telegram-passport-tooltip-shown {' + 'margin-bottom: 16px;' + '}' + '.telegram-passport-tooltip-wrap.tooltip-left .telegram-passport-tooltip-shown {' + 'margin-right: 16px;' + '}' + '.telegram-passport-tooltip-wrap.tooltip-right .telegram-passport-tooltip-shown {' + 'margin-left: 16px;' + '}' + '.telegram-passport-button-icon {' + 'display: inline-block;' + 'vertical-align: top;' + "background: url('') no-repeat;" + 'background-size: 27px 22px;' + 'width: 27px;' + 'height: 22px;' + 'margin: 0 15px -2px -5px;' + '}' + '.telegram-passport-tooltip:before {' + "content: '';" + 'display: inline-block;' + 'position: absolute;' + '}' + '.telegram-passport-tooltip-wrap.tooltip-bottom .telegram-passport-tooltip:before {' + 'left: 50%;' + 'top: 0;' + 'border: 10px solid;' + 'border-radius: 4px 0 0;' + 'border-color: #949494 transparent transparent #949494;' + 'transform: rotateZ(45deg) translate3d(-3px,5px,0);' + 'transform-origin: 100% 0;' + '}' + '.telegram-passport-tooltip-wrap.tooltip-top .telegram-passport-tooltip:before {' + 'left: 50%;' + 'bottom: 0;' + 'border: 10px solid;' + 'border-radius: 0 0 4px;' + 'border-color: transparent #949494 #949494 transparent;' + 'transform: rotateZ(45deg) translate3d(-11px,9px,0);' + 'transform-origin: 0 100%;' + '}' + '.telegram-passport-tooltip-wrap.tooltip-left .telegram-passport-tooltip:before {' + 'top: 50%;' + 'right: 0;' + 'border: 8px solid;' + 'border-radius: 0 2px 0 0;' + 'border-color: #949494 #949494 transparent transparent;' + 'transform: rotateZ(45deg) translate3d(4px,-3.5px,0);' + 'transform-origin: 100% 0;' + '}' + '.telegram-passport-tooltip-wrap.tooltip-right .telegram-passport-tooltip:before {' + 'top: 50%;' + 'left: 0;' + 'border: 8px solid;' + 'border-radius: 0 0 0 2px;' + 'border-color: transparent transparent #949494 #949494;' + 'transform: rotateZ(45deg) translate3d(-15px,-7.5px,0);' + 'transform-origin: 0 100%;' + '}'; var tooltipClass = tooltipForce ? 'telegram-passport-tooltip telegram-passport-tooltip-shown' : 'telegram-passport-tooltip'; var btnHtml = '' + '<style>' + btnStyle + '</style>' + '<div class="telegram-passport-tooltip-wrap ' + tooltipWrapClass + '"><a class="' + tooltipClass + '" href="https://telegram.org/dl/" target="_blank">' + tooltipText + '</a></div>' + '<button class="telegram-passport-button"><i class="telegram-passport-button-icon"></i>' + btnText + '</button>'; var btnContEl = document.createElement('div'); btnContEl.className = 'telegram-passport'; btnContEl.innerHTML = btnHtml; contEl.appendChild(btnContEl); var buttonEl = btnContEl.getElementsByTagName('button')[0]; var tooltipEl = btnContEl.getElementsByTagName('a')[0]; addEvent(buttonEl, 'click', function(e) { preventDefault(e); var options = isFunction(authDataOrFunc) ? authDataOrFunc() : authDataOrFunc; options = options || {}; var tooltipToggle = function(show) { if (show) { tooltipEl.classList.add('telegram-passport-tooltip-shown'); } else { tooltipEl.classList.remove('telegram-passport-tooltip-shown'); } }; passportAuth(options, !tooltipForce ? tooltipToggle : null); }); } if (!window.Telegram) { window.Telegram = {}; } window.Telegram.Passport = { auth: passportAuth, createAuthButton: createAuthButton, }; })(window);