mirror of
https://mau.dev/maunium/synapse.git
synced 2024-12-14 12:13:52 +01:00
166 lines
6 KiB
JavaScript
166 lines
6 KiB
JavaScript
/*
|
|
Copyright 2014 matrix.org
|
|
|
|
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
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
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.
|
|
*/
|
|
|
|
var matrixWebClient = angular.module('matrixWebClient', [
|
|
'ngRoute',
|
|
'MatrixWebClientController',
|
|
'LoginController',
|
|
'RoomController',
|
|
'RoomsController',
|
|
'UserController',
|
|
'matrixService',
|
|
'eventStreamService',
|
|
'eventHandlerService',
|
|
'infinite-scroll'
|
|
]);
|
|
|
|
matrixWebClient.config(['$routeProvider', '$provide', '$httpProvider',
|
|
function($routeProvider, $provide, $httpProvider) {
|
|
$routeProvider.
|
|
when('/login', {
|
|
templateUrl: 'login/login.html',
|
|
controller: 'LoginController'
|
|
}).
|
|
when('/room/:room_id_or_alias', {
|
|
templateUrl: 'room/room.html',
|
|
controller: 'RoomController'
|
|
}).
|
|
when('/room/', { // room URL with room alias in it (ex: http://127.0.0.1:8000/#/room/#public:localhost:8080) will come here.
|
|
// The reason is that 2nd hash key breaks routeProvider parameters cutting so that the URL will not match with
|
|
// the previous '/room/:room_id_or_alias' URL rule
|
|
templateUrl: 'room/room.html',
|
|
controller: 'RoomController'
|
|
}).
|
|
when('/rooms', {
|
|
templateUrl: 'rooms/rooms.html',
|
|
controller: 'RoomsController'
|
|
}).
|
|
when('/user/:user_matrix_id', {
|
|
templateUrl: 'user/user.html',
|
|
controller: 'UserController'
|
|
}).
|
|
otherwise({
|
|
redirectTo: '/rooms'
|
|
});
|
|
|
|
$provide.factory('AccessTokenInterceptor', ['$q', '$rootScope',
|
|
function ($q, $rootScope) {
|
|
return {
|
|
responseError: function(rejection) {
|
|
if (rejection.status === 403 && "data" in rejection &&
|
|
"errcode" in rejection.data &&
|
|
rejection.data.errcode === "M_UNKNOWN_TOKEN") {
|
|
console.log("Got a 403 with an unknown token. Logging out.")
|
|
$rootScope.$broadcast("M_UNKNOWN_TOKEN");
|
|
}
|
|
return $q.reject(rejection);
|
|
}
|
|
};
|
|
}]);
|
|
$httpProvider.interceptors.push('AccessTokenInterceptor');
|
|
}]);
|
|
|
|
matrixWebClient.run(['$location', 'matrixService', 'eventStreamService', function($location, matrixService, eventStreamService) {
|
|
// If user auth details are not in cache, go to the login page
|
|
if (!matrixService.isUserLoggedIn()) {
|
|
eventStreamService.stop();
|
|
$location.path("login");
|
|
}
|
|
else {
|
|
eventStreamService.resume();
|
|
}
|
|
}]);
|
|
|
|
matrixWebClient
|
|
.directive('ngEnter', function () {
|
|
return function (scope, element, attrs) {
|
|
element.bind("keydown keypress", function (event) {
|
|
if(event.which === 13) {
|
|
scope.$apply(function () {
|
|
scope.$eval(attrs.ngEnter);
|
|
});
|
|
event.preventDefault();
|
|
}
|
|
});
|
|
};
|
|
})
|
|
.directive('ngFocus', ['$timeout', function($timeout) {
|
|
return {
|
|
link: function(scope, element, attr) {
|
|
$timeout(function() { element[0].focus() }, 0);
|
|
}
|
|
};
|
|
}])
|
|
.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 );
|
|
if (value["displayname"]) {
|
|
if (!displayNames[value["displayname"]]) {
|
|
displayNames[value["displayname"]] = [];
|
|
}
|
|
displayNames[value["displayname"]].push(key);
|
|
}
|
|
});
|
|
|
|
// FIXME: we shouldn't disambiguate displayNames on every orderMembersList
|
|
// invocation but keep track of duplicates incrementally somewhere
|
|
angular.forEach(displayNames, function(value, key) {
|
|
if (value.length > 1) {
|
|
// console.log(key + ": " + value);
|
|
for (i=0; i < value.length; i++) {
|
|
var v = value[i];
|
|
members[v].displayname += " (" + v + ")";
|
|
// console.log(v + " " + members[v]);
|
|
};
|
|
}
|
|
});
|
|
|
|
filtered.sort(function (a, b) {
|
|
return ((a["mtime_age"] || 10e10) > (b["mtime_age"] || 10e10) ? 1 : -1);
|
|
});
|
|
return filtered;
|
|
};
|
|
})
|
|
.filter('unsafe', ['$sce', function($sce) {
|
|
return function(text) {
|
|
return $sce.trustAsHtml(text);
|
|
};
|
|
}]);
|