@jsonql/utils
v1.3.2
Published
@jsonql/utils general purpose utilities library
Downloads
15
Readme
@jsonql/utils
This is a dependency module for various jsonql node / browser modules.
How to use
When using purely in browser environment, you should use @jsonql/utils/browser
For ESM you could include the @jsonql/utils/esm
When using it within your JS / TS development, most of the methods can be found in @jsonql/utils
~~Where the node only methods will be in @jsonql/utils/node
@DREPRECATED~~
Complete list of all available functions
When use with build tool, for better tree shaking. You need to import them directly. Please reference which functions in what file below
@jsonql/utils/dist/access
accessByPath
(obj: AnyType, path: string)
const obj = { a: 1, b: { c: 2} }
const c = accessByPath(obj, 'b.c')
// c === 2
@jsonql/utils/dist/array (V1.2.0 breaking)
inArray
(arr: AnyTypeArr, value: AnyType): booleantoArray
(arg: AnyType): Arraycompact
(arg: Array): Array
example for compact:
const result = compcat([0, 1, 2, null, false, 3])
// [ 1, 2, 3 ]
Basically compact will remove any non-truthy value from the value, even 0!
@jsonql/utils/dist/chain-fns
chainFns
(mainFn: AnyType, ...moreFns: AnyType)
It returns a function to accept parameter for the mainFn
, then after execute the function will pass to the next function until we get the final result. This is a sync method.
const fn1 = (a) => a + 1
const fn2 = (b) => b + 2
const fn3 = (c) => c + 4
const fn = chainFns(fn1, fn2, fn3)
const result = fn(1)
// result === 8
You can also do this:
const fn1 = (a) => a + 1
const fn2 = (b) => [b, 2]
const fn3 = (x, y) => x + y
const fn = chainFns(fn1, fn2, fn3)
const result = fn(1)
// result === 4
@jsonql/utils/dist/chain-promises
chainPromises
(promies: Array<Promise>, asObject: boolean | object = false)chainProcessPromises
(initPromise: JsonqlPromiseChainFn, ...promises: Array)queuePromisesProcess
(queue: Array, ...initValue: AnyTypeArr)
chainPromises
will put every promises resolve result into an array (default) or if you set the asObject
parameter to true or pass an object, it will merge into one object. In some way this is similar to Promise.all
. The different is when one of the promise failed, it will stop and throw immediately. And it can config to return a merge object as result.
chainProcessPromises
will return a function that accept the argument for the first async function, then each result will pass to the next function as argument. This is the async version of the above chainFns
.
queuePromisesProcess
is a wrapper of the chainProcessPromises
, the call signature makes it easier to call with Reflect.apply
@jsonql/utils/dist/clone-deep
cloneDeepCheap
(obj: AnyType)cloneDeep
(obj: AnyType)
cloneDeepCheap
only able to clone object, internally using JSON
cloneDeep
will able to clone all kinds of deep structure object even a class instance (which could be expensive operation).
@jsonql/utils/dist/common
parseJson
(json: AnyType, t = true): JSON | json | ErrorcreateEvtName
(...args: string[]): stringnil
() => boolean (false)showDeep
(code: unknown): voidformatStr
(str: string, ...args: Array): string
formatStr
example:
const str = 'I want to go from {0} to {1}'
const output = formatStr(str, 'zero', 'one')
// I want to go from zero to one
@jsonql/utils/dist/convert
strToNum
(input: string, t = false): numberstrToBool
(input: string, t = false): boolean
@jsonql/utils/dist/dasherize
dasherize
(str: string): string
@jsonql/utils/dist/empty
isEmptyObj
(obj: AnyType): booleanisNotEmpty
(param: unknown): booleannotEmpty
(a: unknown, valueCheck = false): booleanisEmpty
(value: unknown, valueCheck?: boolean): boolean
@jsonql/utils/dist/get-dirname (node.js only!)
getDirname
(url: string): string
This is only use in ESM
env in node.js
// there is no __dirname in ESM env
const __dirname = getDirname(import.meta.url)
THIS IS NOT INCLUDED IN THE EXPORT LIST, you need to import it like so:
import { getDirname } from '@jsonql/dist/get-dirname'
@jsonql/utils/dist/is-equal
isEqualCheap
(obj1: unknown, obj2: unknown): booleanisEqual
(obj1: unknown, obj2: unknown)
isEqualCheap
can only compare two object, isEqual
can compare anything
@jsonql/utils/dist/is-function
isFunction
(prop: unknown, debug = false): booleanisAsyncFunction
(prop: unknown): boolean
@jsonql/utils/dist/jwt
parseJWT
(token: string): unknown
It returns typed as unknown
is follow the standard, you have to cast it again when your own structure. In the future release, we might create our own type for a standard JWT decoded object type.
@jsonql/utils/dist/lodash
curry
(fn: AnyType, ...args: AnyType[])merge
(target: AnyType, ...sources: AnyType[])flatMap
(arr: AnyType[], callback?: FlatMapCallback)isString
(value: unknown): boolean
These methods used to included from lodash-es
now we implement them ourself, and cut down the library size to just 5kb
@jsonql/utils/dist/logger
logger
(wrapper for console.log to use in browser, setwindow.DEBUG=true
then it will show)
@jsonql/utils/dist/obj-define-props
objDefineProps
(obj: AnyType, name: string, setter: AnyType, getter = null)objHasProp
(obj: AnyType, name: string)injectToFn
(resolver: JsonqlResolver | JsonqlAsyncResolver, name: string, data: AnyType, overwrite = false)
@jsonql/utils/dist/object
isObject
(o: AnyType): booleanisPlainObject
(o: AnyType): booleanisClass
(o: AnyType): booleangetConfigValue
(name: string, obj: object)assign
(...args: unknown[]): unknownextend
(alias toassign
)arrToObj
(args: unknown[], processor: MapCallback, initValue = {}): AnyTypeobjectHasKey
(obj: object, key: string): booleanreadOnly
(config: object): AnyType
@jsonql/utils/dist/promise
promsie
async (cb: AnyType)processAll
async (promises: Array<Promise>)
promise is just a new Promise
wrapper save a bit typing
processAll return Array of Array of results, see example below
const tasks = [
Promise.resolve(1),
Promise.reject(2),
Promise.resolve(3)
]
// this will not throw instead put into the result array
processAll(tasks)
.then(result => {
const done = result[0]
const fail = result[1] // if there is no fail then this won't exist
// done --> [1,3]
// fail --> [2]
})
@jsonql/utils/dist/regex
isRegExp
(pat: AnyType): booleangetRegex
(pattern: string | RegExp): RegExp | string | boolean
@jsonql/utils/dist/timestamp
timestamp
(sec = false): number
Default return mil-seconds
@jsonql/utils/dist/truetypeof
trueTypeOf
(obj: AnyType): string
Special Thank you to (c) 2021 Chris Ferdinandi, MIT License, https://gomakethings.com
@jsonql/utils/dist/urls
urlParams
(url: string, params: AnyType): stringcacheBurstUrl
(url: string): stringcacheBurst
(name = '_cb')
Please check jsonql for more information.
Joel Chu (c) 2022