| 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
 | /*
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.
*/
/*
 * Main controller
 */
'use strict';
angular.module('MatrixWebClientController', ['matrixService', 'mPresence', 'eventStreamService'])
.controller('MatrixWebClientController', ['$scope', '$location', '$rootScope', 'matrixService', 'mPresence', 'eventStreamService',
                               function($scope, $location, $rootScope, matrixService, mPresence, eventStreamService) {
         
    // Check current URL to avoid to display the logout button on the login page
    $scope.location = $location.path();
    
    // Update the location state when the ng location changed
    $rootScope.$on('$routeChangeSuccess', function (event, current, previous) {
        $scope.location = $location.path();
    });
    if (matrixService.isUserLoggedIn()) {
        // eventStreamService.resume();
        mPresence.start();
    }
    
    $scope.go = function(url) {
        $location.url(url);
    };
    
    // Logs the user out 
    $scope.logout = function() {
        
        // kill the event stream
        eventStreamService.stop();
        // Do not update presence anymore
        mPresence.stop();
        // Clean permanent data
        matrixService.setConfig({});
        matrixService.saveConfig();
        
        // And go to the login page
        $location.url("login");
    };
    // Listen to the event indicating that the access token is no longer valid.
    // In this case, the user needs to log in again.
    $scope.$on("M_UNKNOWN_TOKEN", function() {
        console.log("Invalid access token -> log user out");
        $scope.logout();
    });
    
    $scope.requestNotifications = function() {
        if (window.Notification) {
            console.log("Notification.permission: " + window.Notification.permission);
            window.Notification.requestPermission(function(){});
        }
    };
    
}]);
   
 |