function pick (object: O, keys: K[]): Pick { const result: any = {} for (const key of keys) { if (Object.prototype.hasOwnProperty.call(object, key)) { result[key] = object[key] } } return result } function omit (object: O, keys: K[]): Exclude { const result: any = {} const keysSet = new Set(keys) as Set for (const [ key, value ] of Object.entries(object)) { if (keysSet.has(key)) continue result[key] = value } return result } function objectKeysTyped (object: O): K[] { return (Object.keys(object) as K[]) } function getKeys (object: O, keys: K[]): K[] { return (Object.keys(object) as K[]).filter(k => keys.includes(k)) } function hasKey (obj: T, k: keyof any): k is keyof T { return k in obj } function sortObjectComparator (key: string, order: 'asc' | 'desc') { return (a: any, b: any) => { if (a[key] < b[key]) { return order === 'asc' ? -1 : 1 } if (a[key] > b[key]) { return order === 'asc' ? 1 : -1 } return 0 } } function shallowCopy (o: T): T { return Object.assign(Object.create(Object.getPrototypeOf(o)), o) } function simpleObjectsDeepEqual (a: any, b: any) { if (a === b) return true if (typeof a !== 'object' || typeof b !== 'object' || a === null || b === null) { return false } const keysA = Object.keys(a) const keysB = Object.keys(b) if (keysA.length !== keysB.length) return false for (const key of keysA) { if (!keysB.includes(key)) return false if (!simpleObjectsDeepEqual(a[key], b[key])) return false } return true } export { pick, omit, objectKeysTyped, getKeys, hasKey, shallowCopy, sortObjectComparator, simpleObjectsDeepEqual }