2014-08-20 11:28:36 +02:00
|
|
|
/*
|
2014-09-03 18:29:13 +02:00
|
|
|
Copyright 2014 OpenMarket Ltd
|
2014-10-15 15:42:14 +02:00
|
|
|
|
2014-08-20 11:28:36 +02:00
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
you may not use this file except in compliance with the License.
|
|
|
|
You may obtain a copy of the License at
|
2014-10-15 15:42:14 +02:00
|
|
|
|
2014-08-20 11:28:36 +02:00
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
2014-10-15 15:42:14 +02:00
|
|
|
|
2014-08-20 11:28:36 +02:00
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
See the License for the specific language governing permissions and
|
|
|
|
limitations under the License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
'use strict';
|
|
|
|
|
|
|
|
angular.module('matrixWebClient')
|
|
|
|
.filter('duration', function() {
|
|
|
|
return function(time) {
|
|
|
|
if (!time) return;
|
|
|
|
var t = parseInt(time / 1000);
|
|
|
|
var s = t % 60;
|
|
|
|
var m = parseInt(t / 60) % 60;
|
|
|
|
var h = parseInt(t / (60 * 60)) % 24;
|
|
|
|
var d = parseInt(t / (60 * 60 * 24));
|
|
|
|
if (t < 60) {
|
|
|
|
return s + "s";
|
|
|
|
}
|
|
|
|
if (t < 60 * 60) {
|
|
|
|
return m + "m "; // + s + "s";
|
|
|
|
}
|
|
|
|
if (t < 24 * 60 * 60) {
|
|
|
|
return h + "h "; // + m + "m";
|
|
|
|
}
|
|
|
|
return d + "d "; // + h + "h";
|
|
|
|
};
|
|
|
|
})
|
|
|
|
.filter('orderMembersList', function($sce) {
|
|
|
|
return function(members) {
|
|
|
|
var filtered = [];
|
|
|
|
|
|
|
|
var displayNames = {};
|
|
|
|
angular.forEach(members, function(value, key) {
|
|
|
|
value["id"] = key;
|
|
|
|
filtered.push( value );
|
|
|
|
});
|
|
|
|
|
|
|
|
filtered.sort(function (a, b) {
|
2014-09-23 17:25:37 +02:00
|
|
|
// Sort members on their last_active absolute time
|
|
|
|
var aLastActiveTS = 0, bLastActiveTS = 0;
|
|
|
|
if (undefined !== a.last_active_ago) {
|
|
|
|
aLastActiveTS = a.last_updated - a.last_active_ago;
|
|
|
|
}
|
|
|
|
if (undefined !== b.last_active_ago) {
|
|
|
|
bLastActiveTS = b.last_updated - b.last_active_ago;
|
|
|
|
}
|
|
|
|
if (aLastActiveTS || bLastActiveTS) {
|
|
|
|
return bLastActiveTS - aLastActiveTS;
|
2014-09-23 15:18:45 +02:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
// If they do not have last_active_ago, sort them according to their presence state
|
|
|
|
// Online users go first amongs members who do not have last_active_ago
|
|
|
|
var presenceLevels = {
|
|
|
|
offline: 1,
|
|
|
|
unavailable: 2,
|
|
|
|
online: 4,
|
|
|
|
free_for_chat: 3
|
|
|
|
};
|
|
|
|
var aPresence = (a.presence in presenceLevels) ? presenceLevels[a.presence] : 0;
|
|
|
|
var bPresence = (b.presence in presenceLevels) ? presenceLevels[b.presence] : 0;
|
|
|
|
return bPresence - aPresence;
|
|
|
|
}
|
2014-08-20 11:28:36 +02:00
|
|
|
});
|
|
|
|
return filtered;
|
|
|
|
};
|
|
|
|
})
|
2014-10-30 12:14:29 +01:00
|
|
|
.filter('stateEventsFilter', function($sce) {
|
|
|
|
return function(events) {
|
|
|
|
var filtered = {};
|
|
|
|
angular.forEach(events, function(value, key) {
|
|
|
|
if (value && typeof(value.state_key) === "string") {
|
|
|
|
filtered[key] = value;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
return filtered;
|
|
|
|
};
|
|
|
|
})
|
2014-08-20 11:28:36 +02:00
|
|
|
.filter('unsafe', ['$sce', function($sce) {
|
|
|
|
return function(text) {
|
|
|
|
return $sce.trustAsHtml(text);
|
|
|
|
};
|
2014-10-15 15:42:14 +02:00
|
|
|
}])
|
|
|
|
// Exactly the same as ngSanitize's linky but instead of pushing sanitized
|
2014-10-15 15:45:38 +02:00
|
|
|
// text in the addText function, we just push the raw text.
|
2014-10-15 15:42:14 +02:00
|
|
|
.filter('unsanitizedLinky', ['$sanitize', function($sanitize) {
|
|
|
|
var LINKY_URL_REGEXP =
|
|
|
|
/((ftp|https?):\/\/|(mailto:)?[A-Za-z0-9._%+-]+@)\S*[^\s.;,(){}<>"]/,
|
|
|
|
MAILTO_REGEXP = /^mailto:/;
|
|
|
|
|
|
|
|
return function(text, target) {
|
|
|
|
if (!text) return text;
|
|
|
|
var match;
|
|
|
|
var raw = text;
|
|
|
|
var html = [];
|
|
|
|
var url;
|
|
|
|
var i;
|
|
|
|
while ((match = raw.match(LINKY_URL_REGEXP))) {
|
|
|
|
// We can not end in these as they are sometimes found at the end of the sentence
|
|
|
|
url = match[0];
|
|
|
|
// if we did not match ftp/http/mailto then assume mailto
|
|
|
|
if (match[2] == match[3]) url = 'mailto:' + url;
|
|
|
|
i = match.index;
|
|
|
|
addText(raw.substr(0, i));
|
|
|
|
addLink(url, match[0].replace(MAILTO_REGEXP, ''));
|
|
|
|
raw = raw.substring(i + match[0].length);
|
|
|
|
}
|
|
|
|
addText(raw);
|
|
|
|
return $sanitize(html.join(''));
|
|
|
|
|
|
|
|
function addText(text) {
|
|
|
|
if (!text) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
html.push(text);
|
|
|
|
}
|
|
|
|
|
|
|
|
function addLink(url, text) {
|
|
|
|
html.push('<a ');
|
|
|
|
if (angular.isDefined(target)) {
|
|
|
|
html.push('target="');
|
|
|
|
html.push(target);
|
|
|
|
html.push('" ');
|
|
|
|
}
|
|
|
|
html.push('href="');
|
|
|
|
html.push(url);
|
|
|
|
html.push('">');
|
|
|
|
addText(text);
|
|
|
|
html.push('</a>');
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}]);
|