integration/v2/js/keyword-mosaic.js
author veltr
Thu, 27 Jun 2013 16:29:10 +0200
changeset 181 f0dc53d8b462
parent 179 b7fabb9e5d9f
child 182 dde608cfd823
permissions -rw-r--r--
Updated styles for mosaic filtering
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
179
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
     1
$(function() {
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
     2
    
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
     3
    $('.masonry-177').masonry({
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
     4
        columnWidth: 177,
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
     5
        itemSelector: '.item-masonry'
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
     6
    });
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
     7
    
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
     8
    function updateMasonry() {
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
     9
        $('.masonry-177').data('masonry').layout();
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    10
    }
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    11
    
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    12
    var keywordsobj = {};
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    13
    
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    14
    $(".item-masonry").each(function(i, element) {
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    15
        $(element)
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    16
            .attr("data-keywords")
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    17
            .split(",")
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    18
            .forEach(function(kw) {
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    19
                var keyword = kw.replace(/(^\s+|\s+$)/g,''),
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    20
                    basekw = keyword.toLowerCase();
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    21
                if (!keywordsobj.hasOwnProperty(basekw)) {
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    22
                    keywordsobj[basekw] = {
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    23
                        keyword: keyword,
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    24
                        basekeyword: basekw,
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    25
                        count: 0,
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    26
                        items: $(),
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    27
                        enabled: true
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    28
                    };
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    29
                }
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    30
                kwobj = keywordsobj[basekw];
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    31
                kwobj.count++;
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    32
                kwobj.items.push(element);
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    33
            });
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    34
    });
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    35
    
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    36
    var keywordslist = [];
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    37
    
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    38
    for (var k in keywordsobj) {
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    39
        if (keywordsobj.hasOwnProperty(k)) {
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    40
            keywordslist.push(keywordsobj[k]);
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    41
        }
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    42
    }
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    43
    
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    44
    keywordslist.sort(function(a, b) {
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    45
        return b.count - a.count;
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    46
    });
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    47
    
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    48
    var filterlist = $(".filters");
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    49
    
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    50
    function updateKeywords() {
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    51
        var enabledItems = $();
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    52
        keywordslist.forEach(function(kw) {
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    53
            if (kw.enabled) {
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    54
                enabledItems = enabledItems.add(kw.items);
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    55
                kw.li.removeClass("disabled");
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    56
            } else {
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    57
                kw.li.addClass("disabled");
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    58
            }
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    59
        });
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    60
        $(".item-masonry").addClass("disabled");
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    61
        enabledItems.removeClass("disabled");
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    62
    }
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    63
    
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    64
    keywordslist.slice(0,100).forEach(function(kw) {
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    65
        var li = $('<li class="box-shadow-2">'),
181
f0dc53d8b462 Updated styles for mosaic filtering
veltr
parents: 179
diff changeset
    66
            texta = $('<a class="display-keyword" href="#">'),
f0dc53d8b462 Updated styles for mosaic filtering
veltr
parents: 179
diff changeset
    67
            actiona = $('<a class="icon-action" href="#">');
f0dc53d8b462 Updated styles for mosaic filtering
veltr
parents: 179
diff changeset
    68
        texta.text(kw.keyword + ' ');
f0dc53d8b462 Updated styles for mosaic filtering
veltr
parents: 179
diff changeset
    69
        li.append(actiona);
f0dc53d8b462 Updated styles for mosaic filtering
veltr
parents: 179
diff changeset
    70
        li.append(texta);
179
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    71
        kw.li = li;
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    72
        li.click(function() {
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    73
            if (kw.enabled) {
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    74
                keywordslist.forEach(function(k) {
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    75
                    k.enabled = false;
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    76
                });
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    77
                kw.enabled = true;
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    78
            } else {
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    79
                keywordslist.forEach(function(k) {
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    80
                    k.enabled = true;
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    81
                });
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    82
            }
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    83
            updateKeywords();
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    84
            return false;
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    85
        });
181
f0dc53d8b462 Updated styles for mosaic filtering
veltr
parents: 179
diff changeset
    86
        actiona.click(function() {
179
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    87
            kw.enabled = !kw.enabled;
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    88
            updateKeywords();
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    89
            return false;
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    90
        });
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    91
        filterlist.append(li);
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    92
    })
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    93
        
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    94
    $('.toggle-comment').click(function(e){
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    95
        e.preventDefault();
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    96
        $('.show-comment, .hide-comment').hide();
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    97
        if($('.mosaic').length){
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    98
            $('.mosaic').removeClass('mosaic').addClass('mosaic-comment');
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
    99
            $('.hide-comment').show();
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
   100
        }else{
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
   101
            $('.mosaic-comment').removeClass('mosaic-comment').addClass('mosaic');
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
   102
            $('.show-comment').show();
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
   103
        }
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
   104
        updateMasonry();
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
   105
    });
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
   106
    
b7fabb9e5d9f updated tagcloud behaviour
veltr
parents:
diff changeset
   107
});