Telegram Web, preconfigured for usage in I2P.
http://web.telegram.i2p/
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
76 lines
2.7 KiB
76 lines
2.7 KiB
/*! |
|
* Webogram v0.1.2 - messaging web application for MTProto |
|
* https://github.com/zhukov/webogram |
|
* Copyright (C) 2014 Igor Zhukov <igor.beatle@gmail.com> |
|
* https://github.com/zhukov/webogram/blob/master/LICENSE |
|
*/ |
|
|
|
'use strict'; |
|
|
|
window._testMode = location.search.indexOf('test=1') > 0; |
|
window._debugMode = location.search.indexOf('debug=1') > 0; |
|
window._osX = (navigator.platform || '').toLowerCase().indexOf('mac') != -1 || |
|
(navigator.userAgent || '').toLowerCase().indexOf('mac') != -1; |
|
window._retina = window.devicePixelRatio > 1; |
|
window._mobile = $(window).height() < 600; |
|
|
|
if (!window._osX) { |
|
$('body').addClass('non_osx'); |
|
} |
|
$('body').addClass(window._retina ? 'is_2x' : 'is_1x'); |
|
|
|
$(window).on('load', function () { |
|
setTimeout(function () { |
|
window.scrollTo(0,1); |
|
}, 0); |
|
}); |
|
|
|
// Declare app level module which depends on filters, and services |
|
angular.module('myApp', [ |
|
'ngRoute', |
|
'ngAnimate', |
|
'ngSanitize', |
|
'ui.bootstrap', |
|
'pasvaz.bindonce', |
|
'mtproto.services', |
|
'myApp.filters', |
|
'myApp.services', |
|
/*PRODUCTION_ONLY_BEGIN |
|
'myApp.templates', |
|
PRODUCTION_ONLY_END*/ |
|
'myApp.directives', |
|
'myApp.controllers' |
|
]). |
|
config(['$locationProvider', '$routeProvider', '$compileProvider', function($locationProvider, $routeProvider, $compileProvider) { |
|
|
|
var icons = {}, reverseIcons = {}, i, j, hex, name, dataItem, row, column, totalColumns; |
|
|
|
for (j = 0; j < Config.EmojiCategories.length; j++) { |
|
totalColumns = Config.EmojiCategorySpritesheetDimens[j][1]; |
|
for (i = 0; i < Config.EmojiCategories[j].length; i++) { |
|
dataItem = Config.Emoji[Config.EmojiCategories[j][i]]; |
|
name = dataItem[1][0]; |
|
row = Math.floor(i / totalColumns); |
|
column = (i % totalColumns); |
|
icons[':' + name + ':'] = [j, row, column, ':'+name+':']; |
|
reverseIcons[name] = dataItem[0]; |
|
} |
|
} |
|
|
|
$.emojiarea.spritesheetPath = 'img/emojisprite_!.png'; |
|
$.emojiarea.spritesheetDimens = Config.EmojiCategorySpritesheetDimens; |
|
$.emojiarea.iconSize = 20; |
|
$.emojiarea.icons = icons; |
|
$.emojiarea.reverseIcons = reverseIcons; |
|
|
|
$compileProvider.imgSrcSanitizationWhitelist(/^\s*(https?|ftp|file|blob|filesystem|chrome-extension|app):|data:image\//); |
|
$compileProvider.aHrefSanitizationWhitelist(/^\s*(https?|ftp|file|mailto|blob|filesystem|chrome-extension|app):|data:image\//); |
|
|
|
|
|
// $locationProvider.html5Mode(true); |
|
$routeProvider.when('/', {templateUrl: 'partials/welcome.html', controller: 'AppWelcomeController'}); |
|
$routeProvider.when('/login', {templateUrl: 'partials/login.html', controller: 'AppLoginController'}); |
|
$routeProvider.when('/im', {templateUrl: 'partials/im.html', controller: 'AppIMController', reloadOnSearch: false}); |
|
$routeProvider.otherwise({redirectTo: '/'}); |
|
|
|
}]);
|
|
|