deno.land / std@0.224.0 / collections / partition_entries.ts

partition_entries.ts
View Documentation
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.// This module is browser compatible.
/** * Returns a tuple of two records with the first one containing all entries of * the given record that match the given predicate and the second one containing * all that do not. * * @example * ```ts * import { partitionEntries } from "https://deno.land/std@$STD_VERSION/collections/partition_entries.ts"; * import { assertEquals } from "https://deno.land/std@$STD_VERSION/assert/assert_equals.ts"; * * const menu = { * "Salad": 11, * "Soup": 8, * "Pasta": 13, * } as const; * const myOptions = partitionEntries( * menu, * ([item, price]) => item !== "Pasta" && price < 10, * ); * * assertEquals( * myOptions, * [ * { "Soup": 8 }, * { "Salad": 11, "Pasta": 13 }, * ], * ); * ``` */export function partitionEntries<T>( record: Readonly<Record<string, T>>, predicate: (entry: [string, T]) => boolean,): [match: Record<string, T>, rest: Record<string, T>] { const match: Record<string, T> = {}; const rest: Record<string, T> = {}; const entries = Object.entries(record);
for (const [key, value] of entries) { if (predicate([key, value])) { match[key] = value; } else { rest[key] = value; } }
return [match, rest];}
std

Version Info

Tagged at
8 months ago