2014-01-05 20:07:11 +04:00
|
|
|
/*!
|
2014-08-02 00:10:04 +01:00
|
|
|
* Webogram v0.2.9 - messaging web application for MTProto
|
2014-01-05 20:07:11 +04:00
|
|
|
* https://github.com/zhukov/webogram
|
|
|
|
* Copyright (C) 2014 Igor Zhukov <igor.beatle@gmail.com>
|
|
|
|
* https://github.com/zhukov/webogram/blob/master/LICENSE
|
|
|
|
*/
|
|
|
|
|
|
|
|
'use strict';
|
|
|
|
|
|
|
|
// Declare app level module which depends on filters, and services
|
|
|
|
angular.module('myApp', [
|
|
|
|
'ngRoute',
|
|
|
|
'ngSanitize',
|
2014-07-01 22:46:16 +04:00
|
|
|
'ngTouch',
|
2014-01-05 20:07:11 +04:00
|
|
|
'ui.bootstrap',
|
2014-06-20 19:34:14 +04:00
|
|
|
'izhukov.utils',
|
|
|
|
'izhukov.mtproto',
|
|
|
|
'izhukov.mtproto.wrapper',
|
2014-01-05 20:07:11 +04:00
|
|
|
'myApp.filters',
|
|
|
|
'myApp.services',
|
2014-03-12 22:55:12 +01:00
|
|
|
/*PRODUCTION_ONLY_BEGIN
|
|
|
|
'myApp.templates',
|
|
|
|
PRODUCTION_ONLY_END*/
|
2014-01-05 20:07:11 +04:00
|
|
|
'myApp.directives',
|
|
|
|
'myApp.controllers'
|
|
|
|
]).
|
2014-06-20 19:34:14 +04:00
|
|
|
config(['$locationProvider', '$routeProvider', '$compileProvider', 'StorageProvider', function($locationProvider, $routeProvider, $compileProvider, StorageProvider) {
|
2014-01-05 20:07:11 +04:00
|
|
|
|
2014-03-01 14:58:30 +02:00
|
|
|
var icons = {}, reverseIcons = {}, i, j, hex, name, dataItem, row, column, totalColumns;
|
2014-01-05 20:07:11 +04:00
|
|
|
|
2014-03-01 14:58:30 +02:00
|
|
|
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];
|
2014-01-05 20:07:11 +04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-03-01 14:58:30 +02:00
|
|
|
$.emojiarea.spritesheetPath = 'img/emojisprite_!.png';
|
|
|
|
$.emojiarea.spritesheetDimens = Config.EmojiCategorySpritesheetDimens;
|
|
|
|
$.emojiarea.iconSize = 20;
|
2014-01-05 20:07:11 +04:00
|
|
|
$.emojiarea.icons = icons;
|
|
|
|
$.emojiarea.reverseIcons = reverseIcons;
|
|
|
|
|
2014-02-01 16:54:31 +04:00
|
|
|
$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\//);
|
2014-01-05 20:07:11 +04:00
|
|
|
|
2014-06-25 15:24:47 +04:00
|
|
|
if (Config.Modes.test) {
|
|
|
|
StorageProvider.setPrefix('t_');
|
|
|
|
}
|
2014-01-05 20:07:11 +04:00
|
|
|
|
2014-03-09 18:12:41 -03:00
|
|
|
$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});
|
2014-01-05 20:07:11 +04:00
|
|
|
$routeProvider.otherwise({redirectTo: '/'});
|
|
|
|
|
|
|
|
}]);
|
2014-06-25 15:24:47 +04:00
|
|
|
|
|
|
|
|
|
|
|
(function () {
|
|
|
|
var classes = [
|
|
|
|
Config.Navigator.osX ? 'osx' : 'non_osx',
|
|
|
|
Config.Navigator.retina ? 'is_2x' : 'is_1x'
|
|
|
|
];
|
|
|
|
if (Config.Modes.ios_standalone) {
|
|
|
|
classes.push('ios_standalone');
|
|
|
|
}
|
|
|
|
$(document.body).addClass(classes.join(' '));
|
2014-07-01 22:46:16 +04:00
|
|
|
})();
|