src/hdalab/static/hdalab/js/trees.js
author ymh <ymh.work@gmail.com>
Thu, 05 Mar 2015 16:58:28 +0100
changeset 479 51cd6fa9dfe3
parent 477 8f70ba2106a9
child 620 f45d7494332e
permissions -rw-r--r--
small optimization on image loading
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
477
8f70ba2106a9 optimize image loading
ymh <ymh.work@gmail.com>
parents: 345
diff changeset
     1
// from http://stackoverflow.com/a/7031800
8f70ba2106a9 optimize image loading
ymh <ymh.work@gmail.com>
parents: 345
diff changeset
     2
8f70ba2106a9 optimize image loading
ymh <ymh.work@gmail.com>
parents: 345
diff changeset
     3
$.fn.reveal = function() {
8f70ba2106a9 optimize image loading
ymh <ymh.work@gmail.com>
parents: 345
diff changeset
     4
    var args = Array.prototype.slice.call(arguments);
8f70ba2106a9 optimize image loading
ymh <ymh.work@gmail.com>
parents: 345
diff changeset
     5
    return this.each(function(){
8f70ba2106a9 optimize image loading
ymh <ymh.work@gmail.com>
parents: 345
diff changeset
     6
        var img = $(this),
8f70ba2106a9 optimize image loading
ymh <ymh.work@gmail.com>
parents: 345
diff changeset
     7
            src = img.data("src");
479
51cd6fa9dfe3 small optimization on image loading
ymh <ymh.work@gmail.com>
parents: 477
diff changeset
     8
        src && img.attr("src") !== src && img.attr("src", src).load(function(){
477
8f70ba2106a9 optimize image loading
ymh <ymh.work@gmail.com>
parents: 345
diff changeset
     9
            img[args[0]||"show"].apply(img, args.splice(1));
8f70ba2106a9 optimize image loading
ymh <ymh.work@gmail.com>
parents: 345
diff changeset
    10
        });
8f70ba2106a9 optimize image loading
ymh <ymh.work@gmail.com>
parents: 345
diff changeset
    11
    });
8f70ba2106a9 optimize image loading
ymh <ymh.work@gmail.com>
parents: 345
diff changeset
    12
};
8f70ba2106a9 optimize image loading
ymh <ymh.work@gmail.com>
parents: 345
diff changeset
    13
252
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    14
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    15
function countContentsAndThemes(_data) {
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    16
    _data.counts = {
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    17
        contents: (typeof _data.contents == "object" && typeof _data.contents.slice == "function" ? _data.contents.length : 0),
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    18
        themes: (typeof _data.themes == "object" && typeof _data.themes.slice == "function" ? _data.themes.length : 0)
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    19
    }
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    20
    if (typeof _data.themes == "object" && typeof _data.themes.slice == "function") {
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    21
        for (var _i = 0; _i < _data.themes.length; _i++) {
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    22
            countContentsAndThemes(_data.themes[_i]);
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    23
            var _subres = _data.themes[_i].counts;
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    24
            _data.counts.contents += _subres.contents;
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    25
            _data.counts.themes += _subres.themes;
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    26
        }
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    27
    }
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    28
}
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    29
261
f5b5affc2586 Make thesaurus and categories visible
veltr
parents: 253
diff changeset
    30
function renderTemplate(_data, _level, _scale, _maxlevel) {
f5b5affc2586 Make thesaurus and categories visible
veltr
parents: 253
diff changeset
    31
    _data.isfolded = _level >= _maxlevel;
252
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    32
    _(_data.tags).each(function(_tag) {
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    33
        _(_tag.contents).each(function(_content, _key) {
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    34
            _content.trimmed_description = _content.description.trim().replace(/(\n|\r|\r\n)/mg,' ').replace(/(^.{150,200})[\s].+$/m,'$1&hellip;');
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    35
            _content.hidden = (_key >= 5);
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    36
        });
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    37
        _tag.show_more = _tag.contents && _tag.contents.length > 5 ? _tag.contents.length - 5 : 0;
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    38
    });
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    39
    _(_data.contents).each(function(_content, _key) {
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    40
        _content.trimmed_description = _content.description.trim().replace(/(\n|\r|\r\n)/mg,' ').replace(/(^.{150,200})[\s].+$/m,'$1&hellip;');
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    41
        _content.hidden = (_key >= 5);
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    42
    });
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    43
    _data.show_more = _data.contents && _data.contents.length > 5 ? _data.contents.length - 5 : 0;
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    44
    _data.font_size = (10+Math.log(_data.counts.contents)*_scale);
253
1113c3874dd6 Added Datasheet View
veltr
parents: 252
diff changeset
    45
    var _dsurl = endpoints.datasheet.replace(/ID$/,'');
261
f5b5affc2586 Make thesaurus and categories visible
veltr
parents: 253
diff changeset
    46
    var _prefix = '<li class="themeli{{#isfolded}} folded{{/isfolded}}"><p class="theme"><span style="font-size: {{font_size}}px">{{label}}</span> &mdash; {{#counts.themes}}{{counts.themes}} thème(s){{#counts.contents}}, {{/counts.contents}}{{/counts.themes}}{{#counts.contents}}{{counts.contents}} notice(s){{/counts.contents}}</p><ul>',
253
1113c3874dd6 Added Datasheet View
veltr
parents: 252
diff changeset
    47
        _suffix = '{{#contents}}<li class="content{{#hidden}} hidden{{/hidden}}" id="content_{{id}}"><p class="title score_{{score}}"><a href="'
1113c3874dd6 Added Datasheet View
veltr
parents: 252
diff changeset
    48
            + _dsurl
477
8f70ba2106a9 optimize image loading
ymh <ymh.work@gmail.com>
parents: 345
diff changeset
    49
            + '{{hda_id}}">{{title}}</a></p><div class="foldedcontent"><div class="img-container"><img data-src="http://www.histoiredesarts.culture.fr/images/pf/{{hda_id}}.jpg" />'
253
1113c3874dd6 Added Datasheet View
veltr
parents: 252
diff changeset
    50
            + '</div><p class="description">Source: <a href="{{organization_url}}" target="_blank">{{organization}}</a><br /><a href="'
1113c3874dd6 Added Datasheet View
veltr
parents: 252
diff changeset
    51
            + _dsurl
1113c3874dd6 Added Datasheet View
veltr
parents: 252
diff changeset
    52
            + '{{hda_id}}" class="content">{{trimmed_description}}</a></p></div></li>{{/contents}}{{#show_more}}<li class="show_more">Plus de contenus (<span class="show_more_count">{{show_more}}</span>)&hellip;</li>{{/show_more}}</ul></li>',
252
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    53
        _html = Mustache.to_html(_prefix, _data);
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    54
    if (typeof _data.themes == "object" && typeof _data.themes.slice == "function") {
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    55
        for (var _i = 0; _i < _data.themes.length; _i++) {
261
f5b5affc2586 Make thesaurus and categories visible
veltr
parents: 253
diff changeset
    56
            _html += renderTemplate(_data.themes[_i], _level + 1, _scale, _maxlevel);
252
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    57
        }
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    58
    }
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    59
    _html += Mustache.to_html(_suffix, _data);
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    60
    return _html;
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    61
}
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    62
261
f5b5affc2586 Make thesaurus and categories visible
veltr
parents: 253
diff changeset
    63
function renderData(_selector, _data, _maxlevel) {
252
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    64
    countContentsAndThemes(_data);
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    65
    var _scale = 8 / Math.max(1,Math.log(_data.counts.contents));
261
f5b5affc2586 Make thesaurus and categories visible
veltr
parents: 253
diff changeset
    66
    _selector.html(renderTemplate(_data, 0, _scale, _maxlevel));
252
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    67
    _selector.find("p.theme").click(function() {
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    68
        $(this).parent().toggleClass("folded")
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    69
        return false;
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    70
    });
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    71
    _selector.find("li.content").mouseenter(function() {
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    72
        $(this).find(".foldedcontent")
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    73
        .dequeue()
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    74
        .animate({
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    75
            height: 5 + $(this).find("p.description").outerHeight()
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    76
        },
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    77
        500);
477
8f70ba2106a9 optimize image loading
ymh <ymh.work@gmail.com>
parents: 345
diff changeset
    78
        $(this).find(".img-container img").reveal("fadeIn", 500);
252
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    79
    }).mouseleave(function() {
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    80
        $(this).find(".foldedcontent")
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    81
        .dequeue()
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    82
        .animate({
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    83
            height: "0"
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    84
        },
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    85
        500);
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    86
    });
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    87
    _selector.find(".show_more").click(function() {
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    88
        $(this).siblings(".hidden:lt(5)").removeClass("hidden");
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    89
        var _l = $(this).siblings(".hidden").length;
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    90
        $(this).find(".show_more_count").html(_l);
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    91
        if (!_l) {
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    92
            $(this).detach();
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    93
        } 
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    94
    });
a46461f8a74f Separated Thesaurus and WP Categories
veltr
parents:
diff changeset
    95
}