Skip to content
Snippets Groups Projects
Commit 93bcc22f authored by Moritz Strohm's avatar Moritz Strohm
Browse files

removed unnecessary code from bootstrap/tooltip.js

parent 3889963b
No related branches found
No related tags found
No related merge requests found
// Attach global hover handler for tooltips. // Attach global hover handler for tooltips.
// Applies to all elements having a "data-tooltip" attribute. // Applies to all elements having a "data-tooltip" attribute.
// Tooltip may be provided in the data-attribute itself or by // Tooltip may be provided in the data-attribute itself or by
// defining a title attribute. The latter is prefered due to // defining a title attribute. The latter is preferred due to
// the obvious accessibility issues. // the obvious accessibility issues.
var timeout = null; var timeout = null;
...@@ -10,58 +10,22 @@ STUDIP.Tooltip.threshold = 6; ...@@ -10,58 +10,22 @@ STUDIP.Tooltip.threshold = 6;
$(document).on('mouseenter mouseleave focusin focusout', '[data-tooltip],.tooltip:has(.tooltip-content)', function(event) { $(document).on('mouseenter mouseleave focusin focusout', '[data-tooltip],.tooltip:has(.tooltip-content)', function(event) {
let data = $(this).data(); let data = $(this).data();
const visible = event.type === 'mouseenter' || event.type === 'focusin'; const visible = event.type === 'mouseenter' || event.type === 'focusin';
const offset = $(this).offset(); const offset = $(this).offset();
const x = offset.left + $(this).outerWidth(true) / 2; const x = offset.left + $(this).outerWidth(true) / 2;
const y = offset.top; const y = offset.top;
const delay = data.tooltipDelay ?? 300; const delay = data.tooltipDelay ?? 300;
let content;
let tooltip;
if (!data.tooltipObject) { if (!data.tooltipObject) {
// If tooltip has not yet been created (first hover), obtain it's data.tooltipObject = new STUDIP.Tooltip(x, y, $(this).children('.tooltip-content').first().html());
// contents and create the actual tooltip object.
if (!data.tooltip || !$.isPlainObject(data.tooltip)) {
let describing_element = $('#' + $(this).attr('aria-describedby'));
content = $('<div/>').text(data.tooltip || $(this).attr('title')).html();
if (!content && describing_element) {
content = $(describing_element).html();
}
} else if (data.tooltip.html !== undefined) {
content = data.tooltip.html;
} else if (data.tooltip.text !== undefined) {
content = data.tooltip.text;
} else {
throw "Invalid content for tooltip via data";
}
if (!content) {
content = $(this).closest('.tooltip-content').html();
}
$(this).attr('title', null);
$(this).attr('data-tooltip', content);
tooltip = new STUDIP.Tooltip(x, y, content);
data.tooltipObject = tooltip;
$(this).on('remove', function() {
tooltip.remove();
});
} else if (visible) {
// If tooltip has already been created, update it's position.
// This is neccessary if the surrounding content is scrollable AND has
// been scrolled. Otherwise the tooltip would appear at it's previous
// and now wrong location.
data.tooltipObject.position(x, y);
} }
if (visible) { if (visible) {
$('.studip-tooltip').not(data.tooltipObject).hide(); // If tooltip has already been created, update its position.
data.tooltipObject.show(); // This is necessary if the surrounding content is scrollable AND has
} else { // been scrolled. Otherwise, the tooltip would appear at its previous
timeout = setTimeout(() => data.tooltipObject.hide(), delay); // and now wrong location.
data.tooltipObject.position(x, y);
} }
}).on('mouseenter focusin', '.studip-tooltip', () => { }).on('mouseenter focusin', '.studip-tooltip', () => {
clearTimeout(timeout); clearTimeout(timeout);
......
...@@ -7,7 +7,7 @@ ...@@ -7,7 +7,7 @@
box-shadow: 0 1px 0 fade-out($white, 0.5) inset; box-shadow: 0 1px 0 fade-out($white, 0.5) inset;
font-size: var(--font-size-base); font-size: var(--font-size-base);
margin-bottom: 8px; margin-bottom: 8px;
max-width: 230px; max-width: $grid-element-width;
padding: 10px; padding: 10px;
position: absolute; position: absolute;
text-align: left; text-align: left;
...@@ -34,11 +34,11 @@ ...@@ -34,11 +34,11 @@
@include icon(before, info-circle, attention); @include icon(before, info-circle, attention);
} }
& + .tooltip-content { .tooltip-content {
@extend %tooltip; @extend %tooltip;
display: none; display: none;
} }
&:hover + .tooltip-content { &:hover .tooltip-content, &:focus .tooltip-content {
bottom: 100%; bottom: 100%;
display: inline-block; display: inline-block;
left: 50%; left: 50%;
......
<span class="tooltip tooltip-icon <? if ($important) echo 'tooltip-important'; ?>" <span class="tooltip tooltip-icon <? if ($important) echo 'tooltip-important'; ?>"
data-tooltip <? if (!$html) printf('title="%s"', htmlReady($text)) ?> tabindex="0">
tabindex="0" aria-describedby="tooltip_<?= htmlReady($tooltip_id) ?>"> <span class="tooltip-content"><?= $html ? $text : htmlReady($text) ?></span>
</span> </span>
<span id="tooltip_<?= htmlReady($tooltip_id) ?>" class="tooltip-content"><?= htmlReady($text) ?></span>
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment