You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
52 lines
1.2 KiB
52 lines
1.2 KiB
/**
|
|
* Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
*
|
|
* This source code is licensed under the MIT license found in the
|
|
* LICENSE file in the root directory of this source tree.
|
|
*
|
|
* @format
|
|
* @flow
|
|
*/
|
|
|
|
'use strict';
|
|
|
|
type truncateOptions = {
|
|
breakOnWords: boolean,
|
|
minDelta: number,
|
|
elipsis: string,
|
|
...
|
|
};
|
|
|
|
const defaultOptions = {
|
|
breakOnWords: true,
|
|
minDelta: 10, // Prevents truncating a tiny bit off the end
|
|
elipsis: '...',
|
|
};
|
|
|
|
// maxChars (including ellipsis)
|
|
const truncate = function (
|
|
str: ?string,
|
|
maxChars: number,
|
|
options?: truncateOptions,
|
|
): ?string {
|
|
options = {...defaultOptions, ...options};
|
|
if (
|
|
str &&
|
|
str.length &&
|
|
str.length - options.minDelta + options.elipsis.length >= maxChars
|
|
) {
|
|
// If the slice is happening in the middle of a wide char, add one more char
|
|
const extraChar =
|
|
str.charCodeAt(maxChars - options.elipsis.length) > 255 ? 1 : 0;
|
|
str = str.slice(0, maxChars - options.elipsis.length + 1 + extraChar);
|
|
if (options.breakOnWords) {
|
|
const ii = Math.max(str.lastIndexOf(' '), str.lastIndexOf('\n'));
|
|
str = str.slice(0, ii);
|
|
}
|
|
str = str.trim() + options.elipsis;
|
|
}
|
|
return str;
|
|
};
|
|
|
|
module.exports = truncate;
|