').find('.field-item').addClass('dontsplit');
columnsPage($('.group_side_4 .column-wrapper', $card), 210, ch);
}
};
MaterioBaseTheme.prototype.on_mousemove_cardmedium = function(event){
// trace('on_mousemove_cardmedium');
horiHoverImagesSwitcher(event);
};
MaterioBaseTheme.prototype.on_click_cardmedium = function(event){
// trace('on_click_cardmedium');
sideSwitcher(event);
};
MaterioBaseTheme.prototype.on_mouseleave_cardmedium = function(event){
if($('.side.op-visible').is('.oops') || $('.side.op-visible').is('.upgrade')){
sideSwitcher(event, 0);
}
};
/**
* cards Big
*/
// MaterioBaseTheme.prototype.init_layout_cardbig = function($card){
//trace('initLayoutCardBig');
// columnsPage($('.field-name-field-description, .field-name-body', $card), 425, 270);
// };
MaterioBaseTheme.prototype.on_mouseenter_cardbig = function(event){
// trace('on_mouseenter_cardbig');
showLazyLoadedImages(event.currentTarget);
if(!$('.columnized', event.currentTarget).size()){
columnsPage($('.field-name-field-description, .field-name-body', event.currentTarget), 425, 270);
$('.group_4', event.currentTarget).wrapInner('
').find('.field-item').addClass('dontsplit');
columnsPage($('.group_4 .column-wrapper', event.currentTarget), 425, 270);
}
};
MaterioBaseTheme.prototype.on_mousemove_cardbig = function(event){
// trace('on_mousemove_cardbig');
horiHoverImagesSwitcher(event);
};
MaterioBaseTheme.prototype.on_click_cardbig = function(event){
//trace('on_click_cardbig');
sideSwitcher(event);
};
MaterioBaseTheme.prototype.on_mouseleave_cardbig = function(event){
if($('.side.op-visible').is('.oops') || $('.side.op-visible').is('.upgrade')){
sideSwitcher(event, 0);
}
};
/**
* cards Full
*/
// MaterioBaseTheme.prototype.init_layout_cardfull = function($card){
// trace('initLayoutCardFull');
// };
MaterioBaseTheme.prototype.on_mouseenter_cardfull = function(event){
// trace('on_mouseenter_cardfull');
showLazyLoadedImages(event.currentTarget);
};
MaterioBaseTheme.prototype.on_mousemove_cardfull = function(event){
// trace('on_mousemove_cardfull');
horiHoverImagesSwitcher(event);
};
// MaterioBaseTheme.prototype.on_click_cardfull = function(event){
// trace('on_click_cardfull');
// };
// MaterioBaseTheme.prototype.on_mouseleave_cardfull = function(event){
// trace('on_mouseleave_cardfull');
// };
/**
* horiHoverImagesSwitcher
*/
function horiHoverImagesSwitcher(event){
// trace('horiHoverImagesSwitcher', event);
var $curtar = $(event.currentTarget);
if(event.layerX && $curtar.is('.image-ready') ){ // && !$curtar.is('.image-buged')
var $imgs = $('.group_images figure', event.currentTarget);
if($(event.target).parents('.group_images').length){
var imgw = $imgs.eq(0).w(),
rapport = imgw/$imgs.length,
mx = event.layerX > imgw ? imgw-1 : event.layerX,
rapport_pos = Math.floor(mx / rapport);
// trace('rapport_pos = '+rapport_pos+' | event.layerX = '+event.layerX);
rapport_pos = rapport_pos < 0 ? 0 : ( rapport_pos > ($imgs.length - 1) ? $imgs.length - 1 : rapport_pos);
if(!$imgs.eq(rapport_pos).is('.op-visible')){
// google analytics
$.event.trigger({
type : 'record-stat',
categorie : 'Card event',
action : 'image slide switch',
label : rapport_pos
});
$imgs
.removeClass('op-visible').addClass('op-hidden')
.eq(rapport_pos)
.removeClass('op-hidden').addClass('op-visible');
}
}else{
// $curtar.addClass('image-buged');
$imgs.removeClass('op-visible').addClass('op-hidden');
$imgs.eq(0).removeClass('op-hidden').addClass('op-visible');
}
}
};
/**
* protectImages
*/
function protectFigures(context){
// trace('protectFigures');
context = context == null ? 'body' : context;
$('figure:not(.protected)', context)
.append('

')
.addClass('protected')
.bind("contextmenu", function(e){
alert("Cette image est soumise au droit d'auteur.");
return false;
});
}
/**
* lazyloadimages
*/
// unused
function initLazyLoad(context){
// $('figure:first-child img.lazy', context).lazyload();//{
// container:'#content'
// });
// TODO: propage this event to the card near it to anticipate the mouseenter
// $(context).bind('mousemove', showLazyLoadedImages);
};
function showLazyLoadedImages(context){
//trace('MaterioBaseTheme :: initLazyLoad : mouseenter', this);
var $this = $(context);
if( !$this.is('.lazy-processed') ){
$this
.addClass('lazy-processed')
// .find('figure img.lazy')
.find('img.lazy')
.each(function(index){
var $img = $(this);
$img.attr('src', $img.attr('data-original')).removeAttr('data-original');
});
setTimeout(function(){
$this.addClass('image-ready');
}, 300);
}
}
/**
* sideSwitcher
*/
function sideSwitcher(event, delta){
var $sides = $('.side', event.currentTarget);
if($sides.length > 1){
if( typeof delta == 'undefined'){
var delta = 0;
$sides.each(function(i) {
if($(this).is('.op-visible')){
delta = i+1;
return false;
}
});
delta = delta == 0 ? 1 : (delta == $sides.length ? 0 : delta);
}
// google analytics
$.event.trigger({
type : 'record-stat',
categorie : 'Card event',
action : 'side switch',
label : delta
});
$sides.addClass('op-hidden').removeClass('op-visible')
.eq(delta).removeClass('op-hidden').addClass('op-visible');
}
};
/**
* columnsPage
*/
function columnsPage($elmt, cw, ch){
// trace('columnsPage');
var cls = Math.ceil($elmt.h()/ch);
$elmt
.addClass('columnized')
.width(cw*cls)
.columnize({
width:cw,
height:ch,
lastNeverTallest:true,
});
if(cls > 1){
$elmt.find('.column').each(function(index) {
var $this = $(this);
if(!$this.find('*').length){
$this.prev().addClass('last');
$this.remove();
return true;
}
});
$elmt.find('.column').each(function(index) {
var $this = $(this);
if(!$this.is('.first'))
$this.children('*:first-child').prepend('
‹ ...');
if(!$this.is('.last'))
$this.children('*:last-child').append('...
›');
});
$('.column-switcher', $elmt).bind('click', onColumnSwitcherClick);
}
};
function onColumnSwitcherClick(event){
event.preventDefault();
//trace('onColumnSwitcherClick', event);
var $this = $(event.currentTarget),
$columnized = $this.parents('.columnized');
// google analytics
$.event.trigger({
type : 'record-stat',
categorie : 'Card event',
action : 'column switch',
label : $this.attr('col')
});
$columnized.css({
marginLeft : -1 * $this.attr('cw') * $this.attr('col') +'px'
});
return false;
}
/**
* initViewmodes
*/
function initViewmodes(){
checkViewmodesResponsive();
};
function checkViewmodesResponsive(){
if(_480_768()){
if($('.viewmode-link.active').is('.viewmode-cardfull')){
$('.viewmode-cardbig').trigger('click');
}
}else if(_max_480()){
if($('.viewmode-link.active').is('.viewmode-cardbig, .viewmode-cardfull')){
$('.viewmode-cardmedium').trigger('click');
}
}
};
/**
* FLAGS
*/
function initFlagsEvent(){
$('.bookmarks, .mylists .flaged').children('.node:not(.listened)')
.bind('mouseenter mousemove click mouseleave', onCardEventDispatcher)
// .each(function(event){ initLayoutCardDispatcher($(this)); })
.addClass('listened');
};
function onAfterFlaging(event){
//trace('MaterioBaseTheme :: onAfterFlaging', event);
// WARNING to use event variables i had to hack flag.js from flag module (change the event declaration)
var $target = $(event.link).parents('article.node');
if(event.flagStatus == 'flag'){
$target.addClass('flaged');
}else if(event.flagStatus == 'unflag'){
if($('.flag-lists-entity-links a.unflag-action', $target).length == 0)
$target.removeClass('flaged');
}
};
function onMybookmarksBlockUpdate(event){
initFlagsEvent();
initLayout();
};
function onClickList(event){
//trace('onClickList', event);
var $link = $(event.currentTarget).addClass('active'),
name = $link.attr('name'),
$block = $link.parents('.block'),
$flaged = $('.flaged.'+name, $block).addClass('active');
$link.siblings().removeClass('active');
$flaged.siblings().removeClass('active');
createCookie('materiomyflaglistsopened', name, 1);
$flaged.parents('.mylists').height($flaged.h());
initLayout();
};
function onMyListsBlockUpdate(event){
//trace('MaterioBaseTheme :: onMyListsBlockUpdate', event);
initFlagsEvent();
initLazyLoad(this);
// TODO: refresh contents (search results) to see new flaglist links.
initLayout();
};
function onMyListsBlockBuilded(event){
//trace('MaterioBaseTheme :: onMyListsBlockBuilded', event);
// initLazyLoad(event.block);
showLazyLoadedImages(event.block);
};
/**
* cards bookmark
*/
// MaterioBaseTheme.prototype.init_layout_bookmark = function($card){
// trace('initLayoutCardBig');
// };
MaterioBaseTheme.prototype.on_mouseenter_bookmark = function(event){
//trace('on_mouseenter_bookmark', event);
_$tooltip
.html($('.group_header', this).clone())
.css({
top:event.pageY - _$tooltip.h() -5,//- event.layerY,
left:event.pageX + 5 + ($(this).w() - event.layerX)
})
.removeClass('op-hidden').addClass('op-visible');
};
MaterioBaseTheme.prototype.on_mousemove_bookmark = function(event){
// trace('on_mousemove_Card', event);
// if(event.layerX)
// horiHoverImagesSwitcher(event);
_$tooltip
.css({
top:event.pageY - _$tooltip.h() -5,// - event.layerY,
left:event.pageX + 5 + ($(this).w() - event.layerX)
});
};
// MaterioBaseTheme.prototype.on_click_bookmark = function(event){
// trace('on_click_bookmark', event);
// };
MaterioBaseTheme.prototype.on_mouseleave_bookmark = function(event){
// trace('on_mouseleave_Card', event);
$('.images img.op-visible', this)
.removeClass('op-visible').addClass('op-hidden')
.eq(0)
.removeClass('op-hidden').addClass('op-visible');
_$tooltip.removeClass('op-visible').addClass('op-hidden');
};
/**
* keyboradshortcuts
*/
function initKeyboardShortcuts(){
var stat_event = { type : 'record-stat', categorie : 'Shortcuts'};
$(document).bind('keydown', 'Alt+f',function (evt){
if($('#edit-searchfield').size()){
stat_event.action = 'Alt+f';
stat_event.label = 'Focus on search text field';
$.event.trigger(stat_event);
$('#edit-searchfield').focus();
return false;
}
});
$(document).bind('keydown', 'Alt+1',function (evt){
if($('a.viewmode-link.viewmode-cardsmall').size()){
stat_event.action = 'Alt+1';
stat_event.label = 'Change view mode : card small';
$.event.trigger(stat_event);
$('a.viewmode-link.viewmode-cardsmall').click();
return false;
}
});
$(document).bind('keydown', 'Alt+2',function (evt){
if($('a.viewmode-link.viewmode-cardmedium').size()){
stat_event.action = 'Alt+2';
stat_event.label = 'Change view mode : card medium';
$.event.trigger(stat_event);
$('a.viewmode-link.viewmode-cardmedium').click();
return false;
}
});
$(document).bind('keydown', 'Alt+3',function (evt){
if($('a.viewmode-link.viewmode-cardbig').size()){
stat_event.action = 'Alt+3';
stat_event.label = 'Change view mode : card big';
$.event.trigger(stat_event);
$('a.viewmode-link.viewmode-cardbig').click();
return false;
}
});
$(document).bind('keydown', 'Alt+4',function (evt){
if($('a.viewmode-link.viewmode-cardfull').size()){
stat_event.action = 'Alt+4';
stat_event.label = 'Change view mode : card full';
$.event.trigger(stat_event);
$('a.viewmode-link.viewmode-cardfull').click();
return false;
}
});
};
/**
* Misc
*/
function onResizeWindow(e){
clearInterval(_resizeTimer);
_resizeTimer = setTimeout(function(){
initLayout();
checkViewmodesResponsive();
}, 200);
};
/**
* Statics
*/
function initAdhesion(){
$('#webform-component-membership-options').change(function(event){
console.log(event);
// if($(event.target).is('#edit-submitted-membership-options-3')){
if( $('input[type="radio"]:checked', this).is('#edit-submitted-membership-options-3') ){
$('#webform-component-collaborators').show();
}else{
$('#webform-component-collaborators').hide();
}
});
$('.get-link a').bind('click', function(event) {
var $this = $(this),
$parent = $this.parents('.column'),
radio;
if($parent.is('.flocon')){
radio = "#edit-submitted-membership-options-1";
}else if($parent.is('.etoile')){
radio = "#edit-submitted-membership-options-2";
}else if($parent.is('.cinqetoiles')){
radio = "#edit-submitted-membership-options-3";
}
// $('input', '#edit-submitted-type-dadhesion').attr('checked', false);
$(radio).attr('checked', true);
$('#webform-component-membership-options').change();
$('#content-bottom').css('padding-top', $('#container').css('padding-top'));
});
$("#edit-submitted-membership-options-1").attr('checked', true);
$('#webform-component-membership-options').change();
};
/** helpers */
$.fn.h = function(){
if(this.css('height') == undefined)
return 0;
return parseInt(this.css('height')) + parseInt(this.css('padding-top')) + parseInt(this.css('padding-bottom'));
};
$.fn.w = function(){
if(this.css('width') == undefined)
return 0;
return parseInt(this.css('width')) + parseInt(this.css('padding-left')) + parseInt(this.css('padding-right'));
};
function getDocHeight() {
var D = document;
return Math.max(
Math.max(D.body.scrollHeight, D.documentElement.scrollHeight),
Math.max(D.body.offsetHeight, D.documentElement.offsetHeight),
Math.max(D.body.clientHeight, D.documentElement.clientHeight)
);
}
// http://andylangton.co.uk/articles/javascript/get-viewport-size-javascript/
function viewport() {
var e = window, a = 'inner';
if (!('innerWidth' in window )) {
a = 'client';
e = document.documentElement || document.body;
}
return { width : e[ a+'Width' ] , height : e[ a+'Height' ] };
}
/**
* Forms
*/
function initForms(){
$('#edit-searchfield')
.bind('focus', function(event) {
var $this = $(this);
//$this.attr('value', 'test');
// trace('value', $this.val());
// trace('default', $this.attr('default'));
if($this.val() == $this.attr('default'))
$this.val('');
})
.bind('focusout', function(event) {
var $this = $(this);
if($this.val() == "")
$this.val($this.attr('default'));
});
var id,label, description;
$('input.form-text', '#block-user-login, #block-materio-user-user-register').each(function(i) {
id = $(this).attr('id');
label = $('label[for='+id+']').hide().text();
description = $(this).parent().find('.description').hide().text();
$(this).attr('placeholder', label).attr('title', description);
});
}
/**
* cookies
*/
function createCookie(name,value,days) {
if (days) {
var date = new Date();
date.setTime(date.getTime()+(days*24*60*60*1000));
var expires = "; expires="+date.toGMTString();
}
else var expires = "";
document.cookie = name+"="+value+expires+"; path=/";
}
function readCookie(name) {
var nameEQ = name + "=";
var ca = document.cookie.split(';');
for(var i=0;i < ca.length;i++) {
var c = ca[i];
while (c.charAt(0)==' ') c = c.substring(1,c.length);
if (c.indexOf(nameEQ) == 0) return c.substring(nameEQ.length,c.length);
}
return null;
}
function eraseCookie(name) {
createCookie(name,"",-1);
}
/**
* google analytics
*/
function onRecordStat(event){
//trace('onRecordStat', event);
// path, category, action, opt_label, opt_value
if(typeof _gaq !== 'undefined'){
if(event.path){
_gaq.push(['_trackPageview', event.path]);
}else{
_gaq.push(['_trackEvent', event.categorie, event.action, event.label, event.value]);
}
}
}
init();
};
$(document).ready(function() {
var materiobasetheme = new MaterioBaseTheme();
});
/**
* Attach collapse behavior to the feedback form block.
*/
Drupal.behaviors.feedbackForm = {
attach: function (context) {
$('#block-feedback-form', context).once('feedback', function () {
var $block = $(this);
$block.find('span.feedback-link')
.prepend('
feedback ')
.css('cursor', 'pointer')
.toggle(function () {
Drupal.feedbackFormToggle($block, false);
},
function() {
Drupal.feedbackFormToggle($block, true);
}
);
$block.find('form').hide();
$block.show();
});
}
};
/**
* Collapse or uncollapse the feedback form block.
*/
Drupal.feedbackFormToggle = function ($block, enable) {
$block.find('form').slideToggle('medium');
if (enable) {
$('#feedback-form-toggle', $block).html('feedback');
}
else {
$('#feedback-form-toggle', $block).html('feedback (close)');
}
};
})(jQuery);