123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127 |
- // @license magnet:?xt=urn:btih:0b31508aeb0634b347b8270c7bee4d411b5d4109&dn=agpl-3.0.txt AGPL-v3-or-Later
- window._coliberatorURL = 'http://localhost/coliberator/';
- window.Coliberator = {
- data: {},
- templates: {
- speaker: function (data){
- return '<li data-id="'+data.id+'" class="participant-item"><a href="#" class="participant" title="Click for more details"><img src="'+data.imageURL+'" alt="'+data.name+'"/><span class="participant-details">'+data.name+'</span></a></li>';
- },
- speakerDescription: function (data){
- var presentations = '<div class="presentations"><span class="category">Talks about:</span><ul>',
- i, l, v;
- for (i = 0, l = data.presentations.length; i < l; i ++) {
- v = data.presentations[i];
- presentations += '<li>' + v.title + '</li>';
- }
- presentations += '</ul></div>';
- return '<div class="pop-up"><div class="details"><img src="'+data.imageURL+'" alt="'+data.name+'"/><h2>'+data.name+'</h2><h5>'+data.occupation+'</h5><span class="description">'+data.description+'</span>'+presentations+'<button class="close-btn" title="Close the description panel"></button></div></div>';
- },
- presentation: function (data){
- var separator = '';
- var desc = '';
- if (data.name.length != 0) {
- separator = ' de ';
- }
- if (data.description.length != 0) {
- desc = '<p>' + data.description + '</p>';
- }
- if (data.description == 'separator') {
- return '<li style="border-bottom: 1px solid gray; margin-top: 20px;"><span class="title">'+data.when+'</span> (<span style="">'+data.title+'</span>)<span class="details">'+separator+data.name+'</span>'+desc+'</li>';
- }
- return '<li><span class="when">'+data.when+'</span><span class="title">'+data.title+'</span><span class="details">'+separator+data.name+'</span>'+desc+'</li>';
- }
- },
- build: {
- presentations: function (data) {
- var el = $('#presentations'),
- i, l, v = '';
- for (i = 0, l = data.length; i < l; i ++) {
- v += Coliberator.templates.presentation(data[i]);
- }
- el.append(v);
- el.on('click','li', Coliberator.build.showPresentationDescription);
- },
- speakers: function (data) {
- var el = $('#speakers'),
- i, l, v = '';
- for (i = 0, l = data.length; i < l; i ++) {
- v += Coliberator.templates.speaker(data[i]);
- }
- el.append(v);
- el.on('click','li', Coliberator.build.speakerDescription);
- },
- speakerDescription: function (ev) {
- var $this = $(this),
- data,
- $descrEl,
- closeFunction = function () {
- var $el = $(this);
- $el.animate({
- top: '100%'
- },'fast', function() {
- $el.parent().remove();
- $el.remove();
- $el.blur();
- $this.focus();
- $('body').off();
- });
- };
- $this.blur();
- ev.preventDefault();
- data = Coliberator.data.speakers[$this.data('id')];
- $descrEl = $(Coliberator.templates.speakerDescription(data));
- // ... event participants .append
- $('body').prepend($descrEl);
- var $details = $descrEl.find('.details').animate({
- top: '25%'
- },'fast').on('click','.close-btn', function(){
- $el = $(this.parentElement);
- closeFunction.call($details);
- });
- $('body').keypress(function(e){
- // bind escape to the close modal functionality
- if (e.keyCode == 27) {
- closeFunction.call($details);
- }
- });
- // set focus on the close button: fixes a bug where you could press
- // enter multiple times on participant and helps ux
- $details.find('.close-btn').focus();
- },
- showPresentationDescription: function (ev) {
- var $this = $(this),
- data,
- $descrEl;
- ev.preventDefault();
- $this.find('p').stop().slideToggle();
- }
- }
- }
- $(document).ready(function() {
- Coliberator.build.speakers(Coliberator.data.speakers);
- Coliberator.build.presentations(Coliberator.data.presentations);
- $('.header-container').on('click','a',function (){
- //scrollTop: $(this).offset().top + 'px'
- var el = $($(this).attr('href')), top;
- if (el.length) {
- top = el.offset().top - $('.header-container').outerHeight();
- } else {
- top = 0;
- }
- $('body').animate({
- scrollTop: top + 'px'
- }, 'fast');
- });
- });
- // @license-end
|