debian-mirror-gitlab/app/assets/javascripts/lib/utils/text_utility.js

203 lines
4.7 KiB
JavaScript
Raw Normal View History

2019-07-07 11:18:12 +05:30
import _ from 'underscore';
2018-03-17 18:26:18 +05:30
/**
* Adds a , to a string composed by numbers, at every 3 chars.
*
* 2333 -> 2,333
* 232324 -> 232,324
*
* @param {String} text
* @returns {String}
*/
2018-05-09 12:01:36 +05:30
export const addDelimiter = text =>
2018-12-13 13:39:08 +05:30
text ? text.toString().replace(/\B(?=(\d{3})+(?!\d))/g, ',') : text;
2017-09-10 17:25:29 +05:30
2018-03-17 18:26:18 +05:30
/**
* Returns '99+' for numbers bigger than 99.
*
* @param {Number} count
* @return {Number|String}
*/
export const highCountTrim = count => (count > 99 ? '99+' : count);
2017-08-17 22:00:37 +05:30
2018-03-17 18:26:18 +05:30
/**
* Converts first char to uppercase and replaces undercores with spaces
* @param {String} string
* @requires {String}
*/
2018-05-09 12:01:36 +05:30
export const humanize = string =>
string.charAt(0).toUpperCase() + string.replace(/_/g, ' ').slice(1);
2017-08-17 22:00:37 +05:30
2018-03-17 18:26:18 +05:30
/**
* Replaces underscores with dashes
* @param {*} str
* @returns {String}
*/
export const dasherize = str => str.replace(/[_\s]+/g, '-');
2017-08-17 22:00:37 +05:30
2018-03-17 18:26:18 +05:30
/**
2019-12-26 22:10:19 +05:30
* Replaces whitespace and non-sluggish characters with a given separator
* @param {String} str - The string to slugify
* @param {String=} separator - The separator used to separate words (defaults to "-")
2018-03-17 18:26:18 +05:30
* @returns {String}
*/
2019-12-26 22:10:19 +05:30
export const slugify = (str, separator = '-') => {
2019-09-30 21:07:59 +05:30
const slug = str
.trim()
.toLowerCase()
2019-12-26 22:10:19 +05:30
.replace(/[^a-zA-Z0-9_.-]+/g, separator);
2019-09-30 21:07:59 +05:30
2019-12-26 22:10:19 +05:30
return slug === separator ? '' : slug;
2019-09-30 21:07:59 +05:30
};
2017-08-17 22:00:37 +05:30
2018-11-20 20:47:30 +05:30
/**
2019-12-26 22:10:19 +05:30
* Replaces whitespace and non-sluggish characters with underscores
2018-11-20 20:47:30 +05:30
* @param {String} str
* @returns {String}
*/
2019-12-26 22:10:19 +05:30
export const slugifyWithUnderscore = str => slugify(str, '_');
2018-11-20 20:47:30 +05:30
2018-03-17 18:26:18 +05:30
/**
* Truncates given text
*
* @param {String} string
* @param {Number} maxLength
* @returns {String}
*/
2018-05-09 12:01:36 +05:30
export const truncate = (string, maxLength) => `${string.substr(0, maxLength - 3)}...`;
2017-08-17 22:00:37 +05:30
2018-11-08 19:23:39 +05:30
/**
* Truncate SHA to 8 characters
*
* @param {String} sha
* @returns {String}
*/
export const truncateSha = sha => sha.substr(0, 8);
2019-03-02 22:35:43 +05:30
const ELLIPSIS_CHAR = '…';
export const truncatePathMiddleToLength = (text, maxWidth) => {
let returnText = text;
let ellipsisCount = 0;
while (returnText.length >= maxWidth) {
const textSplit = returnText.split('/').filter(s => s !== ELLIPSIS_CHAR);
const middleIndex = Math.floor(textSplit.length / 2);
returnText = textSplit
.slice(0, middleIndex)
.concat(
new Array(ellipsisCount + 1).fill().map(() => ELLIPSIS_CHAR),
textSplit.slice(middleIndex + 1),
)
.join('/');
ellipsisCount += 1;
}
return returnText;
};
2018-03-17 18:26:18 +05:30
/**
* Capitalizes first character
*
* @param {String} text
* @return {String}
*/
export function capitalizeFirstCharacter(text) {
return `${text[0].toUpperCase()}${text.slice(1)}`;
}
2017-08-17 22:00:37 +05:30
2018-11-18 11:00:15 +05:30
/**
* Returns the first character capitalized
*
* If falsey, returns empty string.
*
* @param {String} text
* @return {String}
*/
export function getFirstCharacterCapitalized(text) {
2018-12-13 13:39:08 +05:30
return text ? text.charAt(0).toUpperCase() : '';
2018-11-18 11:00:15 +05:30
}
2018-03-17 18:26:18 +05:30
/**
* Replaces all html tags from a string with the given replacement.
*
* @param {String} string
* @param {*} replace
* @returns {String}
*/
2018-10-15 14:42:47 +05:30
export const stripHtml = (string, replace = '') => {
if (!string) return string;
return string.replace(/<[^>]*>/g, replace);
};
2016-09-13 17:45:13 +05:30
2018-03-17 18:26:18 +05:30
/**
* Converts snake_case string to camelCase
*
* @param {*} string
*/
export const convertToCamelCase = string => string.replace(/(_\w)/g, s => s[1].toUpperCase());
2018-05-09 12:01:36 +05:30
2019-12-26 22:10:19 +05:30
/**
* Converts camelCase string to snake_case
*
* @param {*} string
*/
export const convertToSnakeCase = string =>
slugifyWithUnderscore(string.match(/([a-zA-Z][^A-Z]*)/g).join(' '));
2018-05-09 12:01:36 +05:30
/**
* Converts a sentence to lower case from the second word onwards
* e.g. Hello World => Hello world
*
* @param {*} string
*/
export const convertToSentenceCase = string => {
const splitWord = string.split(' ').map((word, index) => (index > 0 ? word.toLowerCase() : word));
return splitWord.join(' ');
};
2018-11-08 19:23:39 +05:30
/**
* Splits camelCase or PascalCase words
* e.g. HelloWorld => Hello World
*
* @param {*} string
2018-12-13 13:39:08 +05:30
*/
export const splitCamelCase = string =>
2018-11-08 19:23:39 +05:30
string
2018-12-13 13:39:08 +05:30
.replace(/([A-Z]+)([A-Z][a-z])/g, ' $1 $2')
.replace(/([a-z\d])([A-Z])/g, '$1 $2')
.trim();
2019-07-07 11:18:12 +05:30
/**
* Intelligently truncates an item's namespace by doing two things:
* 1. Only include group names in path by removing the item name
* 2. Only include the first and last group names in the path
* when the namespace includes more than 2 groups
*
* @param {String} string A string namespace,
* i.e. "My Group / My Subgroup / My Project"
*/
export const truncateNamespace = (string = '') => {
if (_.isNull(string) || !_.isString(string)) {
return '';
}
const namespaceArray = string.split(' / ');
if (namespaceArray.length === 1) {
return string;
}
namespaceArray.splice(-1, 1);
let namespace = namespaceArray.join(' / ');
if (namespaceArray.length > 2) {
namespace = `${namespaceArray[0]} / ... / ${namespaceArray.pop()}`;
}
return namespace;
};