jsoft-agile v2.4.3
jsoft-agile
A node.js module that provides a collection of ready-made functions used on large systems for their development.
Getting Started
Prerequisites
This module was developed in node.js v10.16.3.
We recommend using node.js v10.x or higher.Installation
This is a Node.js module available through the npm registry.
Installation is done using the npm install command:
$ npm install --save jsoft-agile or in development mode:
$ npm install --save-dev jsoft-agile Loading
you can load this module like this:
const jagile = require("jsoft-agile");
or
const {wallFilters, ...} = require("jsoft-agile")or like this:
import jagile from "jsoft-agile";
or
import {inObject, ...} from "jsoft-agile";What jsoft-agile offers us?
Added in version 2.x
2.4.3
Faster and fully independent.
2.2.0
isNamecheck if the passed value is a name
Improvements: correctName, isUsername, inArrayAnyValue, inObjectAnyProp and removeArrayElements
2.1.0
isAllcheck if all elements ofarrayaretypeofpassed
2.0.0
inArrayAnyValuecheck if any value exists insidearrayinObjectAnyPropcheck if any prop exists insideobjecthasValueAllProps*check if all props have value*getTypeofget type of value like "commonNumber, commonObject, array, function, etc..."wallFilters*validates or filters all data according to a rule*
Added in version 1.x
isStringcheck if the passed value is astringisAllStringcheck if all elements of an array arestringsisNumbercheck if the passed value is anumberisCommonNumberchecks if the passed value is acommonNumberlike "-1, 0, 1, 1.2, etc..."isAllCommonNumbercheck if all elements of an array arecommonNumberlike "-1, 0, 1, 1.2, etc..."isBooleancheck if the passed value is abooleanisAllBooleancheck if all elements of an array arebooleanisObjectcheck if the passed value is aobjectlike "null, {}, etc..."isObjectIdcheck if the passed value is aobjectIdlike "5db7e872dab3eb3d7cc44080"isAllObjectIdcheck if all elements of an array areobjectIdlike "5db7e872dab3eb3d7cc44080isCommonObjectCheck if the passed value is acommonObjectlike "{}"isAllCommonObjectcheck if all elements of an array arecommonObjectlike "{}"isArraycheck if the passed value is anarrayisAllArraycheck if all elements of an array arearrayisEmailcheck if the passed value is anemailisUsernamecheck if the passed value is ausernamelike "joao99, jay99, jay, etc..."isPhoneNumbercheck if the passed value is an international phone number like "+244 913 056 212, +555 555 1234"inArraycheck if value exists insidearrayinObjectcheck if prop exists insideobjecthasValue*check if has some value*hasAllValues*check if all elements of an array has value*justifySpaceWords*justify space between words*capitalizeText*make the first letters of words capitalized*checkMinValueEachWords*check the minimum amount of characters for each word*checkMaxValueEachWords*check the maximum amount of characters for each word*checkMinAndMaxValueEachWord*check the minimum and maximum amount of characters for each word*correctName*remove special characters and space except accents*getArrayElements*getarrayelements*getObjectProps*getobjectprops*getOnlyNumber*get only numbers*getElementPos*get the first position of anarrayofobjectsby field and value*generateObjectIdgenerates a uniqueobjectIdlike "5db7e872dab3eb3d7cc44080"removeArrayElementsremovearrayelementsremoveObjectPropsremoveobjectpropertiesuniqueArrayremove repeated elements fromarrayuniqueArrayObjectByremove repeated elements from anarrayofobjectsby propertyexistModulecheck if there is a node.js module like "http, jsoft-agile, etc..."
37 functions ready for youHow can I use?
isString
Check if the passed value is a string. The return is boolean.
Syntax
isString: (value: any) => booleanUse
// example
console.log(jagile.isString("jay"));
> true
console.log(jagile.isString(19));
> false
console.log(jagile.isString({}));
> false
// and so on...isAllString
Check if all elements of an array are string. The return is boolean.
Syntax
isAllString: (values: array) => booleanUse
// example
console.log(jagile.isAllString(["jay", "trindade", "jsoft"]))
> true
// example - 2
let name = "João Trindade",
username = "joaotrindade.soft"
console.log(jagile.isAllString([name, username]))
> true
// example - 3
let stack = "MERN",
username = "jaytrindade",
id = 145678
console.log(jagile.isAllString([stack, username, id]))
> false
// example - 4
console.log(jagile.isAllString(["joão", 1, NaN, {}]))
> false
// and so on...isNumber
Check if the passed value is a number. The return is boolean.
Syntax
isNumber: (value: any) => booleanUse
// example
console.log(jagile.isNumber(1));
> true
console.log(jagile.isNumber(NaN));
> true
console.log(jagile.isNumber("jay"));
> false
// and so on...isCommonNumber
Checks if the passed value is a commonNumber like "-1, 0, 1, 2.1, etc...". The return is boolean.
Syntax
isCommonNumber: (value: any) => booleanUse
// example
console.log(jagile.isCommonNumber(1));
> true
console.log(jagile.isCommonNumber(NaN));
> false
console.log(jagile.isCommonNumber("jay"));
> false
// and so on...isAllCommonNumber
Check if all elements of an array are commonNumber like "-1, 0, 1, 2.1, etc...". The return is boolean.
Syntax
isAllCommonNumber: (values: array) => booleanUse
// example
console.log(jagile.isAllCommonNumber([-10, 20, 0, 1.2]))
> true
// example - 2
let age = 19,
id = 13456
console.log(jagile.isAllCommonNumber([age, id]))
> true
// example - 3
console.log(jagile.isAllCommonNumber([8, NaN, 50]))
> false
// example - 4
let name = "joão trindade",
id = 145678
console.log(jagile.isAllCommonNumber([name, id]))
> false
// and so on...isBoolean
Check if the passed value is a boolean. The return is boolean.
Syntax
isBoolean: (value: any) => booleanUse
// example
console.log(jagile.isBoolean(true));
> true
console.log(jagile.isBoolean(1));
> false
console.log(jagile.isBoolean("jay"));
> false
// and so on...isAllBoolean
Check if all elements of an array are boolean. The return is boolean.
Syntax
isAllBoolean: (values: any) => booleanUse
// example
console.log(jagile.isAllBoolean([true, false]))
> true
// example - 2
let cool = true,
data = 100
console.log(jagile.isAllBoolean([cool, data]))
> false
// and so on...isAll
Check if all elements of array are typeof passed. The return is boolean.
Syntax
isAll: (values: any, type: string) => booleanUse
// example
console.log(jagile.isAll([true, false], "boolean"))
> true
console.log(jagile.isAll([1, 2.1], "commonNumber"))
> true
console.log(jagile.isAll([1, "jay"], "string"))
> false
// and so on...isObject
Check if the passed value is a object. The return is boolean.
Syntax
isObject: (value: any) => booleanUse
// example
console.log(jagile.isObject({}));
> true
console.log(jagile.isObject([]));
> true
console.log(jagile.isObject(null));
> true
console.log(jagile.isObject(1));
> false
console.log(jagile.isObject("jay"));
> false
// and so on...isObjectId
Check if the passed value is a objectId like "5db7e872dab3eb3d7cc44080". The return is boolean.
Syntax
isObjectId: (value: any) => booleanUse
// example
console.log(jagile.isObjectId("5db7e872dab3eb3d7cc44080"));
> true
console.log(jagile.isObjectId([]));
> false
console.log(jagile.isObjectId(null));
> false
console.log(jagile.isObjectId(1));
> false
console.log(jagile.isObjectId("jay"));
> false
// and so on ...isAllObjectId
Check if all elements of an array are objectId like "5db7e872dab3eb3d7cc44080. The return is boolean.
Syntax
isAllObjectId: (value: array) => booleanUse
// example
console.log(jagile.isAllObjectId(["5db7e872dab3eb3d7cc44080", "5db7e872dab3eb3d7cc44bcd"]))
> true
// example - 2
let obj1 = "5db7e872dab3eb3d7cc44080",
obj2 = "5db7e872dab3eb3d7cc44bcd"
console.log(jagile.isAllObjectId([obj1, obj2]))
> true
// example - 3
console.log(jagile.isAllObjectId([1, "Oops", {}]))
> false
// example - 4
console.log(jagile.isAllObjectId(["5db7e872dab3eb3d7cc44bcd", 1, false]))
> false
// and so on...isCommonObject
Check if the passed value is a commonObject like "{}". The return is boolean.
Syntax
isCommonObject: (value: any) => booleanUse
// example
console.log(jagile.isCommonObject({}));
> true
console.log(jagile.isCommonObject([]));
> false
console.log(jagile.isCommonObject(null));
> false
console.log(jagile.isCommonObject(1));
> false
console.log(jagile.isCommonObject("jay"));
> false
// and so on...isAllCommonObject
Check if all elements of an array are commonObject like "{}". The return is boolean.
Syntax
isAllCommonObject: (value: any) => booleanUse
// example
console.log(jagile.isAllCommonObject([{name: "jay"}, {age: 20}, {}]))
> true
// example - 2
let obj1 = {day: "today"},
obj2 = {name: "soft"}
console.log(jagile.isAllCommonObject([obj1, obj2]))
> true
// example - 3
console.log(jagile.isAllCommonObject([1, "Oops", {}]))
> false
// example - 4
console.log(jagile.isAllCommonObject([["jay", "trindade"], 1]))
> false
// and so on..isArray
Check if the passed value is an array. The return is boolean.
Syntax
isArray: (value: any) => booleanUse
// example
console.log(jagile.isArray([]));
> true
console.log(jagile.isArray(["jay", "trindade"]));
> true
console.log(jagile.isArray({}));
> false
console.log(jagile.isArray(1));
> false
console.log(jagile.isArray("jay"));
> false
// and so on...isAllArray
Check if all elements of an array are array. The return is boolean.
Syntax
isAllArray: (value: array) => booleanUse
// example
console.log(jagile.isAllArray([["jay"], [20], []]))
> true
// example - 2
let arr1 = ["some"],
arr2 = ["value"]
console.log(jagile.isAllArray([arr1, arr2]))
> true
// example - 3
console.log(jagile.isAllArray([1, "Oops", {}]))
> false
// example - 4
console.log(jagile.isAllArray([["jay", "trindade"], 1]))
> false
// and so on...isEmail
Check if the passed value is an email. The return is boolean.
Syntax
isEmail: (value: any) => booleanUse
// example
console.log(jagile.isEmail("joaotrindade.soft@gmail.com"));
> true
console.log(jagile.isEmail("jay@gmail.com"));
> true
console.log(jagile.isEmail("jay@gmail"));
> false
console.log(jagile.isEmail("jay"));
> false
// and so on...isUsername
Check if the passed value is a username like "joao99, jay99, jay, etc...". The return is boolean.
Syntax
isUsername: (value: any, limitChar: ?number) => booleanUse
// example
console.log(jagile.isUsername("_joao99"));
> true
console.log(jagile.isUsername("@jay"));
> false
console.log(jagile.isUsername("12jay"));
> false
// and so on...isName
Check if the passed value is a correct name. The return is boolean.
Syntax
isName: (value: any) => booleanUse
// example
console.log(jagile.isName("Jay Trindade J'soft"));
> true
console.log(jagile.isName("João soft-dev J'soft"));
> true
console.log(jagile.isName("Jay 234 Soft"));
> false
console.log(jagile.isName("Jay Trindade jay_soft"));
> false
// and so on...isPhoneNumber
Check if the passed value is an international phone number like "+244 913 056 212, +555 555 1234". The return is boolean.
Syntax
isPhoneNumber: (value: any) => booleanUse
// example
console.log(jagile.isPhoneNumber("+244 913 056 212"));
> true
console.log(jagile.isPhoneNumber("555 555 1234"));
> false
// and so on...inArray
Check if value exists inside array. The return is boolean.
Syntax
inArray: (arr: array, values: string | array) => booleanUse
// example
let arr = ["jay", "trindade", 1, true, -4]
console.log(jagile.inArray(arr, ["jay", 1]));
> true
console.log(jagile.inArray(arr, -4));
> true
console.log(jagile.inArray(arr, [0, 1]));
> false
// and so on...inArrayAnyValue
Check if any value exists inside array. The return is commonObject.
Syntax
inArrayAnyValue: (arr: array, values: array) => commonObjectUse
// example
let arr = ["jay", "trindade", 1, true, -4]
console.log(jagile.inArrayAnyValue(arr, ["jay", 1]));
> {ok: true, complete: true}
console.log(jagile.inArrayAnyValue(arr, [2, "trindade", "soft"]));
> {ok: true, complete: false, exist: ["trindade"], notExist: [1, "soft"]}
console.log(jagile.inArrayAnyValue(arr, [0, "soft", true]));
> {ok: false, complete: false}
// and so on...inObject
Check if value exists inside object. The return is boolean.
Syntax
inObject: (obj: commonObject, values: string | array) => booleanUse
// example
let obj = {id: 1, name: "jay", lastName: "trindade", age: 19}
console.log(jagile.inObject(obj, ["id", "name"]));
> true
console.log(jagile.inObject(obj, "sex"));
> false
console.log(jagile.inObject(obj, ["id", "sex"]));
> false
// and so on...inObjectAnyProp
Check if any prop exists inside commonObject. The return is commonObject.
Syntax
inObjectAnyProp: (obj: commonObject, values: array) => commonObjectUse
// example
let obj = {id: 1, name: "jay", lastName: "trindade", age: 19}
console.log(jagile.inObjectAnyProp(obj, ["id", "name"]));
> {ok: true, complete: true}
console.log(jagile.inObjectAnyProp(obj, ["name", "country"]));
> {ok: true, complete: false, exist: ["name"], notExist: ["country"]}
console.log(jagile.inObjectAnyProp(obj, ["sex", "city", "state"]));
> {ok: false, complete: false}
// and so on...hasValue
Check if has some value. The return is boolean.
Syntax
hasValue: (value: any) => booleanUse
// example
console.log(jagile.hasValue("jay"));
> true
console.log(jagile.hasValue(1));
> true
console.log(jagile.hasValue(false));
> true
console.log(jagile.hasValue([]));
> false
console.log(jagile.hasValue({}));
> false
console.log(jagile.hasValue(null));
> false
// and so on...hasAllValue
Check if all elements of an array has value. The return is boolean.
Syntax
hasAllValue: (values: array) => booleanUse
// example
console.log(jagile.hasAllValue(["jay", [20], true, -1]))
> true
// example - 2
let name = "jay",
age = 19
console.log(jagile.hasAllValue([name, age]))
> true
// example - 3
console.log(jagile.hasAllValue(["", "Oops", {}, []]))
> false
// and so on...hasValueAllProps
Check if all props have value. The return is commonObject.
Syntax
hasValueAllProps: (values: array) => commonObjectUse
// example
let obj = {name: "jay", username:"soft", age: 19, sex: 1}
console.log(jagile.hasValueAllProps(obj, ["name", "username"]))
> {ok: true}
console.log(jagile.hasValueAllProps(obj, ["name", "city"]))
> {ok: false, except: ["city"]}
console.log(jagile.hasValueAllProps(obj, ["country", "city"]))
> {ok: false, except: ["country", "city"]}
// and so on...justifySpaceWords
Justify space between words. The return is string.
Syntax
justifySpaceWords: (value: string) => stringUse
// example
console.log(jagile.justifySpaceWords("joão trindade"));
> joão trindade
// and so on...capitalizeText
Make the first letters of words capitalized. The return is string.
Syntax
capitalizeText: (value: string) => stringUse
// example
console.log(jagile.capitalizeText("jOÃO tRiNdade jsoFt"));
> JOÃO tRiNdade jsoFt
console.log(jagile.capitalizeText("jOÃO tRiNdade jsoFt", true));
> JOÃO TRiNdade JsoFt
// and so on...checkMinValueEachWords
Check the minimum amount of characters for each word. The return is boolean.
Syntax
checkMinValueEachWords: (value: string, min: number) => booleanUse
// example
console.log(jagile.checkMinValueEachWords("joão de trindade", 2));
> true
console.log(jagile.checkMinValueEachWords("joão d trindade", 2));
> false
// and so on...checkMaxValueEachWords
Check the maximum amount of characters for each word. The return is boolean.
Syntax
checkMaxValueEachWords: (value: string, max: number) => boolean- max - a positive number
Use
// example
console.log(jagile.checkMaxValueEachWords("jay soft", 5));
> true
console.log(jagile.checkMaxValueEachWords("joão trindade", 5));
> false
// and so on...checkMinAndMaxValueEachWord
Check the minimum and maximum amount of characters for each word. The return is boolean.
Syntax
checkMinAndMaxValue: (value: string, min: number, max: number) => boolean- min > 0 and min < max
Use
// example
console.log(jagile.checkMinAndMaxValueEachWord("jay soft", 2, 4));
> true
console.log(jagile.checkMinAndMaxValueEachWord("joão trindade", 5, 9));
> false
// and so on...correctName
Remove special characters and space except accents. The return is string.
Syntax
correctName: (value: string) => stringUse
// example
console.log(jagile.correctName("João980_$ 78 Tri_ndade J'soft"));
// joão Trindade J'soft
// and so on...getTypeof
Get type of value. The return is typeof.
Syntax
getTypeof: (value: any) => "string" | "number" | "bigint" | "boolean" | "symbol" | "undefined" | "object" | "function" | "commonNumber" | "commonObject" | "objectId" | "array"Use
// example
console.log(jagile.getTypeof("jay"));
> "string"
console.log(jagile.getTypeof(1));
> "commonNumber"
console.log(jagile.getTypeof([]));
> "array"
console.log(jagile.getTypeof({}));
> "commonObject"
// and so on...getArrayElements
Get array elements. The return is array.
Syntax
getArrayElements: (arr: array, elements: any) => arrayUse
// example
let arr = ["jay", 19, true, "cool", -1, ...];
console.log(jagile.getArrayElements(arr, ["jay", -1]));
> ["jay", -1]
console.log(jagile.getArrayElements(arr, "jay"));
> ["jay"]
// and so on...getObjectProps
Get object props. The return is commonObject.
Syntax
getObjectProps: (obj: object, props: string | array) => objectUse
// example
let obj = {id: 1, name: "jay", age: 19};
console.log(jagile.getObjectProps(obj, ["id", "age"]));
> {id: 1, age: 19}
console.log(jagile.getObjectProps(obj, "age"));
> {age: 19}
// and so on...getOnlyNumber
Get only numbers. The return is number.
Syntax
getOnlyNumber: (value: any) => numberUse
// example
console.log(jagile.getOnlyNumber("jay 1df 34 soft"));
> 134
// and so on...getElementPos
Get the first position of an array of objects by field and value. The return is number.
Syntax
getElementPos: (arr: array, prop: string, value: any) => numberUse
// example
let arr = [{name: "jay", age: 19}, {name: "soft", age: 20}, {name: "trindade", age: 19}]
console.log(jagile.getElementPos(arr, "name", "soft"));
> 1
console.log(jagile.getElementPos(arr, "id", "1"));
> -1
// and so on...generateObjectId
Generates a unique objectId like "5db7e872dab3eb3d7cc44080". The return is objectId.
Syntax
generateObjectId: () => objectIdUse
// example
console.log(jagile.generateObjectId());
> 5db7e872dab3eb3d7cc44080
// and so on...removeArrayElement
Remove array elements. The return is array.
Syntax
removeArrayElement: (arr: array, element: string | array) => arrayUse
// example
let arr = ["jay", 1, true, "soft"]
console.log(jagile.removeArrayElement(arr, ["jay", true]));
> [1, "soft"]
console.log(jagile.removeArrayElement(arr, 1);
> ["jay", true, "soft"]
// and so on...removeObjectProps
Remove object properties. The return is object.
Syntax
removeObjectProps: (obj: object, props: string | array) => objectUse
// example
let obj = {name: "jay", age: 19, sex: 1, username: "joaotrindade.soft"}
console.log(jagile.removeObjectProps(obj, ["name", "sex"]));
> {age: 19, username: "joaotrindade.soft"}
console.log(jagile.removeObjectProps(obj, "username");
> {name: "jay", age: 19, sex: 1}
// and so on...uniqueArray
Remove repeated elements from array. The return is array.
Syntax
uniqueArray: (arr: array) => arrayUse
// example
let arr = [1, 4, 2, "jay", 2, 4, true, "jay"];
console.log(jagile.uniqueArray(arr));
> [1, 4, 2, "jay", true]
// and so on...uniqueArrayObjectBy
Remove repeated elements from an array of objects by property. The return is array.
Syntax
uniqueArrayObjectBy: (arr: any, prop: string) => arrayUse
// example
let arr = [{name: "jay", age: 19}, {name: "soft", age: 20}, {name: "jay", age: 18}]
console.log(jagile.uniqueArrayObjectBy(arr, "name"));
> [{name: "jay", age: 19}, {name: "soft", age: 20}]
// and so on...existModule
Check if there is a node.js module like "http, jsoft-agile, etc...". The return is boolean.
Syntax
existModule: (value: any) => booleanUse
// example
console.log(jagile.existModule("http"));
> true
console.log(jagile.existModule("jsoft-agile"));
> true
console.log(jagile.existModule("kkkkkk"));
> false
// and so on...wallFilters
Validates or filters all data according to a rule. The return is commonObject.
Syntax
wallFilters: (data: commonObject) => commonObject
data: {
service: "string",
data: "commonObject",
rules: "commonObject",
validations: ?"function"
}Use
rules.js
const rules = {
signup: {
fields: {
name: {
type: "string",
importantFields: ["username"],
validate: ["name", "username"]
},
username: { type: "string", validate: "username" },
sex: { type: "commonNumber", required: true, accepts: [1, 2] },
country: { type: "string", accepts: ["usa", "china"] },
state: { type: "string", needFields: ["country"] }
},
config: {
minFields: 3,
output: {
name: "Name",
username: "UserName",
sex: "Sex",
country: "Country",
state: "State"
}
}
}
};
/**
* field: {
* type: typeof,
* required: boolean,
* default: value,
* validate: string | array(string),
* importantFields: array(string),
* needFields: array(string),
* accepts: array
* }
*
* config: {
* minField: commonNumber,
* output: commonObject
* }
*/
module.exports = rules;validates.js
const jagile = require("jsoft-agile");
// validate name
const name = value => {
value = jagile.correctName(value);
if (jagile.checkMinAndMaxValueEachWord(value, 2, 8)) {
return { ok: true, value: value };
} else return { ok: false, message: "limit char" };
};
// validate username
const username = value => {
if (jagile.isUsername(value)) return { ok: true, value: value };
else return { ok: false, message: "invalid username" };
};
// all validates
const validate = data => {
let { type, value } = data;
if (type == "name") return name(value);
if (type == "username") return username(value);
return null
};
module.exports = validate;index.js
const jagile = require("jsoft-agile");
const myRules = require("./rules");
const myValidations = require("./validates");
// example
console.log(
jagile.wallFilters({
service: "signup",
data: {
name: "jay trindade",
username: "jaytrindade",
age: 20,
sex: 1,
country: "usa"
},
rules: myRules,
validations: myValidations
})
);
>
{
ok: true,
exec: true,
data: {
Name: 'jay trindade',
UserName: 'jaytrindade',
Sex: 1,
Country: 'usa'
}
}
>
// example - 2
console.log(
jagile.wallFilters({
service: "signup",
data: {
name: "jay",
username: "@jay",
age: 19,
sex: 3,
country: "bbb"
},
rules: myRules,
validations: myValidations
})
);
>
{
ok: false,
exec: true,
errors: {
username: 'invalid username',
sex: 'Not allowed value',
country: 'Not allowed value'
},
keys: [
'username',
'sex',
'country'
]
}
>
// and so on...Recommendations
Contributing
Please read CONTRIBUTING.md for details on our code of conduct, and the process for submitting pull requests to us.
Versions
We use SemVer for versioning.
Author
João Trindade
- Email: joaotrindade.soft@gmail.com
- WhatsApp: +244 913 056 212
- Instagram: jayjsoft
License
This project is licensed under the MIT License
Acknowledgments
- I thank God for all the good you have done in my life
- To all those who supported me and always believed in me