mirror of
https://github.com/iib0011/omni-tools.git
synced 2025-12-29 16:16:02 +00:00
108 lines
2.8 KiB
TypeScript
108 lines
2.8 KiB
TypeScript
import { UpdateField } from '@components/options/ToolOptions';
|
|
|
|
// Here starting the shared values for string manipulation.
|
|
|
|
/**
|
|
* This map is used to replace special characters with their visual representations.
|
|
* It is useful for displaying strings in a more readable format, especially in tools
|
|
**/
|
|
|
|
export const specialCharMap: { [key: string]: string } = {
|
|
'': '␀',
|
|
' ': '␣',
|
|
'\n': '↲',
|
|
'\t': '⇥',
|
|
'\r': '␍',
|
|
'\f': '␌',
|
|
'\v': '␋'
|
|
};
|
|
|
|
// Here starting the utility functions for string manipulation.
|
|
|
|
export function capitalizeFirstLetter(string: string | undefined) {
|
|
if (!string) return '';
|
|
return string.charAt(0).toUpperCase() + string.slice(1);
|
|
}
|
|
|
|
export function isNumber(number: any): boolean {
|
|
return !isNaN(parseFloat(number)) && isFinite(number);
|
|
}
|
|
|
|
export const updateNumberField = <T>(
|
|
val: string,
|
|
key: keyof T,
|
|
updateField: UpdateField<T>
|
|
) => {
|
|
if (val === '') {
|
|
// @ts-ignore
|
|
updateField(key, '');
|
|
} else if (isNumber(val)) {
|
|
// @ts-ignore
|
|
updateField(key, Number(val));
|
|
}
|
|
};
|
|
|
|
export const replaceSpecialCharacters = (str: string) => {
|
|
return str
|
|
.replace(/\\"/g, '"')
|
|
.replace(/\\n/g, '\n')
|
|
.replace(/\\t/g, '\t')
|
|
.replace(/\\r/g, '\r')
|
|
.replace(/\\b/g, '\b')
|
|
.replace(/\\f/g, '\f')
|
|
.replace(/\\v/g, '\v');
|
|
};
|
|
|
|
export function reverseString(input: string): string {
|
|
return input.split('').reverse().join('');
|
|
}
|
|
|
|
/**
|
|
* Checks if the input string contains only digits.
|
|
* @param input - The string to validate.
|
|
* @returns True if the input contains only digits including float, false otherwise.
|
|
*/
|
|
export function containsOnlyDigits(input: string): boolean {
|
|
return /^\d+(\.\d+)?$/.test(input.trim());
|
|
}
|
|
|
|
/**
|
|
* unquote a string if properly quoted.
|
|
* @param value - The string to unquote.
|
|
* @param quoteCharacter - The character used for quoting (e.g., '"', "'").
|
|
* @returns The unquoted string if it was quoted, otherwise the original string.
|
|
*/
|
|
export function unquoteIfQuoted(value: string, quoteCharacter: string): string {
|
|
if (
|
|
quoteCharacter &&
|
|
value.startsWith(quoteCharacter) &&
|
|
value.endsWith(quoteCharacter)
|
|
) {
|
|
return value.slice(1, -1); // Remove first and last character
|
|
}
|
|
return value;
|
|
}
|
|
|
|
/**
|
|
* Count the occurence of items.
|
|
* @param array - array get from user with a custom delimiter.
|
|
* @param ignoreItemCase - boolean status to ignore the case i .
|
|
* @returns Dict of Items count {[Item]: occcurence}.
|
|
*/
|
|
export function itemCounter(
|
|
array: string[],
|
|
ignoreItemCase: boolean
|
|
): { [key: string]: number } {
|
|
const dict: { [key: string]: number } = {};
|
|
for (const item of array) {
|
|
let key = ignoreItemCase ? item.toLowerCase() : item;
|
|
|
|
if (key in specialCharMap) {
|
|
key = specialCharMap[key];
|
|
}
|
|
|
|
dict[key] = (dict[key] || 0) + 1;
|
|
}
|
|
return dict;
|
|
}
|