mirror of
https://git.anonymousland.org/anonymousland/synapse-product.git
synced 2024-12-24 16:59:27 -05:00
1bc036a12d
- add a simple CSS template across the app for navigation & cosmetics - split login into login & register, and totally reskin it - restructure room CSS to play nicely with it - implement basis 1:1 chat from user pages - disable autofocus on iOS to improve UX
100 lines
3.6 KiB
JavaScript
100 lines
3.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',
|
|
'RegisterController',
|
|
'RoomController',
|
|
'HomeController',
|
|
'RecentsController',
|
|
'SettingsController',
|
|
'UserController',
|
|
'matrixService',
|
|
'matrixPhoneService',
|
|
'MatrixCall',
|
|
'eventStreamService',
|
|
'eventHandlerService',
|
|
'infinite-scroll'
|
|
]);
|
|
|
|
matrixWebClient.config(['$routeProvider', '$provide', '$httpProvider',
|
|
function($routeProvider, $provide, $httpProvider) {
|
|
$routeProvider.
|
|
when('/login', {
|
|
templateUrl: 'login/login.html',
|
|
controller: 'LoginController'
|
|
}).
|
|
when('/register', {
|
|
templateUrl: 'login/register.html',
|
|
controller: 'RegisterController'
|
|
}).
|
|
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('/', {
|
|
templateUrl: 'home/home.html',
|
|
controller: 'HomeController'
|
|
}).
|
|
when('/settings', {
|
|
templateUrl: 'settings/settings.html',
|
|
controller: 'SettingsController'
|
|
}).
|
|
when('/user/:user_matrix_id', {
|
|
templateUrl: 'user/user.html',
|
|
controller: 'UserController'
|
|
}).
|
|
otherwise({
|
|
redirectTo: '/'
|
|
});
|
|
|
|
$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', function($location, matrixService) {
|
|
|
|
// If user auth details are not in cache, go to the login page
|
|
if (!matrixService.isUserLoggedIn() &&
|
|
$location.path() !== "/login" &&
|
|
$location.path() !== "/register")
|
|
{
|
|
$location.path("login");
|
|
}
|
|
|
|
}]);
|