@ckeditor/ckeditor5-typing
Version:
Typing feature for CKEditor 5.
50 lines (49 loc) • 1.53 kB
TypeScript
/**
* @license Copyright (c) 2003-2025, CKSource Holding sp. z o.o. All rights reserved.
* For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-licensing-options
*/
/**
* @module typing/utils/getlasttextline
*/
import type { Model, Range } from '@ckeditor/ckeditor5-engine';
/**
* Returns the last text line from the given range.
*
* "The last text line" is understood as text (from one or more text nodes) which is limited either by a parent block
* or by inline elements (e.g. `<softBreak>`).
*
* ```ts
* const rangeToCheck = model.createRange(
* model.createPositionAt( paragraph, 0 ),
* model.createPositionAt( paragraph, 'end' )
* );
*
* const { text, range } = getLastTextLine( rangeToCheck, model );
* ```
*
* For model below, the returned `text` will be "Foo bar baz" and `range` will be set on whole `<paragraph>` content:
*
* ```xml
* <paragraph>Foo bar baz<paragraph>
* ```
*
* However, in below case, `text` will be set to "baz" and `range` will be set only on "baz".
*
* ```xml
* <paragraph>Foo<softBreak></softBreak>bar<softBreak></softBreak>baz<paragraph>
* ```
*/
export default function getLastTextLine(range: Range, model: Model): LastTextLineData;
/**
* The value returned by {@link module:typing/utils/getlasttextline~getLastTextLine}.
*/
export type LastTextLineData = {
/**
* The text from the text nodes in the last text line.
*/
text: string;
/**
* The range set on the text nodes in the last text line.
*/
range: Range;
};