@olmokit/utils
Interfaces
Other
AnyAsyncFunction
Ƭ AnyAsyncFunction: (...args: any[]) => Promise<any>
Type declaration
▸ (...args): Promise<any>
Parameters
| Name | Type |
|---|---|
...args | any[] |
Returns
Promise<any>
Defined in
AnyClass
Ƭ AnyClass: (...args: any[]) => any
Type declaration
• (...args)
Parameters
| Name | Type |
|---|---|
...args | any[] |
Defined in
AnyFunction
Ƭ AnyFunction: (...args: any[]) => any
Type declaration
▸ (...args): any
Parameters
| Name | Type |
|---|---|
...args | any[] |
Returns
any
File
Same as is-what plus:
isFormDataisIntisFloat
Defined in
AnythingFalsy
Ƭ AnythingFalsy: null | undefined | 0 | ""
Whatever that in javascript returns false when checked in an if condition
Defined in
ClsxClassValue
Ƭ ClsxClassValue: ClassValue
Defined in
DebounceOptions
Ƭ DebounceOptions<Result>: Object
Categroy
functionn
Type parameters
| Name |
|---|
Result |
Type declaration
| Name | Type |
|---|---|
callback? | (data: Result) => void |
isImmediate? | boolean |
maxWait? | number |
Defined in
KeysStartsWith
Ƭ KeysStartsWith<T, S>: keyof PickStartsWith<T, S>
Returns a union of all the keys of an object T which starts with S.
Type parameters
| Name | Type |
|---|---|
T | extends object |
S | extends string |
Defined in
KeysTailsStartsWith
Ƭ KeysTailsStartsWith<T, S>: keyof PickStartsWithTails<T, S>
Returns a union of all the keys of an object T which starts with S.
The strings in the produced union have S removed.
Type parameters
| Name | Type |
|---|---|
T | extends object |
S | extends string |
Defined in
PickStartsWith
Ƭ PickStartsWith<T, S>: { [K in keyof T as K extends `${S}${string}` ? K : never]: T[K] }
Pick the keys of an object T that starts with S. It produces a mapped type
with a subset of T whose keys start with S.
Type parameters
| Name | Type |
|---|---|
T | extends object |
S | extends string |
Defined in
PickStartsWithTails
Ƭ PickStartsWithTails<T, S>: { [K in keyof T as K extends `${S}${string}` ? Replace<K, S, ""> : never]: T[K] }
Pick the keys of an object T that starts with S. It produces a mapped type
with a subset of T whose keys start with S and have S removed.
Type parameters
| Name | Type |
|---|---|
T | extends object |
S | extends string |
Defined in
PlainObject
Ƭ PlainObject: Record<string | number | symbol, any>
Defined in
TypeGuard
Ƭ TypeGuard<A, B>: (payload: A) => payload is B
Type parameters
| Name | Type |
|---|---|
A | A |
B | extends A |
Type declaration
▸ (payload): payload is B
Parameters
| Name | Type |
|---|---|
payload | A |
Returns
payload is B
Defined in
getType
▸ getType(payload): string
Returns the object type of the given payload
Parameters
| Name | Type |
|---|---|
payload | any |
Returns
string
Defined in
matchSorter
▸ matchSorter<ItemType>(items, value, options?): ItemType[]
Takes an array of items and a value and returns a new array with the items that match the given value
Type parameters
| Name | Type |
|---|---|
ItemType | string |
Parameters
| Name | Type | Description |
|---|---|---|
items | readonly ItemType[] | the items to sort |
value | string | the value to use for ranking |
options | MatchSorterOptions<ItemType> | Some options to configure the sorter |
Returns
ItemType[]
- the new sorted array
Defined in
array
addOrReplaceAtIdx
▸ addOrReplaceAtIdx<T>(list, newItem, newIdx?): T[]
Add or replace an item in the given array, it returns a new array (immutable).
Typescript wise this is meant to keep the same type on the newly returned
array, therefore the newItem must match the type of the list items.
Type parameters
| Name |
|---|
T |
Parameters
| Name | Type |
|---|---|
list | T[] |
newItem | T |
newIdx? | number |
Returns
T[]
Defined in
arrayOfAll
▸ arrayOfAll<T>(): <U>(array: U & [T] extends [U[number]] ? unknown : "Invalid") => U & [T] extends [U[number]] ? unknown : "Invalid"
Ensure an array contains all desired values
Type parameters
| Name |
|---|
T |
Returns
fn
▸ <U>(array): U & [T] extends [U[number]] ? unknown : "Invalid"
Type parameters
| Name | Type |
|---|---|
U | extends T[] |
Parameters
| Name | Type |
|---|---|
array | U & [T] extends [U[number]] ? unknown : "Invalid" |
Returns
U & [T] extends [U[number]] ? unknown : "Invalid"
Borrows
SO comment by CertainPerformance
Usage
type Fruit = "pear" | "apple" | "orange";
const arrayOfAllFruits = arrayOfAll<Fruit>();
const allFruits = arrayOfAllFruits([
"pear",
"apple",
"orange"
]); // ts compiler ok
const allFruits = arrayOfAllFruits([
"pear",
"apple",
]); // ts compiler fails
Defined in
arraySum
▸ arraySum(numbers): number
Sum array of numbers
Parameters
| Name | Type |
|---|---|
numbers | number[] |
Returns
number
Defined in
arrayToLookup
▸ arrayToLookup<T>(array?): Record<T, 1>
Maps a simple flat array to a lookup dictionary object
Type parameters
| Name | Type |
|---|---|
T | extends string | number | symbol |
Parameters
| Name | Type |
|---|---|
array | T[] |
Returns
Record<T, 1>
Defined in
chunkByChunks
▸ chunkByChunks<T>(arr, nrOfChunks, balanced?): T[][]
Type parameters
| Name |
|---|
T |
Parameters
| Name | Type |
|---|---|
arr | T[] |
nrOfChunks | number |
balanced? | boolean |
Returns
T[][]
See
https://stackoverflow.com/a/8189268/1938970 TODO: untested
Defined in
chunkBySize
▸ chunkBySize<T>(arr, size): T[][]
Type parameters
| Name |
|---|
T |
Parameters
| Name | Type |
|---|---|
arr | T[] |
size | number |
Returns
T[][]
See
https://stackoverflow.com/a/40682136/1938970
Defined in
findDuplicatedIndexes
▸ findDuplicatedIndexes(arr): Record<number, true>
Parameters
| Name | Type |
|---|---|
arr | any[] |
Returns
Record<number, true>
Defined in
getEmptyArray
▸ getEmptyArray(length): undefined[]
Returns an array of undefined values of the desired length, useful to build skeleton UIs.
Parameters
| Name | Type |
|---|---|
length | string | number |
Returns
undefined[]
Defined in
mapListBy
▸ mapListBy<T>(array?, key?): Record<T[keyof T], T>
Maps an array of objects into a map keyed with the given key
Type parameters
| Name | Type |
|---|---|
T | extends Record<string | number | symbol, any> |
Parameters
| Name | Type |
|---|---|
array | T[] |
key | keyof T |
Returns
Record<T[keyof T], T>
Defined in
moveSortableArrayItemByKey
▸ moveSortableArrayItemByKey<T, K>(items, key, fromItem, toItem): T[]
Move item from one place to another in a sortable array of objects, re-ordering the array accrodingly (no swapping of position). This is useful for drag and drop functionalities
Type parameters
| Name | Type |
|---|---|
T | T |
K | extends string | number | symbol |
Parameters
| Name | Type |
|---|---|
items | T[] |
key | K |
fromItem | Pick<T, K> |
toItem | Pick<T, K> |
Returns
T[]
Defined in
moveSortableArrayItemByKey.ts:8
removeDuplicatesByKey
▸ removeDuplicatesByKey<T>(array?, key): T[]
Remove duplicated array objects, equality is determined by a strict (===)
comparison of each object's given key
Type parameters
| Name | Type |
|---|---|
T | extends Record<string | number | symbol, any> |
Parameters
| Name | Type |
|---|---|
array | T[] |
key | keyof T |
Returns
T[]
Defined in
removeDuplicatesComparing
▸ removeDuplicatesComparing<T>(from, to): T[]
Type parameters
| Name |
|---|
T |
Parameters
| Name | Type |
|---|---|
from | any[] |
to | T[] |
Returns
T[]
Defined in
removeDuplicatesComparing.ts:7
removeIndexesFromArray
▸ removeIndexesFromArray<T>(arr, indexes): T[]
Type parameters
| Name |
|---|
T |
Parameters
| Name | Type |
|---|---|
arr | T[] |
indexes | Record<number, true> |
Returns
T[]
Defined in
shuffle
▸ shuffle<T>(array): T[]
Creates an array of shuffled values, using a version of the Fisher-Yates shuffle.
Type parameters
| Name |
|---|
T |
Parameters
| Name | Type | Description |
|---|---|---|
array | T[] | The array to shuffle. |
Returns
T[]
The new shuffled array.
Borrows
Example
shuffle([1, 2, 3, 4])
// => [4, 1, 3, 2]
Defined in
async
Deferred
Ƭ Deferred<T>: Promise<T> & { reject: PromiseConstructor["reject"] ; resolve: PromiseConstructor["resolve"] }
Type parameters
| Name |
|---|
T |
Defined in
Defer
▸ Defer<T>(): Deferred<T>
Type parameters
| Name |
|---|
T |
Returns
Deferred<T>
See
https://stackoverflow.com/a/37673534/1938970
Example
const deferred = Defer();
deferred.resolve();
deferred.then(handleSuccess, handleError);
Defined in
tryUntil
▸ tryUntil(test, timeout, interval, resolve, reject?): void
Parameters
| Name | Type | Description |
|---|---|---|
test | () => boolean | - |
timeout | number | in ms |
interval | number | in ms |
resolve | () => void | - |
reject? | () => void | - |
Returns
void
Borrows
Javascript: Wait Until Something Happens or Timeout
Defined in
wait
▸ wait(milliseconds): Promise<unknown>
A promisified setTimeout
Parameters
| Name | Type |
|---|---|
milliseconds | number |
Returns
Promise<unknown>
Defined in
cast
ensureInt
▸ ensureInt(input): number
Ensure input to be an integer
Parameters
| Name | Type |
|---|---|
input | string | number |
Returns
number
Defined in
errorToString
▸ errorToString(e): string
Ensure to transform a JavaScript Error into a string (uses its message)
Parameters
| Name | Type |
|---|---|
e | unknown |
Returns
string
Defined in
toNumber
▸ toNumber(input?, fallback?): number
Parameters
| Name | Type |
|---|---|
input? | string | number |
fallback? | number |
Returns
number
Defined in
colors
createPalette
▸ createPalette<TName, TShades, TColor, TMap>(name, shades): readonly [TMap, Record<`${TName}-${TShades[number][0]}`, string>, TColor[]]
Create palette, this is primarily thought to improve the reuse of a palette definition between TailwindCSS and straight ES imports
Type parameters
| Name | Type |
|---|---|
TName | extends string |
TShades | extends PaletteShades |
TColor | TShades[number][``1``] |
TMap | PaletteMap<TShades> |
Parameters
| Name | Type |
|---|---|
name | TName |
shades | TShades |
Returns
readonly [TMap, Record<`${TName}-${TShades[number][0]}`, string>, TColor[]]
An array with: 1) A flat palette map 2) A TailwindCSS ready palette
object 3) A flat array of colors (no special sorting, same order as the shades
given as argument)
Defined in
toRgba
▸ toRgba(hex, alpha?): string
Parameters
| Name | Type | Default value |
|---|---|---|
hex | string | undefined |
alpha | number | 1 |
Returns
string
Defined in
cookie
CookieAttributesClient
Ƭ CookieAttributesClient: CookieAttributes
Defined in
CookieAttributesServer
Ƭ CookieAttributesServer: CookieAttributes & { decode?: (input: string) => string ; encode?: (input: string) => string ; httpOnly?: boolean ; maxAge?: number }
Defined in
parseCookie
▸ parseCookie<T>(str, attributes?): T
Parse a cookie header.
Parse the given cookie header string into an object The object has the various cookies as keys(names) => values
Type parameters
| Name | Type |
|---|---|
T | extends Record<string, unknown> = Record<string, string> |
Parameters
| Name | Type |
|---|---|
str | string |
attributes | CookieAttributesServer |
Returns
T
Defined in
readCookie
▸ readCookie<T>(name?): T
Read cookie
Type parameters
| Name | Type |
|---|---|
T | extends Record<string, unknown> = Record<string, string> |
Parameters
| Name | Type |
|---|---|
name? | null |
Returns
T
Defined in
▸ readCookie<T, N>(name): T[N]
Type parameters
| Name | Type |
|---|---|
T | extends Record<string, unknown> = Record<string, string> |
N | extends string | number | symbol = keyof T |
Parameters
| Name | Type |
|---|---|
name | N |
Returns
T[N]
Defined in
removeCookie
▸ removeCookie(name, attributes?): void
Parameters
| Name | Type |
|---|---|
name | string |
attributes | CookieAttributes |
Returns
void
Defined in
serializeCookie
▸ serializeCookie(name, val, attributes?): string
Serialize data into a cookie header.
Serialize the a name value pair into a cookie string suitable for http headers. An optional attributes object specified cookie parameters.
serialize('foo', 'bar', { httpOnly: true }) => "foo=bar; httpOnly"
Parameters
| Name | Type |
|---|---|
name | string |
val | string |
attributes | CookieAttributesServer |
Returns
string
Defined in
setCookie
▸ setCookie<T>(name, value, attributes?): string | undefined
Type parameters
| Name | Type |
|---|---|
T | extends string = string |
Parameters
| Name | Type |
|---|---|
name | string |
value | string | T |
attributes | CookieAttributes |
Returns
string | undefined
Defined in
error
errorToString
▸ errorToString(e): string
Ensure to transform a JavaScript Error into a string (uses its message)
Parameters
| Name | Type |
|---|---|
e | unknown |
Returns
string
Defined in
format
gbToBytes
▸ gbToBytes(bytes): number
Gigabytes to bytes
Parameters
| Name | Type |
|---|---|
bytes | number |
Returns
number
Defined in
kbToBytes
▸ kbToBytes(bytes): number
Kilobytes to bytes
Parameters
| Name | Type |
|---|---|
bytes | number |
Returns
number
Defined in
mbToBytes
▸ mbToBytes(bytes): number
Megabytes to bytes
Parameters
| Name | Type |
|---|---|
bytes | number |
Returns
number
Defined in
function
debounce
▸ debounce<T>(fn, wait?, immediate?): (this: unknown, ...args: Parameters<T>) => void
Debounce function (with setTimeout)
Type parameters
| Name | Type |
|---|---|
T | extends (...args: any[]) => any |
Parameters
| Name | Type |
|---|---|
fn | T |
wait? | number |
immediate? | boolean |
Returns
fn
▸ (this, ...args): void
Parameters
| Name | Type |
|---|---|
this | unknown |
...args | Parameters<T> |
Returns
void
Borrows
Defined in
debouncePromise
▸ debouncePromise<Args, F>(func, waitMilliseconds?, options?): DebouncedFunction<Args, F>
Debounce function (with Promise)
Type parameters
| Name | Type |
|---|---|
Args | extends any[] |
F | extends (...args: Args) => any |
Parameters
| Name | Type | Default value |
|---|---|---|
func | F | undefined |
waitMilliseconds | number | 50 |
options | DebounceOptions<ReturnType<F>> | {} |
Returns
DebouncedFunction<Args, F>
Borrows
License
MIT: Jakub Chodorowicz
Defined in
debounceRaf
▸ debounceRaf<T>(this, fn): (this: unknown, ...args: Parameters<T>) => void
Debounce function (with requestAnimationFrame)
Type parameters
| Name | Type |
|---|---|
T | extends (...args: any[]) => any |
Parameters
| Name | Type |
|---|---|
this | unknown |
fn | T |
Returns
fn
▸ (this, ...args): void
Parameters
| Name | Type |
|---|---|
this | unknown |
...args | Parameters<T> |
Returns
void
Borrows
License
(c) 2021 Chris Ferdinandi, MIT License, https://gomakethings.com
Defined in
throttle
▸ throttle<TFn, TContext>(fn, limit, context?): (this: TContext, ...args: any[]) => undefined | Timeout
Throttle function (e.g. for resize / scroll handlers)
Type parameters
| Name | Type |
|---|---|
TFn | extends Function |
TContext | TContext |
Parameters
| Name | Type |
|---|---|
fn | TFn |
limit | number |
context? | TContext |
Returns
fn
▸ (this, ...args): undefined | Timeout
Parameters
| Name | Type |
|---|---|
this | TContext |
...args | any[] |
Returns
undefined | Timeout
Borrows
Defined in
tryUntil
▸ tryUntil(test, timeout, interval, resolve, reject?): void
Parameters
| Name | Type | Description |
|---|---|---|
test | () => boolean | - |
timeout | number | in ms |
interval | number | in ms |
resolve | () => void | - |
reject? | () => void | - |
Returns
void
Borrows
Javascript: Wait Until Something Happens or Timeout
Defined in
img
imgEmptyPixel
• Const imgEmptyPixel: ""
Empty img pixel as a string to inline
Defined in
impl
Emitter
▸ Emitter<EventMap>(namespace): Object
Emitter super simple class
Events will be prefixed with the given namespace plus a . so:
{namespace}.myevent
Adapted from https://github.com/developit/mitt
Regarding typescript support see:
Type parameters
| Name | Type |
|---|---|
EventMap | extends Object |
Parameters
| Name | Type |
|---|---|
namespace | string |
Returns
Object
| Name | Type |
|---|---|
emit | <EventName>(name: EventName, data?: EventMap[EventName]) => void |
on | <EventName>(name: EventName, handler: (data?: EventMap[EventName]) => any) => void |
Defined in
clsx
▸ clsx(...args): string
Class names utility
Parameters
| Name | Type |
|---|---|
...args | ClassValue[] |
Returns
string
Borrows
License
MIT Luke Edwards https://github.com/lukeed/clsx/blob/master/license
Defined in
quaranteneProps
▸ quaranteneProps<TProps, TSupectPropsKeys>(props, propsKeysToQuarantene): Omit<TProps, TSupectPropsKeys[number]> & { _: Pick<TProps, TSupectPropsKeys[number]> }
Type parameters
| Name | Type |
|---|---|
TProps | extends Record<never, never> |
TSupectPropsKeys | extends QuaranteneProps<TProps> |
Parameters
| Name | Type |
|---|---|
props | TProps |
propsKeysToQuarantene | TSupectPropsKeys |
Returns
Omit<TProps, TSupectPropsKeys[number]> & { _: Pick<TProps, TSupectPropsKeys[number]> }
Example
const { _: { onKeyDown }, myOwnProp, ...rest } = quaranteneProps([
"onPointerLeave",
"onPointerMove",
"onClick",
"onPointerDown",
"onPointerUp",
"onKeyDown",
]);
Defined in
is
isBrowser
• Const isBrowser: boolean
Defined in
isServer
• Const isServer: boolean = !isBrowser
Defined in
isAnyObject
▸ isAnyObject(payload): payload is PlainObject
Returns whether the payload is an any kind of object (including special classes or objects with different prototypes)
Parameters
| Name | Type |
|---|---|
payload | any |
Returns
payload is PlainObject
Defined in
isArray
▸ isArray(payload): payload is any[]
Returns whether the payload is an array
Parameters
| Name | Type |
|---|---|
payload | any |
Returns
payload is any[]
Defined in
isBlob
▸ isBlob(payload): payload is Blob
Returns whether the payload is a Blob
Parameters
| Name | Type |
|---|---|
payload | any |
Returns
payload is Blob
Defined in
isBoolean
▸ isBoolean(payload): payload is boolean
Returns whether the payload is a boolean
Parameters
| Name | Type |
|---|---|
payload | any |
Returns
payload is boolean
Defined in
isBrowserNow
▸ isBrowserNow(): boolean
Returns
boolean
Defined in
isDate
▸ isDate(payload): payload is Date
Returns whether the payload is a Date, and that the date is valid
Parameters
| Name | Type |
|---|---|
payload | any |
Returns
payload is Date
Defined in
isEmptyArray
▸ isEmptyArray(payload): payload is []
Returns whether the payload is a an empty array
Parameters
| Name | Type |
|---|---|
payload | any |
Returns
payload is []
Defined in
isEmptyObject
▸ isEmptyObject(payload): payload is Object
Returns whether the payload is a an empty object (excluding special classes or objects with other prototypes)
Parameters
| Name | Type |
|---|---|
payload | any |
Returns
payload is Object
Defined in
isEmptyString
▸ isEmptyString(payload): payload is string
Returns whether the payload is ''
Parameters
| Name | Type |
|---|---|
payload | any |
Returns
payload is string
Defined in
isError
▸ isError(payload): payload is Error
Returns whether the payload is an Error
Parameters
| Name | Type |
|---|---|
payload | any |
Returns
payload is Error
Defined in
isFile
▸ isFile(payload): payload is File
Returns whether the payload is a File
Parameters
| Name | Type |
|---|---|
payload | any |
Returns
payload is File
Defined in
isFloat
▸ isFloat(payload): payload is number
Returns whether the payload is a float number
Parameters
| Name | Type |
|---|---|
payload | any |
Returns
payload is number
Defined in
isFormData
▸ isFormData(payload): payload is FormData
Returns whether the payload is a FormData
Parameters
| Name | Type |
|---|---|
payload | any |
Returns
payload is FormData
Defined in
isFullArray
▸ isFullArray(payload): payload is any[]
Returns whether the payload is a an array with at least 1 item
Parameters
| Name | Type |
|---|---|
payload | any |
Returns
payload is any[]
Defined in
isFullObject
▸ isFullObject(payload): payload is PlainObject
Returns whether the payload is a an empty object (excluding special classes or objects with other prototypes)
Parameters
| Name | Type |
|---|---|
payload | any |
Returns
payload is PlainObject
Defined in
isFullString
▸ isFullString(payload): payload is string
Returns whether the payload is a string, BUT returns false for ''
Parameters
| Name | Type |
|---|---|
payload | any |
Returns
payload is string
Defined in
isFunction
▸ isFunction(payload): payload is AnyFunction
Returns whether the payload is a function (regular or async)
Parameters
| Name | Type |
|---|---|
payload | any |
Returns
payload is AnyFunction
Defined in
isInt
▸ isInt(payload): payload is number
Returns whether the payload is an integer number
Parameters
| Name | Type |
|---|---|
payload | any |
Returns
payload is number
Defined in
isMap
▸ isMap(payload): payload is Map<any, any>
Returns whether the payload is a Map
Parameters
| Name | Type |
|---|---|
payload | any |
Returns
payload is Map<any, any>
Defined in
isNaNValue
▸ isNaNValue(payload): payload is number
Returns whether the payload is literally the value NaN (it's NaN and also a number)
Parameters
| Name | Type |
|---|---|
payload | any |
Returns
payload is number
Defined in
isNegativeNumber
▸ isNegativeNumber(payload): payload is number
Returns whether the payload is a negative number (but not 0)
Parameters
| Name | Type |
|---|---|
payload | any |
Returns
payload is number
Defined in
isNull
▸ isNull(payload): payload is null
Returns whether the payload is null
Parameters
| Name | Type |
|---|---|
payload | any |
Returns
payload is null
Defined in
isNullOrUndefined
▸ isNullOrUndefined(payload): payload is undefined | null
Returns true whether the payload is null or undefined
Parameters
| Name | Type |
|---|---|
payload | any |
Returns
payload is undefined | null
Defined in
isNumber
▸ isNumber(payload): payload is number
Returns whether the payload is a number (but not NaN)
This will return false for NaN!!
Parameters
| Name | Type |
|---|---|
payload | any |
Returns
payload is number
Defined in
isObject
▸ isObject(payload): payload is PlainObject
Returns whether the payload is a plain JavaScript object (excluding special classes or objects with other prototypes)
Parameters
| Name | Type |
|---|---|
payload | any |
Returns
payload is PlainObject
Defined in
isObjectLike
▸ isObjectLike<T>(payload): payload is T
Returns whether the payload is an object like a type passed in < >
Usage: isObjectLike<{id: any}>(payload) // will make sure it's an object and has an id prop.
Type parameters
| Name | Type |
|---|---|
T | extends PlainObject |
Parameters
| Name | Type |
|---|---|
payload | any |
Returns
payload is T
Defined in
isOneOf
▸ isOneOf<A, B, C>(a, b): TypeGuard<A, B | C>
Type parameters
| Name |
|---|
A |
B |
C |
Parameters
| Name | Type |
|---|---|
a | TypeGuard<A, B> |
b | TypeGuard<A, C> |
Returns
TypeGuard<A, B | C>
Defined in
▸ isOneOf<A, B, C, D>(a, b, c): TypeGuard<A, B | C | D>
Type parameters
| Name |
|---|
A |
B |
C |
D |
Parameters
| Name | Type |
|---|---|
a | TypeGuard<A, B> |
b | TypeGuard<A, C> |
c | TypeGuard<A, D> |
Returns
TypeGuard<A, B | C | D>
Defined in
▸ isOneOf<A, B, C, D, E>(a, b, c, d): TypeGuard<A, B | C | D | E>
Type parameters
| Name |
|---|
A |
B |
C |
D |
E |
Parameters
| Name | Type |
|---|---|
a | TypeGuard<A, B> |
b | TypeGuard<A, C> |
c | TypeGuard<A, D> |
d | TypeGuard<A, E> |
Returns
TypeGuard<A, B | C | D | E>
Defined in
▸ isOneOf<A, B, C, D, E, F>(a, b, c, d, e): TypeGuard<A, B | C | D | E | F>
Type parameters
| Name |
|---|
A |
B |
C |
D |
E |
F |
Parameters
| Name | Type |
|---|---|
a | TypeGuard<A, B> |
b | TypeGuard<A, C> |
c | TypeGuard<A, D> |
d | TypeGuard<A, E> |
e | TypeGuard<A, F> |
Returns
TypeGuard<A, B | C | D | E | F>
Defined in
isPlainObject
▸ isPlainObject(payload): payload is PlainObject
Returns whether the payload is a plain JavaScript object (excluding special classes or objects with other prototypes)
Parameters
| Name | Type |
|---|---|
payload | any |
Returns
payload is PlainObject
Defined in
isPositiveNumber
▸ isPositiveNumber(payload): payload is number
Returns whether the payload is a positive number (but not 0)
Parameters
| Name | Type |
|---|---|
payload | any |
Returns
payload is number
Defined in
isPrimitive
▸ isPrimitive(payload): payload is undefined | null | string | number | boolean | symbol
Returns whether the payload is a primitive type (eg. Boolean | Null | Undefined | Number | String | Symbol)
Parameters
| Name | Type |
|---|---|
payload | any |
Returns
payload is undefined | null | string | number | boolean | symbol
Defined in
isPromise
▸ isPromise(payload): payload is Promise<any>
Returns whether the payload is a Promise
Parameters
| Name | Type |
|---|---|
payload | any |
Returns
payload is Promise<any>
Defined in
isRegExp
▸ isRegExp(payload): payload is RegExp
Returns whether the payload is a regular expression (RegExp)
Parameters
| Name | Type |
|---|---|
payload | any |
Returns
payload is RegExp
Defined in
isServerNow
▸ isServerNow(): boolean
Returns
boolean
Defined in
isSet
▸ isSet(payload): payload is Set<any>
Returns whether the payload is a Set
Parameters
| Name | Type |
|---|---|
payload | any |
Returns
payload is Set<any>
Defined in
isString
▸ isString(payload): payload is string
Returns whether the payload is a string
Parameters
| Name | Type |
|---|---|
payload | any |
Returns
payload is string
Defined in
isSymbol
▸ isSymbol(payload): payload is symbol
Returns whether the payload is a Symbol
Parameters
| Name | Type |
|---|---|
payload | any |
Returns
payload is symbol
Defined in
isType
▸ isType<T>(payload, type): payload is T
Does a generic check to check that the given payload is of a given type. In cases like Number, it will return true for NaN as NaN is a Number (thanks javascript!); It will, however, differentiate between object and null
Type parameters
| Name | Type |
|---|---|
T | extends AnyFunction | AnyClass |
Parameters
| Name | Type |
|---|---|
payload | any |
type | T |
Returns
payload is T
Throws
Will throw type error if type is an invalid type
Defined in
isUndefined
▸ isUndefined(payload): payload is undefined
Returns whether the payload is undefined
Parameters
| Name | Type |
|---|---|
payload | any |
Returns
payload is undefined
Defined in
isWeakMap
▸ isWeakMap(payload): payload is WeakMap<any, any>
Returns whether the payload is a WeakMap
Parameters
| Name | Type |
|---|---|
payload | any |
Returns
payload is WeakMap<any, any>
Defined in
isWeakSet
▸ isWeakSet(payload): payload is WeakSet<any>
Returns whether the payload is a WeakSet
Parameters
| Name | Type |
|---|---|
payload | any |
Returns
payload is WeakSet<any>
Defined in
location
AnyQueryParams
Ƭ AnyQueryParams: undefined | null | Record<string | number, unknown>
Defined in
buildUrlQueryString
▸ buildUrlQueryString<T>(params): string
Get clean query string for URL
It returns the query string with the initial ?
TODO: at some point replace with URLSearchParams,
Type parameters
| Name | Type |
|---|---|
T | extends AnyQueryParams |
Parameters
| Name | Type |
|---|---|
params | T |
Returns
string
See
Defined in
changeUrlPath
▸ changeUrlPath(pathname, state?, replace?): string
Change URL path, ensures initial and ending slashes and normalise eventual
consecutive slashes, it uses history.
Parameters
| Name | Type | Description |
|---|---|---|
pathname | string | - |
state? | object | - |
replace? | boolean | Replace URL instead of pushing it in the history stack. By default it pushes it. |
Returns
string
The new cleaned pathname
Defined in
getParamAmong
▸ getParamAmong<T>(raw?, allowedValues?): null | T[number]
Get query parameter as string treating the ParsedUrlQuery result of
querystring (used in next.js
router and elsewhere)
Type parameters
| Name | Type |
|---|---|
T | extends string[] |
Parameters
| Name | Type | Description |
|---|---|---|
raw? | string | string[] | The raw query parameter |
allowedValues | T | The list of values (as strings) that the parameter can have, if not one of them null is returned |
Returns
null | T[number]
Defined in
getParamAsInt
▸ getParamAsInt<TFallback>(raw?, fallback?): number | TFallback
Get query parameter as integer treating the ParsedUrlQuery result of
querystring (used in next.js
router and elsewhere)
Type parameters
| Name | Type |
|---|---|
TFallback | extends undefined | null | number |
Parameters
| Name | Type | Description |
|---|---|---|
raw? | string | string[] | The raw query parameter |
fallback | TFallback | Fallback number, we return null if not provided |
Returns
number | TFallback
Defined in
getParamAsString
▸ getParamAsString(raw?): string
Get query parameter as string treating the ParsedUrlQuery result of
querystring (used in next.js
router and elsewhere)
Parameters
| Name | Type | Description |
|---|---|---|
raw? | string | string[] | The raw query parameter |
Returns
string
Defined in
getUrlHashParams
▸ getUrlHashParams<T>(hash?): T
It returns the "query params" as an object extracting it from the given hash
string or, if not provided, failling back reading the location.hash
Type parameters
| Name | Type |
|---|---|
T | extends Record<string | number, unknown> |
Parameters
| Name | Type | Default value |
|---|---|---|
hash | string | "" |
Returns
T
Defined in
getUrlHashPathname
▸ getUrlHashPathname(hash?): string
It returns the "pathname" cleaned up from the # and the initial slashes
extracting it from the given hash string or, if not provided, failling
back reading the location.hash
Parameters
| Name | Type | Default value |
|---|---|---|
hash | string | "" |
Returns
string
Defined in
getUrlPathnameParts
▸ getUrlPathnameParts(pathname?): string[]
Get pathname parts
First clean the pathname from the first slash if any then split the pathname
in parts,
Given a pathname like: "/en/{prefix}/{collection}/{slug}" we obtain
[locale, prefix, collection, slug]
Parameters
| Name | Type | Default value |
|---|---|---|
pathname | string | "" |
Returns
string[]
Defined in
getUrlQueryParams
▸ getUrlQueryParams<T>(url?): T
Get parsed query parameters as object dictionary (from URL or given query string)
Type parameters
| Name | Type |
|---|---|
T | extends Record<string | number, unknown> |
Parameters
| Name | Type | Description |
|---|---|---|
url? | string | A URL which contains a ?, e.g. ?myparam=x or https://a.com?myparams=x. If not provided it defaults reading the current URL query string with location.search. Through this argument you can use this same function to parse, for instance, the query params of the href of a <a href="..."> HTML tag. |
Returns
T
Defined in
isExternalUrl
▸ isExternalUrl(url, currentUrl?): boolean
Is external url compared to the given current URL (if not provided it falls
back to location.href)
Parameters
| Name | Type |
|---|---|
url | string |
currentUrl? | string |
Returns
boolean
Defined in
mergeUrlQueryParams
▸ mergeUrlQueryParams<T>(oldParams?, newParams?): T
Merge query parameters objects, it mutates the first given object argument
Type parameters
| Name | Type |
|---|---|
T | extends AnyQueryParams |
Parameters
| Name | Type |
|---|---|
oldParams | Record<string | number, unknown> |
newParams | Record<string | number, unknown> |
Returns
T
Defined in
normaliseUrl
▸ normaliseUrl(absoluteUrl?): string
Normalise URL, it works both for absolute and relative URLs
- replaces too many consecutive slashes (except
http{s}://) - removes the trailing slash
Parameters
| Name | Type | Default value |
|---|---|---|
absoluteUrl | string | "" |
Returns
string
See
https://stackoverflow.com/a/40649435/1938970
Defined in
normaliseUrlPathname
▸ normaliseUrlPathname(pathname?): string
Normalise URL pathname (relative URL)
- replaces too many consecutive slashes
- removes the trailing slash
Parameters
| Name | Type | Default value |
|---|---|---|
pathname | string | "" |
Returns
string
Defined in
parseURL
▸ parseURL(url): null | { hash: string ; host: string ; hostname: string ; href: string = url; pathname: string ; port: string ; protocol: string ; search: string }
Solution without DOM or specific env native methods
Parameters
| Name | Type |
|---|---|
url | string |
Returns
null | { hash: string ; host: string ; hostname: string ; href: string = url; pathname: string ; port: string ; protocol: string ; search: string }
See
https://stackoverflow.com/a/21553982/1938970
Defined in
removeTralingSlash
▸ removeTralingSlash(urlLike?): string
Strips out the trailing slash
Parameters
| Name | Type | Default value |
|---|---|---|
urlLike | string | "" |
Returns
string
Defined in
removeUrlQueryParams
▸ removeUrlQueryParams(url, paramsToRemove?): string
Remove the given keys from the given URL query parameters
Parameters
| Name | Type | Default value |
|---|---|---|
url | string | undefined |
paramsToRemove | string[] | [] |
Returns
string
Defined in
transformToUrlPathname
▸ transformToUrlPathname(toPathname?): string
Transform string in a URL pathname (relative URL)
- adds an initial slash
- encode the string
- replaces whitespaces with dashes
Parameters
| Name | Type |
|---|---|
toPathname? | string |
Returns
string
Defined in
updateLinkParams
▸ updateLinkParams($anchor, newParams): string
Update link <a href=""> merging the given new query parameters.
it returns the newly created href URL value
Parameters
| Name | Type |
|---|---|
$anchor | HTMLAnchorElement |
newParams | Record<string | number, unknown> |
Returns
string
Pure
Defined in
updateUrlQueryParams
▸ updateUrlQueryParams(url, newParams?): string
Update a URL string query parameters merging the given new query parameters
Parameters
| Name | Type |
|---|---|
url | string |
newParams | Record<string | number, unknown> |
Returns
string
Defined in
math
arraySum
▸ arraySum(numbers): number
Sum array of numbers
Parameters
| Name | Type |
|---|---|
numbers | number[] |
Returns
number
Defined in
clamp
▸ clamp(num, min, max): number
Returns a number whose value is limited to the given range.
Parameters
| Name | Type |
|---|---|
num | number |
min | number |
max | number |
Returns
number
See
https://stackoverflow.com/a/11409944/1938970
Defined in
convertRange
▸ convertRange(num, r1, r2): number
Convert range of a number
e.g. converting number 5 in a scale/range from 0 10 to a scale/range from 50 to 100 would return 75
Parameters
| Name | Type |
|---|---|
num | number |
r1 | number[] |
r2 | number[] |
Returns
number
Example
convertRange(5, [0, 10], [50, 100]);
See
https://stackoverflow.com/a/14224813
Defined in
randomInt
▸ randomInt(min, max): number
Get random int (min and max included)
Parameters
| Name | Type |
|---|---|
min | number |
max | number |
Returns
number
Defined in
roundTo
▸ roundTo(num, decimals?): string
Round to given number of the given number of decimals
Parameters
| Name | Type | Default value |
|---|---|---|
num | number | undefined |
decimals | number | 2 |
Returns
string
See
https://stackoverflow.com/a/15762794/1938970
Defined in
misc
randomKey
▸ randomKey<T>(obj): keyof T
Get random key from given object
Type parameters
| Name | Type |
|---|---|
T | extends Record<string | number, unknown> |
Parameters
| Name | Type |
|---|---|
obj | T |
Returns
keyof T
See
https://stackoverflow.com/a/15106541/1938970
Defined in
native
forin
▸ forin<T>(object, cb): void
To easily get typed native for in
Type parameters
| Name |
|---|
T |
Parameters
| Name | Type |
|---|---|
object | T |
cb | <K>(key: K, value: T[K]) => void |
Returns
void
Defined in
getKeys
▸ getKeys<T>(obj): keyof T[]
Type safe replacement for Object.keys(myObject) to iterate over a record
without loosing the key's types in simple strings.
Type parameters
| Name | Type |
|---|---|
T | extends object |
Parameters
| Name | Type |
|---|---|
obj | T |
Returns
keyof T[]
See
https://stackoverflow.com/a/59459000/1938970
Defined in
lowercase
▸ lowercase<T>(str?): Lowercase<T>
Replacement for native toLowercase tyescript ready (type narrowing ready)
Type parameters
| Name | Type |
|---|---|
T | extends string |
Parameters
| Name | Type |
|---|---|
str? | null | T |
Returns
Lowercase<T>
Defined in
noop
▸ noop(): undefined | void
No operation function
Returns
undefined | void
Defined in
uppercase
▸ uppercase<T>(str?): Uppercase<T>
Replacement for native toUpperCase tyescript ready (type narrowing ready)
Type parameters
| Name | Type |
|---|---|
T | extends string |
Parameters
| Name | Type |
|---|---|
str? | null | T |
Returns
Uppercase<T>
Defined in
object
areEqual
▸ areEqual(a, b?): boolean
A simple and quick deep equal objects utility. This is meant to be used
solely to deduplicate requests payload and perform comparison on JSON ready
objects made of primitives string, number and booleans.
It support nested objects and arrays only.
NB: undefined and null values do not count in the comparison as they are
usually meant to be ignored in JSON requestBody payloads.
According to very rudimentary tests this function takes on average between 0.15 ms and 2ms to compare two averaged sizes requet body payloads.
Parameters
| Name | Type |
|---|---|
a | Comparable |
b? | Comparable |
Returns
boolean
Defined in
forin
▸ forin<T>(object, cb): void
To easily get typed native for in
Type parameters
| Name |
|---|
T |
Parameters
| Name | Type |
|---|---|
object | T |
cb | <K>(key: K, value: T[K]) => void |
Returns
void
Defined in
getKeys
▸ getKeys<T>(obj): keyof T[]
Type safe replacement for Object.keys(myObject) to iterate over a record
without loosing the key's types in simple strings.
Type parameters
| Name | Type |
|---|---|
T | extends object |
Parameters
| Name | Type |
|---|---|
obj | T |
Returns
keyof T[]
See
https://stackoverflow.com/a/59459000/1938970
Defined in
mergeObjects
▸ mergeObjects<T>(target, ...sources): T
Merge two or more objects together. It mutates the target object.
Type parameters
| Name | Type |
|---|---|
T | extends object = object |
Parameters
| Name | Type |
|---|---|
target | T |
...sources | Partial<T>[] |
Returns
T
See
https://stackoverflow.com/a/46973278/1938970
Defined in
objectFlip
▸ objectFlip<T, U>(input, keyTransformer?): Record<U, T>
Type parameters
| Name | Type |
|---|---|
T | extends PropertyKey |
U | extends PropertyKey |
Parameters
| Name | Type |
|---|---|
input | Record<T, U> |
keyTransformer? | (key: string) => T |
Returns
Record<U, T>
Borrows
Defined in
objectOmit
▸ objectOmit<T, Keys>(object, keys): Omit<T, Keys[number]>
Omit object properties by removing the given keys, it returns a new object.
NOTE: most of the time using a normal destructuring assignment is enough, use this utility only when it makes sense.
Type parameters
| Name | Type |
|---|---|
T | extends object |
Keys | extends keyof T[] |
Parameters
| Name | Type |
|---|---|
object | T |
keys | Keys |
Returns
Omit<T, Keys[number]>
Defined in
objectPick
▸ objectPick<T, Keys>(object, keys): Pick<T, Keys[number]>
Pick object properties by selecting only the given keys, it returns a new object.
Type parameters
| Name | Type |
|---|---|
T | extends object |
Keys | extends keyof T[] |
Parameters
| Name | Type |
|---|---|
object | T |
keys | Keys |
Returns
Pick<T, Keys[number]>
Defined in
swapMap
▸ swapMap<T>(map?): Record<T[keyof T], keyof T>
Swap object map key/value
Type parameters
| Name | Type |
|---|---|
T | extends Record<string, string | number | symbol> = Record<string, string | number | symbol> |
Parameters
| Name | Type |
|---|---|
map | T |
Returns
Record<T[keyof T], keyof T>
Defined in
responsive
GetMediaQueryWidthResolversBreakpoints
Ƭ GetMediaQueryWidthResolversBreakpoints: Record<string, number>
Defined in
getMediaQueryWidthResolvers.ts:4
createPalette
▸ createPalette<TName, TShades, TColor, TMap>(name, shades): readonly [TMap, Record<`${TName}-${TShades[number][0]}`, string>, TColor[]]
Create palette, this is primarily thought to improve the reuse of a palette definition between TailwindCSS and straight ES imports
Type parameters
| Name | Type |
|---|---|
TName | extends string |
TShades | extends PaletteShades |
TColor | TShades[number][``1``] |
TMap | PaletteMap<TShades> |
Parameters
| Name | Type |
|---|---|
name | TName |
shades | TShades |
Returns
readonly [TMap, Record<`${TName}-${TShades[number][0]}`, string>, TColor[]]
An array with: 1) A flat palette map 2) A TailwindCSS ready palette
object 3) A flat array of colors (no special sorting, same order as the shades
given as argument)
Defined in
getMediaQueryWidthResolvers
▸ getMediaQueryWidthResolvers<TBreakpointsConfig>(customBreakpoints): Object
Type parameters
| Name | Type |
|---|---|
TBreakpointsConfig | extends GetMediaQueryWidthResolversBreakpoints |
Parameters
| Name | Type |
|---|---|
customBreakpoints | TBreakpointsConfig |
Returns
Object
| Name | Type |
|---|---|
between | (br1: Extract<keyof TBreakpointsConfig, string>, br2?: Extract<keyof TBreakpointsConfig, string>) => string |
down | (br: Extract<keyof TBreakpointsConfig, string>) => string |
max | (br: Extract<keyof TBreakpointsConfig, string>) => string |
min | (br: Extract<keyof TBreakpointsConfig, string>) => string |
only | (br: Extract<keyof TBreakpointsConfig, string>) => string |
up | (br: Extract<keyof TBreakpointsConfig, string>) => string |
Defined in
getMediaQueryWidthResolvers.ts:9
getMediaQueryWidthTailwindScreens
▸ getMediaQueryWidthTailwindScreens(breakpoints): Record<string, { raw: string }>
Parameters
| Name | Type |
|---|---|
breakpoints | GetMediaQueryWidthResolversBreakpoints |
Returns
Record<string, { raw: string }>
Defined in
getMediaQueryWidthTailwindScreens.ts:10
security
decode
▸ decode<TReturn>(str): TReturn
Type parameters
| Name | Type |
|---|---|
TReturn | extends string |
Parameters
| Name | Type |
|---|---|
str | string |
Returns
TReturn
See
https://stackoverflow.com/a/22405578/9122820
Defined in
encode
▸ encode<TReturn>(str): TReturn
Type parameters
| Name | Type |
|---|---|
TReturn | extends string |
Parameters
| Name | Type |
|---|---|
str | string |
Returns
TReturn
See
https://stackoverflow.com/a/22405578/9122820
Defined in
getNonce
▸ getNonce(): null | string
Returns
null | string
See
Defined in
ssr
isBrowser
• Const isBrowser: boolean
Defined in
isServer
• Const isServer: boolean = !isBrowser
Defined in
isBrowserNow
▸ isBrowserNow(): boolean
Returns
boolean
Defined in
isServerNow
▸ isServerNow(): boolean
Returns
boolean
Defined in
tailwind
createPalette
▸ createPalette<TName, TShades, TColor, TMap>(name, shades): readonly [TMap, Record<`${TName}-${TShades[number][0]}`, string>, TColor[]]
Create palette, this is primarily thought to improve the reuse of a palette definition between TailwindCSS and straight ES imports
Type parameters
| Name | Type |
|---|---|
TName | extends string |
TShades | extends PaletteShades |
TColor | TShades[number][``1``] |
TMap | PaletteMap<TShades> |
Parameters
| Name | Type |
|---|---|
name | TName |
shades | TShades |
Returns
readonly [TMap, Record<`${TName}-${TShades[number][0]}`, string>, TColor[]]
An array with: 1) A flat palette map 2) A TailwindCSS ready palette
object 3) A flat array of colors (no special sorting, same order as the shades
given as argument)
Defined in
getMediaQueryWidthTailwindScreens
▸ getMediaQueryWidthTailwindScreens(breakpoints): Record<string, { raw: string }>
Parameters
| Name | Type |
|---|---|
breakpoints | GetMediaQueryWidthResolversBreakpoints |
Returns
Record<string, { raw: string }>
Defined in
getMediaQueryWidthTailwindScreens.ts:10
text
AccentsSet
Ƭ AccentsSet: [string, string]
First value is the to, second is from, from which chars do we translates to
Defined in
accentsSets
• Const accentsSets: AccentsSet[]
Accent sets
Resources
- https://gist.github.com/mathewbyrne/1280286#gistcomment-3498021
- https://gist.github.com/eek/9c4887e80b3ede05c0e39fee4dce3747 for usage of normalize
Defined in
capitalize
▸ capitalize<T>(string?): Capitalize<T>
Capitalize first letter of the given string.
Type parameters
| Name | Type |
|---|---|
T | extends string |
Parameters
| Name | Type |
|---|---|
string? | null | T |
Returns
Capitalize<T>
Resources
Defined in
removeAccents
▸ removeAccents(text?, sets?): string
Parameters
| Name | Type | Default value |
|---|---|---|
text | string | "" |
sets | AccentsSet[] | accentsSets |
Returns
string
Defined in
slugify
▸ slugify(text, separator?): string
Slugify a text
- replaces the accented letters
- replaces the punctuation with dashes
Parameters
| Name | Type | Default value |
|---|---|---|
text | string | undefined |
separator | string | "-" |
Returns
string
Borrows
Defined in
titleCase
▸ titleCase(input?): string
Parameters
| Name | Type |
|---|---|
input? | null | string |
Returns
string
Borrows
License
Blake Embrey (hello@blakeembrey.com)
Defined in
truncate
▸ truncate(input, length): string
Truncate string
Parameters
| Name | Type |
|---|---|
input | undefined | null | string |
length | number |
Returns
string
Defined in
uppercase
▸ uppercase<T>(str?): Uppercase<T>
Replacement for native toUpperCase tyescript ready (type narrowing ready)
Type parameters
| Name | Type |
|---|---|
T | extends string |
Parameters
| Name | Type |
|---|---|
str? | null | T |
Returns
Uppercase<T>
Defined in
uid
uid
▸ uid(prefix?): string
Super basic UID increment-based generator
Parameters
| Name | Type | Default value |
|---|---|---|
prefix | string | "id" |
Returns
string
Defined in
uuid
▸ uuid(): string
Uuid, tiny custom helper instead of node's uuid/v4
Returns
string
See
https://stackoverflow.com/a/2117523/1938970
Defined in
uuidNumeric
▸ uuidNumeric(): number
Returns
number
See
https://stackoverflow.com/a/18048162/1938970