~webapps/unity-webapps-qml/trunk

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
window.onload = function() {
    document.getElementById('refreshAccounts').addEventListener('click', listAccounts);

    var api = external.getUnityObject('1.0');
    var oa = api.OnlineAccounts;

    var appId = "shotwell";

    oa.api.getProviders({"applicationId": appId}, function(providers) {
        var ul = document.querySelector('#providers ul');

        for (var i = 0; i < providers.length; ++i) {
            var li = document.createElement('li');
            var button = document.createElement('input');
            button.type = 'button';
            button.providerId = providers[i].providerId;
            button.value = 'Request account';
            button.addEventListener('click', function() {
                oa.api.requestAccount(appId, this.providerId, function() {});
            });
            li.innerHTML = 'displayName: ' + providers[i].displayName
                    + ', providerId: ' + providers[i].providerId;
            li.appendChild(button);
            ul.appendChild(li);
        }
    });

    function listAccounts() {
        var filters = {};
        var service = document.getElementById('service').value;
        if (service) {
            filters['service'] = service
        }
        var provider = document.getElementById('provider').value;
        if (provider) {
            filters['provider'] = provider
        }

        oa.api.getAccounts(filters, function(accounts) {
            var ul = document.querySelector('#accounts ul');
            if (accounts.length === 0) {
                var li = document.createElement('li');
                li.appendChild(document.createTextNode('No accounts found'));
                ul.appendChild(li);
            }
            else {
                for(var i = 0; i < accounts.length; ++i) {
                    var li = document.createElement('li');
                    li.innerHTML = 'id: ' + accounts[i].accountId()
                            + ', name: ' + accounts[i].displayName()
                            + ', provider: ' + JSON.stringify(accounts[i].provider())
                            + ', service: ' + JSON.stringify(accounts[i].service());
                    ul.appendChild(li);

                    (function(i) {
                        function authcallback(results) {
                            setResults('Authentication result: ' + JSON.stringify(results));
                        };

                        li.addEventListener('click', function() {
                            accounts[i].authenticate(authcallback);
                        });
                    })(i);
                }
            }
        });
    }

    function setResults(data) {
        var results = document.getElementById('results');
        results.innerHTML += data;
    };
};