| /** |
| * 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. |
| * ```ts |
| * const phoneBook = [ |
| * { name: 'Jon', num: '555-1234' }, |
| * { name: 'Jenny', num: '867-5309' } |
| * ] |
| * |
| * const entriesByName = keyMap( |
| * phoneBook, |
| * entry => entry.name |
| * ) |
| * |
| * // { |
| * // Jon: { name: 'Jon', num: '555-1234' }, |
| * // Jenny: { name: 'Jenny', num: '867-5309' } |
| * // } |
| * |
| * const jennyEntry = entriesByName['Jenny'] |
| * |
| * // { name: 'Jenny', num: '857-6309' } |
| * ``` |
| */ |
| export function keyMap(list, keyFn) { |
| const result = Object.create(null); |
|
|
| for (const item of list) { |
| result[keyFn(item)] = item; |
| } |
|
|
| return result; |
| } |