TooltipManager (ui)
@ckeditor/ckeditor5-ui/src/tooltipmanager
A tooltip manager class for the UI of the editor.
Note: Most likely you do not have to use the TooltipManager
API listed below in order to display tooltips. Popular
UI components support tooltips out-of-the-box via observable properties
(see tooltip
and tooltipPosition
).
Displaying tooltips
To display a tooltip, set data-cke-tooltip-text
attribute on any DOM element:
domElement.dataset.ckeTooltipText = 'My tooltip';
The tooltip will show up whenever the user moves the mouse over the element or the element gets focus in DOM.
Positioning tooltips
To change the position of the tooltip, use the data-cke-tooltip-position
attribute (s
, se
, sw
, n
, e
, or w
):
domElement.dataset.ckeTooltipText = 'Tooltip to the north';
domElement.dataset.ckeTooltipPosition = 'n';
Disabling tooltips
In order to disable the tooltip temporarily, use the data-cke-tooltip-disabled
attribute:
domElement.dataset.ckeTooltipText = 'Disabled. For now.';
domElement.dataset.ckeTooltipDisabled = 'true';
Styling tooltips
By default, the tooltip has .ck-tooltip
class and its text inner .ck-tooltip__text
.
If your tooltip requires custom styling, using data-cke-tooltip-class
attribute will add additional class to the balloon
displaying the tooltip:
domElement.dataset.ckeTooltipText = 'Tooltip with a red text';
domElement.dataset.ckeTooltipClass = 'my-class';
.ck.ck-tooltip.my-class { color: red }
Note: This class is a singleton. All editor instances re-use the same instance loaded by
EditorUI
of the first editor.
Filtering
Properties
-
readonly
balloonPanelView : BalloonPanelView
module:ui/tooltipmanager~TooltipManager#balloonPanelView
The instance of the balloon panel that renders and positions the tooltip.
-
The view rendering text of the tooltip.
-
private
_currentElementWithTooltip : null | HTMLElement
module:ui/tooltipmanager~TooltipManager#_currentElementWithTooltip
Stores the reference to the DOM element the tooltip is attached to.
null
when there's no tooltip in the UI. -
private
_currentTooltipPosition : null | TooltipPosition
module:ui/tooltipmanager~TooltipManager#_currentTooltipPosition
Stores the current tooltip position.
null
when there's no tooltip in the UI. -
private
_mutationObserver : null | MutationObserverWrapper
module:ui/tooltipmanager~TooltipManager#_mutationObserver
An instance of the mutation observer that keeps track on target element attributes changes.
-
private
_pinTooltipDebounced : DebouncedFunc<( HTMLElement, TooltipData ) => void>
module:ui/tooltipmanager~TooltipManager#_pinTooltipDebounced
A debounced version of
_pinTooltip
. Tooltips show with a delay to avoid flashing and to improve the UX. -
private
_unpinTooltipDebounced : DebouncedFunc<VoidFunction>
module:ui/tooltipmanager~TooltipManager#_unpinTooltipDebounced
A debounced version of
_unpinTooltip
. Tooltips hide with a delay to allow hovering of their titles.
Static properties
-
static
defaultBalloonPositions : Record<string, PositioningFunction>
module:ui/tooltipmanager~TooltipManager.defaultBalloonPositions
A set of default positioning functions used by the
TooltipManager
to pin tooltips in different positions. -
A set of editors the single tooltip manager instance must listen to. This is mostly to handle
EditorUI#update
listeners from individual editors. -
A reference to the
TooltipManager
instance. The class is a singleton and as such, successive attempts at creating instances should return this instance.
Methods
-
constructor( editor )
module:ui/tooltipmanager~TooltipManager#constructor
-
inherited
delegate( events ) → EmitterMixinDelegateChain
module:ui/tooltipmanager~TooltipManager#delegate
Delegates selected events to another
Emitter
. For instance:emitterA.delegate( 'eventX' ).to( emitterB ); emitterA.delegate( 'eventX', 'eventY' ).to( emitterC );
then
eventX
is delegated (fired by)emitterB
andemitterC
along withdata
:emitterA.fire( 'eventX', data );
and
eventY
is delegated (fired by)emitterC
along withdata
:emitterA.fire( 'eventY', data );
Parameters
events : Array<string>
Event names that will be delegated to another emitter.
Returns
-
destroy( editor ) → void
module:ui/tooltipmanager~TooltipManager#destroy
Destroys the tooltip manager.
Note: The manager singleton cannot be destroyed until all editors that use it are destroyed.
Parameters
editor : Editor
The editor the manager was created for.
Returns
void
-
inherited
fire( eventOrInfo, args ) → GetEventInfo<TEvent>[ 'return' ]
module:ui/tooltipmanager~TooltipManager#fire
Fires an event, executing all callbacks registered for it.
The first parameter passed to callbacks is an
EventInfo
object, followed by the optionalargs
provided in thefire()
method call.Type parameters
Parameters
eventOrInfo : GetNameOrEventInfo<TEvent>
The name of the event or
EventInfo
object if event is delegated.args : TEvent[ 'args' ]
Additional arguments to be passed to the callbacks.
Returns
GetEventInfo<TEvent>[ 'return' ]
By default the method returns
undefined
. However, the return value can be changed by listeners through modification of theevt.return
's property (the event info is the first param of every callback).
-
inherited
listenTo( emitter, event, callback, [ options ] ) → void
module:ui/tooltipmanager~TooltipManager#listenTo:DOM_EMITTER
Registers a callback function to be executed when an event is fired in a specific (emitter) object.
Events can be grouped in namespaces using
:
. When namespaced event is fired, it additionally fires all callbacks for that namespace.// myEmitter.on( ... ) is a shorthand for myEmitter.listenTo( myEmitter, ... ). myEmitter.on( 'myGroup', genericCallback ); myEmitter.on( 'myGroup:myEvent', specificCallback ); // genericCallback is fired. myEmitter.fire( 'myGroup' ); // both genericCallback and specificCallback are fired. myEmitter.fire( 'myGroup:myEvent' ); // genericCallback is fired even though there are no callbacks for "foo". myEmitter.fire( 'myGroup:foo' );
An event callback can stop the event and set the return value of the
fire
method.Type parameters
Parameters
emitter : Emitter
The object that fires the event.
event : TEvent[ 'name' ]
The name of the event.
callback : GetCallback<TEvent>
The function to be called on event.
[ options ] : CallbackOptions
Additional options.
Returns
void
-
inherited
listenTo( emitter, event, callback, [ options ] ) → void
module:ui/tooltipmanager~TooltipManager#listenTo:HTML_EMITTER
Registers a callback function to be executed when an event is fired in a specific Emitter or DOM Node. It is backwards compatible with
listenTo
.Type parameters
K : extends keyof DomEventMap
Parameters
emitter : Window | Node
The object that fires the event.
event : K
The name of the event.
callback : ( TooltipManager, EventInfo<string, unknown>, DomEventMap[ K ] ) => void
The function to be called on event.
[ options ] : object
Additional options.
Returns
void
-
Stops executing the callback on the given event. Shorthand for
this.stopListening( this, event, callback )
.Parameters
event : string
The name of the event.
callback : Function
The function to stop being called.
Returns
void
-
Registers a callback function to be executed when an event is fired.
Shorthand for
this.listenTo( this, event, callback, options )
(it makes the emitter listen on itself).Type parameters
Parameters
event : TEvent[ 'name' ]
The name of the event.
callback : GetCallback<TEvent>
The function to be called on event.
[ options ] : GetCallbackOptions<TEvent>
Additional options.
Returns
void
-
Registers a callback function to be executed on the next time the event is fired only. This is similar to calling
on
followed byoff
in the callback.Type parameters
Parameters
event : TEvent[ 'name' ]
The name of the event.
callback : GetCallback<TEvent>
The function to be called on event.
[ options ] : GetCallbackOptions<TEvent>
Additional options.
Returns
void
-
inherited
stopDelegating( [ event ], [ emitter ] ) → void
module:ui/tooltipmanager~TooltipManager#stopDelegating
Stops delegating events. It can be used at different levels:
- To stop delegating all events.
- To stop delegating a specific event to all emitters.
- To stop delegating a specific event to a specific emitter.
Parameters
[ event ] : string
The name of the event to stop delegating. If omitted, stops it all delegations.
[ emitter ] : Emitter
(requires
event
) The object to stop delegating a particular event to. If omitted, stops delegation ofevent
to all emitters.
Returns
void
-
inherited
stopListening( [ emitter ], [ event ], [ callback ] ) → void
module:ui/tooltipmanager~TooltipManager#stopListening:DOM_STOP
Stops listening for events. It can be used at different levels: It is backwards compatible with
listenTo
.- To stop listening to a specific callback.
- To stop listening to a specific event.
- To stop listening to all events fired by a specific object.
- To stop listening to all events fired by all objects.
Parameters
[ emitter ] : Window | Node | Emitter
The object to stop listening to. If omitted, stops it for all objects.
[ event ] : string
(Requires the
emitter
) The name of the event to stop listening to. If omitted, stops it for all events fromemitter
.[ callback ] : Function
(Requires the
event
) The function to be removed from the call list for the givenevent
.
Returns
void
-
private
_onEnterOrFocus( evt, domEvent ) → void
module:ui/tooltipmanager~TooltipManager#_onEnterOrFocus
Handles displaying tooltips on
mouseenter
andfocus
in DOM.Parameters
evt : EventInfo<string, unknown>
An object containing information about the fired event.
domEvent : any
The DOM event.
Returns
void
-
Handles hiding tooltips on
keydown
in DOM.Parameters
evt : EventInfo<string, unknown>
An object containing information about the fired event.
domEvent : KeyboardEvent
The DOM event.
Returns
void
-
private
_onLeaveOrBlur( evt, domEvent ) → void
module:ui/tooltipmanager~TooltipManager#_onLeaveOrBlur
Handles hiding tooltips on
mouseleave
andblur
in DOM.Parameters
evt : EventInfo<string, unknown>
An object containing information about the fired event.
domEvent : any
The DOM event.
Returns
void
-
Handles hiding tooltips on
scroll
in DOM.Parameters
evt : unknown
An object containing information about the fired event.
domEvent : any
The DOM event.
Returns
void
-
private
_pinTooltip( targetDomElement, __namedParameters ) → void
module:ui/tooltipmanager~TooltipManager#_pinTooltip
Pins the tooltip to a specific DOM element.
Parameters
targetDomElement : HTMLElement
__namedParameters : TooltipData
Returns
void
-
-
private
_updateTooltipPosition() → void
module:ui/tooltipmanager~TooltipManager#_updateTooltipPosition
Updates the position of the tooltip so it stays in sync with the element it is pinned to.
Hides the tooltip when the element is no longer visible in DOM or the tooltip text was removed.
Returns
void
Static methods
-
static
getPositioningFunctions( position ) → Array<PositioningFunction>
module:ui/tooltipmanager~TooltipManager.getPositioningFunctions
Returns
balloonPanelView
positioning functions for a given position name.Parameters
position : TooltipPosition
Name of the position (
s
,se
,sw
,n
,e
, orw
).
Returns
Array<PositioningFunction>
Positioning functions to be used by the
balloonPanelView
.
Every day, we work hard to keep our documentation complete. Have you spotted outdated information? Is something missing? Please report it via our issue tracker.
With the release of version 42.0.0, we have rewritten much of our documentation to reflect the new import paths and features. We appreciate your feedback to help us ensure its accuracy and completeness.