@ckeditor/ckeditor5-list
Version:
Ordered and unordered lists feature to CKEditor 5.
53 lines (52 loc) • 1.81 kB
JavaScript
/**
* @license Copyright (c) 2003-2024, CKSource Holding sp. z o.o. All rights reserved.
* For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license
*/
/**
* @module list/legacylistproperties/legacylistreversedcommand
*/
import { Command } from 'ckeditor5/src/core.js';
import { getSelectedListItems } from '../legacylist/legacyutils.js';
/**
* The reversed list command. It changes the `listReversed` attribute of the selected list items. As a result, the list order will be
* reversed.
* It is used by the {@link module:list/legacylistproperties~LegacyListProperties legacy list properties feature}.
*/
export default class LegacyListReversedCommand extends Command {
/**
* @inheritDoc
*/
refresh() {
const value = this._getValue();
this.value = value;
this.isEnabled = value != null;
}
/**
* Executes the command.
*
* @fires execute
* @param options.reversed Whether the list should be reversed.
*/
execute(options = {}) {
const model = this.editor.model;
const listItems = getSelectedListItems(model)
.filter(item => item.getAttribute('listType') == 'numbered');
model.change(writer => {
for (const item of listItems) {
writer.setAttribute('listReversed', !!options.reversed, item);
}
});
}
/**
* Checks the command's {@link #value}.
*
* @returns The current value.
*/
_getValue() {
const listItem = this.editor.model.document.selection.getFirstPosition().parent;
if (listItem && listItem.is('element', 'listItem') && listItem.getAttribute('listType') == 'numbered') {
return listItem.getAttribute('listReversed');
}
return null;
}
}