webogram-i2p/app/js/filters.js

238 lines
6.4 KiB
JavaScript
Raw Normal View History

2014-01-05 20:07:11 +04:00
/*!
* Webogram v0.4.6 - 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';
/* Filters */
angular.module('myApp.filters', ['myApp.i18n'])
2014-01-05 20:07:11 +04:00
2014-10-18 21:10:12 +02:00
.filter('userName', function(_) {
2014-01-05 20:07:11 +04:00
return function (user) {
if (!user || !user.first_name && !user.last_name) {
return _('user_name_deleted');
2014-01-05 20:07:11 +04:00
}
return user.first_name + ' ' + user.last_name;
}
2014-10-18 21:10:12 +02:00
})
2014-01-05 20:07:11 +04:00
2014-10-18 21:10:12 +02:00
.filter('userFirstName', function(_) {
2014-01-05 20:07:11 +04:00
return function (user) {
if (!user || !user.first_name && !user.last_name) {
return _('user_first_name_deleted');
2014-01-05 20:07:11 +04:00
}
return user.first_name || user.last_name;
}
2014-10-18 21:10:12 +02:00
})
2014-01-05 20:07:11 +04:00
2014-10-18 21:10:12 +02:00
.filter('userStatus', function($filter, _) {
var relativeTimeFilter = $filter('relativeTime');
2015-07-01 15:46:34 +03:00
return function (user, botChatPrivacy) {
var statusType = user && user.status && user.status._;
if (!statusType) {
statusType = user.pFlags.bot ? 'userStatusBot' : 'userStatusEmpty';
}
switch (statusType) {
case 'userStatusOnline':
return _('user_status_online');
case 'userStatusOffline':
return _('user_status_last_seen', relativeTimeFilter(user.status.was_online));
case 'userStatusRecently':
return _('user_status_recently');
2014-01-05 20:07:11 +04:00
case 'userStatusLastWeek':
return _('user_status_last_week');
case 'userStatusLastMonth':
return _('user_status_last_month');
2015-07-01 15:46:34 +03:00
case 'userStatusBot':
if (botChatPrivacy) {
if (user.pFlags.botNoPrivacy) {
return _('user_status_bot_noprivacy');
} else {
return _('user_status_bot_privacy');
}
}
return _('user_status_bot');
case 'userStatusEmpty':
default:
return _('user_status_long_ago');
}
2014-01-05 20:07:11 +04:00
}
2014-10-18 21:10:12 +02:00
})
2014-01-05 20:07:11 +04:00
2014-10-18 21:10:12 +02:00
.filter('chatTitle', function(_) {
2014-01-05 20:07:11 +04:00
return function (chat) {
if (!chat || !chat.title) {
return _('chat_title_deleted');
2014-01-05 20:07:11 +04:00
}
return chat.title;
}
2014-10-18 21:10:12 +02:00
})
2014-01-05 20:07:11 +04:00
2014-10-18 21:10:12 +02:00
.filter('dateOrTime', function($filter) {
var dateFilter = $filter('date');
2014-11-05 21:37:01 +03:00
return function (timestamp, extended) {
2015-07-08 20:15:11 +03:00
if (!timestamp) {
return '';
}
2014-01-05 20:07:11 +04:00
var ticks = timestamp * 1000,
diff = Math.abs(tsNow() - ticks),
2014-09-29 21:47:19 +04:00
format = 'shortTime';
2014-01-05 20:07:11 +04:00
if (diff > 518400000) { // 6 days
2014-11-05 21:37:01 +03:00
format = extended ? 'mediumDate' : 'shortDate';
2014-01-05 20:07:11 +04:00
}
else if (diff > 43200000) { // 12 hours
2014-11-05 21:37:01 +03:00
format = extended ? 'EEEE' : 'EEE';
2014-01-05 20:07:11 +04:00
}
2014-11-05 21:37:01 +03:00
return dateFilter(ticks, format);
2014-01-05 20:07:11 +04:00
}
2014-10-18 21:10:12 +02:00
})
2014-01-05 20:07:11 +04:00
2014-10-18 21:10:12 +02:00
.filter('time', function($filter) {
var cachedDates = {},
dateFilter = $filter('date'),
2014-09-29 21:47:19 +04:00
format = Config.Mobile ? 'shortTime' : 'mediumTime';
return function (timestamp) {
if (cachedDates[timestamp]) {
return cachedDates[timestamp];
}
return cachedDates[timestamp] = dateFilter(timestamp * 1000, format);
2014-07-12 15:30:08 +04:00
}
2014-10-18 21:10:12 +02:00
})
2014-07-12 15:30:08 +04:00
2014-10-18 21:10:12 +02:00
.filter('myDate', function($filter) {
var cachedDates = {},
dateFilter = $filter('date');
return function (timestamp) {
if (cachedDates[timestamp]) {
return cachedDates[timestamp];
}
return cachedDates[timestamp] = dateFilter(timestamp * 1000, 'fullDate');
}
2014-10-18 21:10:12 +02:00
})
2014-01-05 20:07:11 +04:00
.filter('duration', [function() {
return function (duration) {
duration = parseInt(duration);
if (isNaN(duration)) {
duration = 0;
}
2014-01-05 20:07:11 +04:00
var secs = duration % 60,
mins = Math.floor((duration - secs) / 60.0);
if (secs < 10) {
secs = '0' + secs;
}
return mins + ':' + secs;
}
}])
2014-11-05 21:37:01 +03:00
.filter('durationRemains', function($filter) {
var durationFilter = $filter('duration');
return function (done, total) {
return '-' + durationFilter(total - done);
}
})
2014-01-05 20:07:11 +04:00
.filter('phoneNumber', [function() {
return function (phoneRaw) {
2014-03-26 10:47:01 +04:00
var nbsp = ' ';
phoneRaw = (phoneRaw || '').replace(/\D/g, '');
if (phoneRaw.charAt(0) == '7' && phoneRaw.length == 11) {
2014-03-26 10:47:01 +04:00
return '+' + phoneRaw.charAt(0) + nbsp + '(' + phoneRaw.substr(1, 3) + ')' + nbsp + phoneRaw.substr(4, 3) + '-' + phoneRaw.substr(7, 2) + '-' + phoneRaw.substr(9, 2);
2014-01-05 20:07:11 +04:00
}
return '+' + phoneRaw;
}
}])
.filter('formatSize', [function () {
2014-10-18 21:10:12 +02:00
return function (size, progressing) {
if (!size) {
return '0';
}
else if (size < 1024) {
return size + ' b';
}
else if (size < 1048576) {
2015-06-30 14:17:52 +03:00
return Math.round(size / 1024) + ' KB';
}
2014-10-18 21:10:12 +02:00
var mbs = size / 1048576;
if (progressing) {
mbs = mbs.toFixed(1);
} else {
2014-11-05 21:37:01 +03:00
mbs = (Math.round(mbs * 10) / 10);
2014-10-18 21:10:12 +02:00
}
return mbs + ' Mb';
}
}])
2014-10-18 21:10:12 +02:00
.filter('formatSizeProgress', function ($filter, _) {
var formatSizeFilter = $filter('formatSize');
return function (progress) {
2014-10-18 21:10:12 +02:00
var done = formatSizeFilter(progress.done, true),
doneParts = done.split(' '),
2014-10-18 21:10:12 +02:00
total = formatSizeFilter(progress.total),
totalParts = total.split(' ');
if (totalParts[1] === doneParts[1]) {
2014-09-23 21:04:10 +04:00
return _('format_size_progress_mulitple', {done: doneParts[0], total: totalParts[0], parts: (doneParts[1] || '')});
}
return _('format_size_progress', {done: done, total: total});
2014-01-05 20:07:11 +04:00
}
2014-10-18 21:10:12 +02:00
})
2014-01-05 20:07:11 +04:00
.filter('nl2br', [function () {
return function (text) {
return text.replace(/\n/g, '<br/>');
}
}])
2014-10-18 21:10:12 +02:00
.filter('richText', function ($filter) {
var linkyFilter = $filter('linky');
2014-01-05 20:07:11 +04:00
return function (text) {
2014-10-18 21:10:12 +02:00
return linkyFilter(text, '_blank').replace(/\n|&#10;/g, '<br/>');
2014-01-05 20:07:11 +04:00
}
2014-10-18 21:10:12 +02:00
})
2014-01-05 20:07:11 +04:00
2014-10-18 21:10:12 +02:00
.filter('relativeTime', function($filter, _) {
2014-10-02 15:59:06 +04:00
var langMinutesPluralize = _.pluralize('relative_time_pluralize_minutes_ago'),
2014-10-18 21:10:12 +02:00
langHoursPluralize = _.pluralize('relative_time_pluralize_hours_ago'),
dateOrTimeFilter = $filter('dateOrTime');
2014-01-05 20:07:11 +04:00
return function (timestamp) {
var ticks = timestamp * 1000,
diff = Math.abs(tsNow() - ticks);
2014-01-05 20:07:11 +04:00
if (diff < 60000) {
return _('relative_time_just_now');
2014-01-05 20:07:11 +04:00
}
2014-11-05 21:37:01 +03:00
if (diff < 3600000) {
var minutes = Math.floor(diff / 60000);
2014-10-02 15:59:06 +04:00
return langMinutesPluralize(minutes);
2014-01-05 20:07:11 +04:00
}
2014-11-05 21:37:01 +03:00
if (diff < 86400000) {
var hours = Math.floor(diff / 3600000);
2014-10-02 15:59:06 +04:00
return langHoursPluralize(hours);
2014-01-05 20:07:11 +04:00
}
2014-11-05 21:37:01 +03:00
return dateOrTimeFilter(timestamp, true);
2014-01-05 20:07:11 +04:00
}
2014-10-18 21:10:12 +02:00
})