MarkerCollection (engine/model)
@ckeditor/ckeditor5-engine/src/model/markercollection
The collection of all markers attached to the document. It lets you get markers or track them using event-update event.
To create, change or remove makers use model writers' methods:
addMarker
or removeMarker
. Since
the writer is the only proper way to change the data model it is not possible to change markers directly using this
collection. All markers created by the writer will be automatically added to this collection.
By default there is one marker collection available as model property.
Filtering
Properties
-
private
_markers : Map<string, Marker>
module:engine/model/markercollection~MarkerCollection#_markers
Stores markers added to the collection.
Methods
-
Symbol.iterator() → IterableIterator<Marker>
module:engine/model/markercollection~MarkerCollection#Symbol.iterator
-
inherited
delegate( events ) → EmitterMixinDelegateChain
module:engine/model/markercollection~MarkerCollection#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() → void
module:engine/model/markercollection~MarkerCollection#destroy
-
inherited
fire( eventOrInfo, args ) → GetEventInfo<TEvent>[ 'return' ]
module:engine/model/markercollection~MarkerCollection#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).
-
getMarkersAtPosition( position ) → IterableIterator<Marker>
module:engine/model/markercollection~MarkerCollection#getMarkersAtPosition
-
getMarkersGroup( prefix ) → IterableIterator<Marker>
module:engine/model/markercollection~MarkerCollection#getMarkersGroup
Iterates over all markers that starts with given
prefix
.const markerFooA = markersCollection._set( 'foo:a', rangeFooA ); const markerFooB = markersCollection._set( 'foo:b', rangeFooB ); const markerBarA = markersCollection._set( 'bar:a', rangeBarA ); const markerFooBarA = markersCollection._set( 'foobar:a', rangeFooBarA ); Array.from( markersCollection.getMarkersGroup( 'foo' ) ); // [ markerFooA, markerFooB ] Array.from( markersCollection.getMarkersGroup( 'a' ) ); // []
Parameters
prefix : string
Returns
IterableIterator<Marker>
-
getMarkersIntersectingRange( range ) → Iterable<Marker>
module:engine/model/markercollection~MarkerCollection#getMarkersIntersectingRange
-
has( markerOrName ) → boolean
module:engine/model/markercollection~MarkerCollection#has
-
inherited
listenTo( emitter, event, callback, [ options ] ) → void
module:engine/model/markercollection~MarkerCollection#listenTo:BASE_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 ] : GetCallbackOptions<TEvent>
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
-
inherited
on( event, callback, [ options ] ) → void
module:engine/model/markercollection~MarkerCollection#on
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
-
inherited
once( event, callback, [ options ] ) → void
module:engine/model/markercollection~MarkerCollection#once
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:engine/model/markercollection~MarkerCollection#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:engine/model/markercollection~MarkerCollection#stopListening:BASE_STOP
Stops listening for events. It can be used at different levels:
- 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 ] : 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
-
internal
_refresh( markerOrName ) → void
module:engine/model/markercollection~MarkerCollection#_refresh
Fires an event-update event for the given marker but does not change the marker. Useful to force downcast conversion for the marker.
Parameters
markerOrName : string | Marker
Marker or name of a marker to refresh.
Returns
void
Fires
-
internal
_remove( markerOrName ) → boolean
module:engine/model/markercollection~MarkerCollection#_remove
-
internal
_set( markerOrName, range, managedUsingOperations, affectsData ) → Marker
module:engine/model/markercollection~MarkerCollection#_set
Creates and adds a marker to the
MarkerCollection
with given name on given range.If
MarkerCollection
already had a marker with given name (or marker was passed), the marker in collection is updated and event-update event is fired but only if there was a change (marker range ormanagedUsingOperations
flag has changed.Parameters
markerOrName : string | Marker
Name of marker to set or marker instance to update.
range : Range
Marker range.
managedUsingOperations : boolean
Specifies whether the marker is managed using operations.
Defaults to
false
affectsData : boolean
Specifies whether the marker affects the data produced by the data pipeline (is persisted in the editor's data).
Defaults to
false
Returns
Marker
Marker
instance which was added or updated.
Fires
-
private
_destroyMarker( marker ) → void
module:engine/model/markercollection~MarkerCollection#_destroyMarker
Events
-
update( eventInfo, marker, oldRange, newRange, oldMarkerData )
module:engine/model/markercollection~MarkerCollection#event:update
Fired whenever marker is added, updated or removed from
MarkerCollection
.Parameters
eventInfo : EventInfo
An object containing information about the fired event.
marker : Marker
Updated Marker.
oldRange : Range | null
Marker range before the update. When is not defined it means that marker is just added.
newRange : Range | null
Marker range after update. When is not defined it means that marker is just removed.
oldMarkerData : MarkerData
Data of the marker before the change.
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.