import type { ObjMap } from './ObjMap';
/**
* Creates a keyed JS object from an array, given a function to produce the keys
* for each value in the array.
*
* This provides a convenient lookup for the array items if the key function
* produces unique results.
* @internal
* @example
* ```ts
* const phoneBook = [
* { name: 'Jon', num: '555-1234' },
* { name: 'Jenny', num: '867-5309' },
* ];
*
* const entriesByName = keyMap(phoneBook, (entry) => entry.name);
*
* Object.keys(entriesByName); // => ['Jon', 'Jenny']
* entriesByName['Jenny']; // => { name: 'Jenny', num: '867-5309' }
* ```
*/
export function keyMap<T>(
list: ReadonlyArray<T>,
keyFn: (item: T) => string,
): ObjMap<T> {
const result = Object.create(null);
for (const item of list) {
result[keyFn(item)] = item;
}
return result;
}