micro-fp-tools-js/src/fnTools.ts

216 lines
5.1 KiB
TypeScript
Raw Normal View History

2022-02-01 15:45:07 +01:00
/**
2022-02-05 18:14:35 +01:00
* Increase the value of a `number`.
*
* @param {number} number The number to increase.
* @param {number} number Increase.
* @return {number} Returns the decrease.
2022-02-04 07:27:23 +01:00
* @example
2022-02-01 15:45:07 +01:00
*
2022-02-05 18:14:35 +01:00
* inc(4)
* // => 5
*
* inc(5, 3)
* // => 8
*
* inc(7.3)
* // => 8.3
2022-02-01 15:45:07 +01:00
*
*/
2022-02-05 18:14:35 +01:00
export function inc(number: number, increase: number=1): number {
return number + increase;
}
/**
* Decrease the value of a `number`.
*
* @param {number} number - The number to decrease.
* @param {number} number - Decrease.
* @return {number} Returns the decrease.
* @example
*
* dec(4)
* // => 3
*
* dec(5, 3)
* // => 2
*
* dec(7.3)
* // => 6.3
*
* dec("foo")
* // => false
*/
export function dec(number: number, decrease: number=1): number {
return number - decrease;
2022-02-01 15:45:07 +01:00
}
2022-02-03 21:01:56 +01:00
2022-02-05 09:39:39 +01:00
2022-02-03 21:01:56 +01:00
/**
* Returns an array with a sequence.
*
2022-02-04 07:18:31 +01:00
* @param {number} start - Beginning of the range.
* @param {number} stop - End of range.
* @param {number} step - Interval between numbers. Default is 1.
2022-02-03 21:06:03 +01:00
* @return {Array} Sequence.
2022-02-04 07:18:31 +01:00
* @example
*
2022-02-05 09:39:39 +01:00
* range(4)
* // => [0, 1, 2, 3, 4]
*
* range(2, 4)
* // => [2, 3, 4]
*
* range(0, 9, 3)
* // => [0, 3, 6, 9]
2022-02-03 21:01:56 +01:00
*/
2022-02-05 18:14:35 +01:00
export function range(start: number, stop: number | null=null, step: number=1): number[] {
2022-02-04 07:27:23 +01:00
const startArray = stop === null ? 0 : start;
const stopArray = stop === null ? start : stop;
2022-02-03 21:01:56 +01:00
return Array.from({ length: (stopArray - startArray) / step + 1}, (_, i) => startArray + (i * step));
}
2022-02-03 21:36:41 +01:00
/**
2022-02-05 18:14:35 +01:00
* Returns a JSON with an updated value
* @param {string} key
* @param {string} newValue
* @param {JSON} json
* @return {JSON}
2022-02-03 21:36:41 +01:00
* @example
*
2022-02-05 18:14:35 +01:00
* const person = {name: 'James', age: 20, pets: ['dog', 'cat']};
* updateJSON('name', 'maria', person);
* // {"age": 20, "name": "maria", "pets": ["dog", "cat"]}
*
* Others: "modify" in Ramda
2022-02-03 21:36:41 +01:00
*/
2022-02-05 18:14:35 +01:00
export function updateJSON(key: string, newValue: any, json: JSON): JSON {
// JSON to Array
return Object.entries(json).map(
function (row: any[]): any[] {
// Replace value
return row[0] == key ? row.slice(0, 1).concat(newValue) : row
}
).reduce(
function (jsonUpdate: any, valueUpdate: any): JSON {
// Array to JSON
jsonUpdate[valueUpdate[0]] = valueUpdate[1];
return jsonUpdate;
}, {});
2022-02-03 21:36:41 +01:00
}
/**
2022-02-05 18:14:35 +01:00
* Creates a duplicate-free version of an array.
2022-02-03 21:36:41 +01:00
*
2022-02-05 18:14:35 +01:00
* @param {Array} array - The array to inspect.
* @return {Array} - Returns the new duplicate free array.
2022-02-03 21:36:41 +01:00
* @example
*
2022-02-05 18:14:35 +01:00
* uniqValuesArray([2, 1, 2, 2])
* // => [2, 1]
2022-02-03 21:36:41 +01:00
*/
2022-02-05 18:14:35 +01:00
export function uniqValuesArray(array: any[]): any[] {
return Array.from(new Set(array));
2022-02-03 21:36:41 +01:00
}
/**
2022-02-05 18:14:35 +01:00
* Clone JSON.
2022-02-03 21:36:41 +01:00
*
2022-02-05 18:14:35 +01:00
* @param {JSON} json - Object. Default {}.
* @return {JSON} New object.
2022-02-03 21:36:41 +01:00
* @example
*
2022-02-05 18:14:35 +01:00
* cloneObject({"edad": 23})
* // => {"edad": 23}
2022-02-03 21:36:41 +01:00
*
2022-02-05 18:14:35 +01:00
* cloneObject()
* // => {}
2022-02-03 21:36:41 +01:00
*
*/
2022-02-05 18:14:35 +01:00
export function cloneJSON(json: JSON): JSON {
return JSON.parse(JSON.stringify(json));
2022-02-06 22:26:49 +01:00
}
/**
* Return random number.
*
* @param {number} min - Minimum number. It is inclusive.
* @param {number} max - Maximum number. It is inclusive.
* @param {number} decimals - Number of decimals. Default 0.
* @return {number}
* @example
*
* getRandom(0, 4)
* // => 3 (Maybe)
*
* getRandom(0, 10, 2)
* // => 8.31 (Maybe)
*
*/
export function getRandom(min, max, decimals=0) {
const minRandom = Math.ceil(min);
const maxRandom = Math.floor(max);
return (Math.random() * (maxRandom - minRandom + 1) + minRandom).toFixed(decimals);
2022-02-09 16:57:17 +01:00
}
/**
* Returns the index of an Array of Files from its name. If there are multiple files with the same name, the last one will be returned.
* @param {string} name - Name file.
* @param {Array<File>} list - List of files.
* @return number
*/
2022-02-09 16:57:28 +01:00
export function getIndexOfFileList(name: string, list: Array<File>): number {
2022-02-09 16:57:17 +01:00
return list.reduce(
(position, file, index) => (file.name === name ? index : position),
-1
);
}
2022-02-09 17:03:34 +01:00
/**
* Returns a copy of the array by removing one position by index.
* @param {number} index
2022-02-10 09:33:36 +01:00
* @param {Array} list
2022-02-09 17:03:34 +01:00
* @return {Array} list
2022-02-10 09:33:36 +01:00
* @example
*
* deleteArrayElementByIndex(2, ['a', 'b', 'c', 'd'])
* // => ['a', 'b', 'd']
2022-02-09 17:03:34 +01:00
*/
2022-02-10 09:33:36 +01:00
export function deleteArrayElementByIndex(index: number, list: Array<any>): FileList {
2022-02-09 17:03:34 +01:00
return list.filter((item, itemIndex) => itemIndex !== index);
}
2022-02-10 09:22:29 +01:00
/**
* Returns a FileLists from an array containing Files.
* @param {Array<File>} filesList
* @return {FileList}
*/
export function arrayFilesToFileList(filesList) {
return filesList.reduce(function (dataTransfer, file) {
dataTransfer.items.add(file);
return dataTransfer;
}, new DataTransfer()).files;
}
2022-02-10 09:30:34 +01:00
/**
* Returns a copy of the Array by swapping 2 indices.
* @param {number} firstIndex
* @param {number} secondIndex
* @param {Array<any>} list
2022-02-10 09:33:36 +01:00
* @example
*
* arraySwapIndex(0, 2, ['a', 'b', 'c', 'd'])
* // => ['c', 'b', 'a', 'd']
2022-02-10 09:30:34 +01:00
*/
export function arraySwapIndex(firstIndex: number, secondIndex: number, list: Array<any>): Array<any> {
const tempList = list.slice();
const tmpFirstPos = tempList[firstIndex];
tempList[firstIndex] = tempList[secondIndex];
tempList[secondIndex] = tmpFirstPos;
return tempList;
}