|
252
|
1 |
|
|
|
2 |
function countContentsAndThemes(_data) { |
|
|
3 |
_data.counts = { |
|
|
4 |
contents: (typeof _data.contents == "object" && typeof _data.contents.slice == "function" ? _data.contents.length : 0), |
|
|
5 |
themes: (typeof _data.themes == "object" && typeof _data.themes.slice == "function" ? _data.themes.length : 0) |
|
|
6 |
} |
|
|
7 |
if (typeof _data.themes == "object" && typeof _data.themes.slice == "function") { |
|
|
8 |
for (var _i = 0; _i < _data.themes.length; _i++) { |
|
|
9 |
countContentsAndThemes(_data.themes[_i]); |
|
|
10 |
var _subres = _data.themes[_i].counts; |
|
|
11 |
_data.counts.contents += _subres.contents; |
|
|
12 |
_data.counts.themes += _subres.themes; |
|
|
13 |
} |
|
|
14 |
} |
|
|
15 |
} |
|
|
16 |
|
|
|
17 |
function renderTemplate(_data, _level, _scale) { |
|
|
18 |
_data.level = !!_level; |
|
|
19 |
_(_data.tags).each(function(_tag) { |
|
|
20 |
_(_tag.contents).each(function(_content, _key) { |
|
|
21 |
_content.trimmed_description = _content.description.trim().replace(/(\n|\r|\r\n)/mg,' ').replace(/(^.{150,200})[\s].+$/m,'$1…'); |
|
|
22 |
_content.hidden = (_key >= 5); |
|
|
23 |
}); |
|
|
24 |
_tag.show_more = _tag.contents && _tag.contents.length > 5 ? _tag.contents.length - 5 : 0; |
|
|
25 |
}); |
|
|
26 |
_(_data.contents).each(function(_content, _key) { |
|
|
27 |
_content.trimmed_description = _content.description.trim().replace(/(\n|\r|\r\n)/mg,' ').replace(/(^.{150,200})[\s].+$/m,'$1…'); |
|
|
28 |
_content.hidden = (_key >= 5); |
|
|
29 |
}); |
|
|
30 |
_data.show_more = _data.contents && _data.contents.length > 5 ? _data.contents.length - 5 : 0; |
|
|
31 |
_data.font_size = (10+Math.log(_data.counts.contents)*_scale); |
|
|
32 |
var _prefix = '<li class="themeli {{#level}}folded {{/level}}"><p class="theme"><span style="font-size: {{font_size}}px">{{label}}</span> — {{#counts.themes}}{{counts.themes}} thème(s){{#counts.contents}}, {{/counts.contents}}{{/counts.themes}}{{#counts.contents}}{{counts.contents}} notice(s){{/counts.contents}}</p><ul>', |
|
|
33 |
_suffix = '{{#contents}}<li class="content{{#hidden}} hidden{{/hidden}}" id="content_{{id}}"><p class="title score_{{score}}">{{title}}</p><div class="foldedcontent"><div class="img-container"><img src="http://www.histoiredesarts.culture.fr/images/cached/images/{{hda_id}}.jpg" />' |
|
|
34 |
+ '</div><p class="description">Source: {{organization}}<br /><a href="{{url}}" target="_blank" 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>)…</li>{{/show_more}}</ul></li>', |
|
|
35 |
_html = Mustache.to_html(_prefix, _data); |
|
|
36 |
if (typeof _data.themes == "object" && typeof _data.themes.slice == "function") { |
|
|
37 |
for (var _i = 0; _i < _data.themes.length; _i++) { |
|
|
38 |
_html += renderTemplate(_data.themes[_i], _level + 1, _scale); |
|
|
39 |
} |
|
|
40 |
} |
|
|
41 |
_html += Mustache.to_html(_suffix, _data); |
|
|
42 |
return _html; |
|
|
43 |
} |
|
|
44 |
|
|
|
45 |
function renderData(_selector, _data) { |
|
|
46 |
countContentsAndThemes(_data); |
|
|
47 |
var _scale = 8 / Math.max(1,Math.log(_data.counts.contents)); |
|
|
48 |
_selector.html(renderTemplate(_data, 0, _scale)); |
|
|
49 |
_selector.find("p.theme").click(function() { |
|
|
50 |
$(this).parent().toggleClass("folded") |
|
|
51 |
return false; |
|
|
52 |
}); |
|
|
53 |
_selector.find("li.content").mouseenter(function() { |
|
|
54 |
$(this).find(".foldedcontent") |
|
|
55 |
.dequeue() |
|
|
56 |
.animate({ |
|
|
57 |
height: 5 + $(this).find("p.description").outerHeight() |
|
|
58 |
}, |
|
|
59 |
500); |
|
|
60 |
}).mouseleave(function() { |
|
|
61 |
$(this).find(".foldedcontent") |
|
|
62 |
.dequeue() |
|
|
63 |
.animate({ |
|
|
64 |
height: "0" |
|
|
65 |
}, |
|
|
66 |
500); |
|
|
67 |
}); |
|
|
68 |
_selector.find(".show_more").click(function() { |
|
|
69 |
$(this).siblings(".hidden:lt(5)").removeClass("hidden"); |
|
|
70 |
var _l = $(this).siblings(".hidden").length; |
|
|
71 |
$(this).find(".show_more_count").html(_l); |
|
|
72 |
if (!_l) { |
|
|
73 |
$(this).detach(); |
|
|
74 |
} |
|
|
75 |
}); |
|
|
76 |
} |