UNPKG

@ckeditor/ckeditor5-table

Version:

Table feature for CKEditor 5.

87 lines (86 loc) 3.09 kB
/** * @license Copyright (c) 2003-2023, CKSource Holding sp. z o.o. All rights reserved. * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license */ import { isObject } from 'lodash-es'; /** * Returns a string if all four values of box sides are equal. * * If a string is passed, it is treated as a single value (pass-through). * * ```ts * // Returns 'foo': * getSingleValue( { top: 'foo', right: 'foo', bottom: 'foo', left: 'foo' } ); * getSingleValue( 'foo' ); * * // Returns undefined: * getSingleValue( { top: 'foo', right: 'foo', bottom: 'bar', left: 'foo' } ); * getSingleValue( { top: 'foo', right: 'foo' } ); * ``` */ export function getSingleValue(objectOrString) { if (!objectOrString || !isObject(objectOrString)) { return objectOrString; } const { top, right, bottom, left } = objectOrString; if (top == right && right == bottom && bottom == left) { return top; } } /** * Adds a unit to a value if the value is a number or a string representing a number. * * **Note**: It does nothing to non-numeric values. * * ```ts * getSingleValue( 25, 'px' ); // '25px' * getSingleValue( 25, 'em' ); // '25em' * getSingleValue( '25em', 'px' ); // '25em' * getSingleValue( 'foo', 'px' ); // 'foo' * ``` * * @param defaultUnit A default unit added to a numeric value. */ export function addDefaultUnitToNumericValue(value, defaultUnit) { const numericValue = parseFloat(value); if (Number.isNaN(numericValue)) { return value; } if (String(numericValue) !== String(value)) { return value; } return `${numericValue}${defaultUnit}`; } /** * Returns the normalized configuration. * * @param options.includeAlignmentProperty Whether the "alignment" property should be added. * @param options.includePaddingProperty Whether the "padding" property should be added. * @param options.includeVerticalAlignmentProperty Whether the "verticalAlignment" property should be added. * @param options.includeHorizontalAlignmentProperty Whether the "horizontalAlignment" property should be added. * @param options.isRightToLeftContent Whether the content is right-to-left. */ export function getNormalizedDefaultProperties(config, options = {}) { const normalizedConfig = { borderStyle: 'none', borderWidth: '', borderColor: '', backgroundColor: '', width: '', height: '', ...config }; if (options.includeAlignmentProperty && !normalizedConfig.alignment) { normalizedConfig.alignment = 'center'; } if (options.includePaddingProperty && !normalizedConfig.padding) { normalizedConfig.padding = ''; } if (options.includeVerticalAlignmentProperty && !normalizedConfig.verticalAlignment) { normalizedConfig.verticalAlignment = 'middle'; } if (options.includeHorizontalAlignmentProperty && !normalizedConfig.horizontalAlignment) { normalizedConfig.horizontalAlignment = options.isRightToLeftContent ? 'right' : 'left'; } return normalizedConfig; }