Statistics
| Branch: | Tag: | Revision:

root / snf-astakos-app / astakos / im / static / im / cloudbar / cloudbar.js @ 7f7863bb

History | View | Annotate | Download (5.4 kB)

1
function equalWidths ( secondEl, firstEl) {
2
        secondEl.css('width',firstEl.outerWidth() );
3
}
4

    
5

    
6

    
7
$(document).ready(function(){
8
    
9
    /*
10
    * LINKS CONFIGURATION
11
    */
12

    
13
    var PROFILE_URL = "https://accounts.cloud.grnet.gr";
14

    
15
    // cookie plugin https://raw.github.com/carhartl/jquery-cookie/master/jquery.cookie.js 
16
    //  * Copyright (c) 2010 Klaus Hartl, @carhartl
17
    //  * Dual licensed under the MIT and GPL licenses
18
    var cookie=function(key,value,options){if(arguments.length>1&&(!/Object/.test(Object.prototype.toString.call(value))||value===null||value===undefined)){options=$.extend({},options);if(value===null||value===undefined){options.expires=-1}if(typeof options.expires==='number'){var days=options.expires,t=options.expires=new Date();t.setDate(t.getDate()+days)}value=String(value);return(document.cookie=[encodeURIComponent(key),'=',options.raw?value:encodeURIComponent(value),options.expires?'; expires='+options.expires.toUTCString():'',options.path?'; path='+options.path:'',options.domain?'; domain='+options.domain:'',options.secure?'; secure':''].join(''))}options=value||{};var decode=options.raw?function(s){return s}:decodeURIComponent;var pairs=document.cookie.split('; ');for(var i=0,pair;pair=pairs[i]&&pairs[i].split('=');i++){if(decode(pair[0])===key)return decode(pair[1]||'')}return null};
19

    
20
    var ACTIVE_MENU = window.CLOUDBAR_ACTIVE_SERVICE || 'cloud';
21
    var USER_DATA = window.CLOUDBAR_USER_DATA || {'user': 'Not logged in', 'logged_in': false};
22
    var COOKIE_NAME = window.CLOUDBAR_COOKIE_NAME || '_pithos2_a';
23

    
24
    var cssloc = window.CLOUDBAR_LOCATION || "http://127.0.0.1:8989/";
25
    
26
    // load css
27
    var css = $("<link />");
28
    css.attr({rel:'stylesheet', type:'text/css', href:cssloc + 'cloudbar.css'});
29
    $("head").append(css);
30
    
31
    // load fonts
32
    var font_url = 'https://fonts.googleapis.com/css?family=Open+Sans:400,600,700&subset=latin,greek-ext,greek';
33
    var css_font = $("<link />");
34
    css_font.attr({rel:'stylesheet', type:'text/css', href:font_url});
35
    $("head").append(css_font);
36

    
37
    // load service specific css
38
    var SKIP_ADDITIONAL_CSS = window.SKIP_ADDITIONAL_CSS == undefined ? false : window.SKIP_ADDITIONAL_CSS;
39

    
40
    if (!SKIP_ADDITIONAL_CSS) {
41
        var css = $("<link />");
42
        css.attr({rel:'stylesheet', type:'text/css', href:cssloc + 'service_' + ACTIVE_MENU + '.css'});
43
        $("head").append(css);
44
    }
45

    
46
    var root = $('body');
47
    var bar = $('<div class="cloudbar servicesbar clearfix"></div>');
48
    var services = $('<ul class="services"></ul>');
49
    var profile = $('<div class="profile"></div>');
50
    
51
    var get_services_url = window.GET_SERVICES_URL || window.CLOUDBAR_SERVICES;
52
    
53
    // create services links and set the active class to the current service
54
    $.getJSON(get_services_url + "?callback=?", function(data) {
55
            $.each(data, function(i, el){
56
            var sli = $("<li>");
57
            var slink = $("<a>");
58
            if (el.icon) {
59
                slink.append($('<img src="'+cssloc+el.icon+'"/>'));
60
                slink.addClass("with-icon");
61
            } else {
62
                slink.text(el.name);
63
            }
64
            slink.attr('href', el.url);
65
            slink.attr('title', el.name);
66
            sli.append(slink);
67
            services.append(sli);
68
            if (el.id == ACTIVE_MENU || el.name == ACTIVE_MENU) {
69
                sli.addClass("active");
70
            }
71
        });
72
      });
73
    
74
    // create profile links
75
    var user = $('<div class="user"></div>');    
76
    if (ACTIVE_MENU == "accounts") { user.addClass("hover active")}
77
    var username = $('<a href="#"></a>');
78
    var usermenu = $("<ul>");
79
    var get_menu_url = (window.GET_MENU_URL || window.CLOUDBAR_MENU) + '?callback=?&location=' + window.location.toString();
80

    
81
    $.getJSON(get_menu_url, function(data) {
82
        $.each(data, function(i,el) {
83
            if (i == 0){
84
                username.html('<span>'+el.name+'</span>');
85
                username.attr('href', el.url);
86
                user.removeClass('full');
87
            }else{
88
                var link = $("<a />");
89
                link.text(el.name);
90
                link.attr({href:el.url});
91
                var li = $("<li />");
92
                li.append(link);
93
                usermenu.append(li);
94
                user.addClass('full');
95
            }
96
        });
97
    });
98
    
99
    //profile.filter(".user a").attr("href", 
100
                                   //profile.find("li a").get(0).attr("href"))
101
    
102
    user.append(username);
103
    user.append(usermenu);
104
    profile.append(user);
105
    bar.append(profile).append(services);
106
    
107

    
108
    root.css('border-top', 'none');
109
    root.prepend(bar);
110
    var firstlink = profile.find("ul li:first-child a").attr("href");
111
    profile.find(".user > a").attr("href", firstlink);
112

    
113
    // ie fix
114
    user.hover(function(){$(this).addClass("hover")}, function(){$(this).removeClass("hover")});
115
    $('html').live('click', function(e){
116
                 $('.cloudbar .profile .full>a').removeClass('open');
117
                 $('.cloudbar .profile .full>a').siblings('ul').hide();
118
        });
119
 
120
   
121
           $('.cloudbar .profile .full>a').live('click', function(e){
122
                   
123
                   e.stopPropagation();
124
        e.preventDefault();
125
        equalWidths ( $('.cloudbar .profile ul'), $('.cloudbar .profile'));
126
                   $(this).siblings('ul').toggle();
127
                   $(this).toggleClass('open');
128
                   
129
           });
130

    
131
    
132
});
133

    
134
$(window).resize(function() {
135
        equalWidths ( $('.cloudbar .profile ul'), $('.cloudbar .profile'));
136
});