##// END OF EJS Templates
docs: update example nginx/apache configs to use .rccontrol static path
docs: update example nginx/apache configs to use .rccontrol static path

File last commit:

r385:4c58728c default
r457:1e39daf5 default
Show More
tooltips.js
94 lines | 3.0 KiB | application/javascript | JavascriptLexer
project: added all source files and assets
r1 // # Copyright (C) 2010-2016 RhodeCode GmbH
// #
// # This program is free software: you can redistribute it and/or modify
// # it under the terms of the GNU Affero General Public License, version 3
// # (only), as published by the Free Software Foundation.
// #
// # This program is distributed in the hope that it will be useful,
// # but WITHOUT ANY WARRANTY; without even the implied warranty of
// # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// # GNU General Public License for more details.
// #
// # You should have received a copy of the GNU Affero General Public License
// # along with this program. If not, see <http://www.gnu.org/licenses/>.
// #
// # This program is dual-licensed. If you wish to learn more about the
// # RhodeCode Enterprise Edition, including its added features, Support services,
// # and proprietary license terms, please see https://rhodecode.com/licenses/
/**
* TOOLTIP IMPL.
*/
var TTIP = {};
TTIP.main = {
offset: [15,15],
maxWidth: 600,
tooltips: use a single delegated event for tooltips
r382 setDeferredListeners: function(){
$('body').on('mouseover', '.tooltip', yt.show_tip);
$('body').on('mousemove', '.tooltip', yt.move_tip);
$('body').on('mouseout', '.tooltip', yt.close_tip);
project: added all source files and assets
r1 },
init: function(){
$('#tip-box').remove();
yt.tipBox = document.createElement('div');
document.body.appendChild(yt.tipBox);
yt.tipBox.id = 'tip-box';
$(yt.tipBox).hide();
$(yt.tipBox).css('position', 'absolute');
if(yt.maxWidth !== null){
$(yt.tipBox).css('max-width', yt.maxWidth+'px');
}
tooltips: use a single delegated event for tooltips
r382 yt.setDeferredListeners();
project: added all source files and assets
r1 },
show_tip: function(e, el){
e.stopPropagation();
e.preventDefault();
tooltips: use a single delegated event for tooltips
r382 var el = e.data || e.currentTarget || el;
project: added all source files and assets
r1 if(el.tagName.toLowerCase() === 'img'){
yt.tipText = el.alt ? el.alt : '';
} else {
yt.tipText = el.title ? el.title : '';
}
if(yt.tipText !== ''){
// save org title
$(el).attr('tt_title', yt.tipText);
// reset title to not show org tooltips
$(el).attr('title', '');
yt.tipBox.innerHTML = yt.tipText;
$(yt.tipBox).show();
}
},
move_tip: function(e, el){
e.stopPropagation();
e.preventDefault();
tooltips: use a single delegated event for tooltips
r382 var el = e.data || e.currentTarget || el;
project: added all source files and assets
r1 var movePos = [e.pageX, e.pageY];
$(yt.tipBox).css('top', (movePos[1] + yt.offset[1]) + 'px')
$(yt.tipBox).css('left', (movePos[0] + yt.offset[0]) + 'px')
},
close_tip: function(e, el){
e.stopPropagation();
e.preventDefault();
tooltips: use a single delegated event for tooltips
r382 var el = e.data || e.currentTarget || el;
project: added all source files and assets
r1 $(yt.tipBox).hide();
$(el).attr('title', $(el).attr('tt_title'));
$('#tip-box').hide();
}
};
tooltips: remove all occurences of explicit tooltip activation
r385 // activate tooltips
yt = TTIP.main;
if ($(document).data('activated-tooltips') !== '1'){
$(document).ready(yt.init);
$(document).data('activated-tooltips', '1');
}