Everything you constantly need for development (and probably still copy-pasting from other projects)
The promise:
- ✅ 1 package: say goodbye to lodash, faker, this and that and the other package.
- ⭕ 0 dependencies: keep it simple and lightweight.
- 🏆 Pick the best: the code is minimal and uses the best current practices and is optimized for max performance.
- 👪🏼 Typescript: use it, support it and export it.
- 🌊 Intuitive: favour always the most intuitive API and common usage, never throw errors unless asked.
- 🙈 Semantic: use simple function names that are easy to remember, no complicated options.
Contributions always welcome!
isArray()
isBoolean()
isBrowser()
to detect if you are on the browserisClient()
to detect if you are ont the browser/clientisEmail()
this is a relaxed check, use your own validation if you need to be strict- ⭐
isEmpty()
to check for empty object, empty array, empty string, null or undefinedisEmptyString()
trims the string and checks if something is leftisEmptyArray()
isEmptyObject()
isFunction()
isJsDate()
if it's a valid javascript's DateisFutureDate()
isPastDate()
isStringDate()
also checks if the string passed is a valid date
isKey()
is a real key of an objectisLastIndex()
is the index is the last item of arrayisNotEmptyString()
must have some text, checks for spaces-onlyisNumber()
if the arg is number, and also usable (no infinity)isInt()
isEven()
isOdd()
isPositiveInt()
isNegativeInt()
isNumeric()
- ⭐
isObject()
if it's a js plain Object isPromise()
isPWA()
isReactElement()
isRegExp()
- ⭐
isSame()
Compare if dates, functions, arrays, objects or anything else are the same isServer()
if you are on the serverisString()
isURL()
isUUID()
average()
numbers of an arraymax()
numbers of an arraymin()
numbers of an arraymultiply()
numbers of an arraysum()
numbers an array
array()
create an arbitrary array based on a functionarrayDiff()
arrayIntersection()
capitalize()
word => WordcleanSpaces()
trims and turns double spaces into single spaceclamp()
clamp number in a rangeenumKeys()
enum FRUIT { APPLE, PEAR } => ["APPLE", "PEAR"]enumValues()
enum FRUIT { APPLE = 1, PEAR = 3 } => [1, 3]first()
get the first element of an arrayfirstKey()
firstValue()
getKeys()
get the keys of an object, includes symbolsgetUrlSearchParam()
getUrlSearchParams()
incrementalId()
autoincremental SQL-like, process-unique numeric idkeysLength()
last()
get the last element of an arraylastIndex()
get the last index of an array- ⭐
merge()
deep merge objects moveToFirst()
move array element to firstmoveToIndex()
move array element to desired indexmoveToLast()
move array element to lastnormalizeNumber()
normalizes between 0 and 1objectDiff()
- ⭐
parseDate()
pass anything Date-Like, and get a JS Date back pretty()
stringify anything, without breaking on circular dependenciespromiseWithTimeout()
takes a promise, a timeoutMs, and an option error as arguments. Returns a new Promise that either resolves with the value of the input promise or rejects with the provided error or a default error message if the input promise does not resolve or reject within the specified timeoutMs.scrambleText()
replace alpha chars with random charsseriesAll()
executes promises in series, and returns all resultssetUrlSearchParams()
shuffle()
shuffles elements in an arraysleep()
promise-based sleeptoggleArrayValue()
remove/add value in arraytruncate()
truncate text, does not break emojisuniqueValues()
gets unique values in an array
formatNumber()
1000 => "1,000" or "1K" or 0.112 => "11.2%"stringToUnicode()
"hello" => "\u0068\u0065\u006c\u006c\u006f"stringToCSSUnicode()
"hello" => "\000068\000065\00006c\00006c\00006f" use this for CSS
These functions are optimized for low entropy random data generation useful for Unit Testing, Storybook, Pass real validations, Reverse hacking, Penetration testing...
randomAddress()
randomAlphaNumericCode()
- ⭐
randomArrayItem()
now supporting non-uniform distribution randomBankAccount()
randomBool()
randomChar()
randomCompany()
- ⭐
randomCoords()
randomLat()
randomLng()
randomDate()
a safe range in decaderandomMaxDate()
a range in the Max dates allowed by JSrandomFutureDate()
randomPastDate()
randomDateRange()
=> { startDate, endDate }
randomEmail()
randomEmoji()
randomEnumKey()
enum FRUIT { APPLE, PEAR } => APPLErandomEnumValue()
enum FRUIT { APPLE = 1, PEAR = 3 } => 3randomFile()
randomFloat()
randomHandle()
useful for social identifiers, or slugsrandomHexColor()
randomHexValue()
randomHtmlColorName()
randomIBAN()
randomInt()
randomPositiveInt()
> 0randomNegativeInt()
< 0randomMaxSafeInt()
Range of very BIG integers, which are still safe to use thorandomMaxInt()
Range within the Maximum integer supported by js
randomIP()
randomName()
randomFirstName()
randomLastName()
randomFullName()
randomNumericCode()
randomParagraph()
randomPassword()
randomPath()
/path/to/somethingrandomPhoneNumber()
randomString()
randomUUID()
lightweight uuid generation, passing UUID validationrandomWord()
Checks are functions that throw an error, if the validation fails
- ⭐
checkEnvVars()
Make sure env vars are set per-environment
Coords
DateLike
Dimensions
Maybe<>
MaybePromise<>
MaybePromiseOrValue<>
MaybePromiseOrValueArray<>
NonUndefined
ObjectKey<>
ObjectKeys<>
ObjectValue<>
ObjectValues<>
ObjectEntries<>
- ⭐
PlainObject
use this instead ofRecord<,>
orextends object
, also makes sure it's not an array Point
PrismaSelect<>
HashMap<>
HashMapKey
NumberMap
StringMap
BoolMap
TrueMap
After changes, run
pnpm bump
To bump the version. CI will take care of publishing the package when merged.