Files
easystream-main/f_scripts/be/js/tip.js
SamiAhmed7777 0b7e2d0a5b feat: Add comprehensive documentation suite and reorganize project structure
- Created complete documentation in docs/ directory
- Added PROJECT_OVERVIEW.md with feature highlights and getting started guide
- Added ARCHITECTURE.md with system design and technical details
- Added SECURITY.md with comprehensive security implementation guide
- Added DEVELOPMENT.md with development workflows and best practices
- Added DEPLOYMENT.md with production deployment instructions
- Added API.md with complete REST API documentation
- Added CONTRIBUTING.md with contribution guidelines
- Added CHANGELOG.md with version history and migration notes
- Reorganized all documentation files into docs/ directory for better organization
- Updated README.md with proper documentation links and quick navigation
- Enhanced project structure with professional documentation standards
2025-10-21 00:39:45 -07:00

99 lines
2.9 KiB
JavaScript

$(document).ready( function()
{
setTimeout(function(){
var animatespeed = 0;
var targets = $( '[rel=tooltip]' ),
target = false,
tooltip = false,
title = false;
$(document).on({ mouseenter: function (e)
{
target = $( this );
tip = target.attr( 'title' );
tooltip = $( '<div class="tooltip"></div>' );
if( !tip || tip == '' )
return false;
$(".tooltip").detach();
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' );
if (target.hasClass('top-notif')) {
pos_left = pos_left - 7;
}
if (target.hasClass('top-upload')) {
if (typeof($('#top-login-form').html()) != "undefined") {
pos_left = pos_left - 82;
pos_top = pos_top + 15;
} else {
pos_left = pos_left - (getWidth() < 701 ? 23 : 55);
}
}
tooltip.css( { left: pos_left, top: pos_top } )
.animate( { top: '+=10', opacity: 1 }, animatespeed );
};
init_tooltip();
$( window ).resize( init_tooltip );
var remove_tooltip = function()
{
tip = tooltip.html();
tooltip.animate( { top: '-=10', opacity: 0 }, animatespeed, function()
{
$( this ).remove();
});
target.attr( 'title', tip );
};
target.bind( 'mouseleave', remove_tooltip );
tooltip.bind( 'click', remove_tooltip );
} }, "[rel=tooltip]");
}, 1000);
});