Участник:MailGik/hilarious.js — различия между версиями
Материал из Hilarious Wiki
MailGik (обсуждение | вклад) |
MailGik (обсуждение | вклад) |
||
Строка 2: | Строка 2: | ||
$('.tooltip').tipsy({gravity: $.fn.tipsy.autoNS}); | $('.tooltip').tipsy({gravity: $.fn.tipsy.autoNS}); | ||
} ); | } ); | ||
+ | |||
+ | |||
+ | $( function() | ||
+ | { | ||
+ | var targets = $( '[rel~=tooltip]' ), | ||
+ | target = false, | ||
+ | tooltip = false, | ||
+ | title = false; | ||
+ | |||
+ | targets.bind( 'mouseenter', function() | ||
+ | { | ||
+ | target = $( this ); | ||
+ | tip = target.attr( 'title' ); | ||
+ | tooltip = $( '<div id="tooltip"></div>' ); | ||
+ | |||
+ | if( !tip || tip == '' ) | ||
+ | return false; | ||
+ | |||
+ | target.removeAttr( 'title' ); | ||
+ | tooltip.css( 'opacity', 0 ) | ||
+ | .html( tip ) | ||
+ | .appendTo( 'body' ); | ||
+ | |||
+ | var init_tooltip = function() | ||
+ | { | ||
+ | if( $( window ).width() < tooltip.outerWidth() * 1.5 ) | ||
+ | tooltip.css( 'max-width', $( window ).width() / 2 ); | ||
+ | else | ||
+ | tooltip.css( 'max-width', 340 ); | ||
+ | |||
+ | var pos_left = target.offset().left + ( target.outerWidth() / 2 ) - ( tooltip.outerWidth() / 2 ), | ||
+ | pos_top = target.offset().top - tooltip.outerHeight() - 20; | ||
+ | |||
+ | if( pos_left < 0 ) | ||
+ | { | ||
+ | pos_left = target.offset().left + target.outerWidth() / 2 - 20; | ||
+ | tooltip.addClass( 'left' ); | ||
+ | } | ||
+ | else | ||
+ | tooltip.removeClass( 'left' ); | ||
+ | |||
+ | if( pos_left + tooltip.outerWidth() > $( window ).width() ) | ||
+ | { | ||
+ | pos_left = target.offset().left - tooltip.outerWidth() + target.outerWidth() / 2 + 20; | ||
+ | tooltip.addClass( 'right' ); | ||
+ | } | ||
+ | else | ||
+ | tooltip.removeClass( 'right' ); | ||
+ | |||
+ | if( pos_top < 0 ) | ||
+ | { | ||
+ | var pos_top = target.offset().top + target.outerHeight(); | ||
+ | tooltip.addClass( 'top' ); | ||
+ | } | ||
+ | else | ||
+ | tooltip.removeClass( 'top' ); | ||
+ | |||
+ | tooltip.css( { left: pos_left, top: pos_top } ) | ||
+ | .animate( { top: '+=10', opacity: 1 }, 50 ); | ||
+ | }; | ||
+ | |||
+ | init_tooltip(); | ||
+ | $( window ).resize( init_tooltip ); | ||
+ | |||
+ | var remove_tooltip = function() | ||
+ | { | ||
+ | tooltip.animate( { top: '-=10', opacity: 0 }, 50, function() | ||
+ | { | ||
+ | $( this ).remove(); | ||
+ | }); | ||
+ | |||
+ | target.attr( 'title', tip ); | ||
+ | }; | ||
+ | |||
+ | target.bind( 'mouseleave', remove_tooltip ); | ||
+ | tooltip.bind( 'click', remove_tooltip ); | ||
+ | }); | ||
+ | }); |
Версия 14:56, 29 января 2017
mw.loader.using( 'jquery.tipsy', function () {
$('.tooltip').tipsy({gravity: $.fn.tipsy.autoNS});
} );
$( function()
{
var targets = $( '[rel~=tooltip]' ),
target = false,
tooltip = false,
title = false;
targets.bind( 'mouseenter', function()
{
target = $( this );
tip = target.attr( 'title' );
tooltip = $( '<div id="tooltip"></div>' );
if( !tip || tip == '' )
return false;
target.removeAttr( 'title' );
tooltip.css( 'opacity', 0 )
.html( tip )
.appendTo( 'body' );
var init_tooltip = function()
{
if( $( window ).width() < tooltip.outerWidth() * 1.5 )
tooltip.css( 'max-width', $( window ).width() / 2 );
else
tooltip.css( 'max-width', 340 );
var pos_left = target.offset().left + ( target.outerWidth() / 2 ) - ( tooltip.outerWidth() / 2 ),
pos_top = target.offset().top - tooltip.outerHeight() - 20;
if( pos_left < 0 )
{
pos_left = target.offset().left + target.outerWidth() / 2 - 20;
tooltip.addClass( 'left' );
}
else
tooltip.removeClass( 'left' );
if( pos_left + tooltip.outerWidth() > $( window ).width() )
{
pos_left = target.offset().left - tooltip.outerWidth() + target.outerWidth() / 2 + 20;
tooltip.addClass( 'right' );
}
else
tooltip.removeClass( 'right' );
if( pos_top < 0 )
{
var pos_top = target.offset().top + target.outerHeight();
tooltip.addClass( 'top' );
}
else
tooltip.removeClass( 'top' );
tooltip.css( { left: pos_left, top: pos_top } )
.animate( { top: '+=10', opacity: 1 }, 50 );
};
init_tooltip();
$( window ).resize( init_tooltip );
var remove_tooltip = function()
{
tooltip.animate( { top: '-=10', opacity: 0 }, 50, function()
{
$( this ).remove();
});
target.attr( 'title', tip );
};
target.bind( 'mouseleave', remove_tooltip );
tooltip.bind( 'click', remove_tooltip );
});
});