mirror of
https://github.com/Kir-Antipov/mc-publish.git
synced 2024-11-22 00:11:02 -05:00
Made a function to retrieve enum keys
This commit is contained in:
parent
0a98e5a66a
commit
1d0d5c6cff
2 changed files with 77 additions and 0 deletions
39
src/utils/enum/enum-key.ts
Normal file
39
src/utils/enum/enum-key.ts
Normal file
|
@ -0,0 +1,39 @@
|
|||
import { isReadOnlyMap } from "@/utils/collections";
|
||||
|
||||
/**
|
||||
* A type that represents the key of an enum type `T`.
|
||||
*
|
||||
* @template T - The enum type whose keys are being represented.
|
||||
*/
|
||||
export type EnumKey<T> = keyof T extends string ? keyof T : never;
|
||||
|
||||
/**
|
||||
* Retrieves an array of the string keys of the specified `enum` object.
|
||||
*
|
||||
* @template T - Type of the enum.
|
||||
*
|
||||
* @param e - The enum object to retrieve the keys for.
|
||||
*
|
||||
* @returns An array of the string keys of the specified `enum` object.
|
||||
*/
|
||||
export function enumKeys<T>(e: T): EnumKey<T>[] {
|
||||
if (isReadOnlyMap<EnumKey<T>, unknown>(e)) {
|
||||
return [...e.keys()];
|
||||
}
|
||||
|
||||
return Object.getOwnPropertyNames(e).filter(key => isEnumKey(e, key)) as EnumKey<T>[];
|
||||
}
|
||||
|
||||
/**
|
||||
* Determines if the provided key is an enumeration key.
|
||||
*
|
||||
* @template T - Type of the enum.
|
||||
*
|
||||
* @param e - The enum object to check the key against.
|
||||
* @param key - The key to be checked.
|
||||
*
|
||||
* @returns `true` if the key is an enumeration key; otherwise, `false`.
|
||||
*/
|
||||
function isEnumKey<T>(e: T, key: string): key is EnumKey<T> {
|
||||
return typeof e[key] !== "function" && key !== String(+key);
|
||||
}
|
38
tests/unit/utils/enum/enum-key.spec.ts
Normal file
38
tests/unit/utils/enum/enum-key.spec.ts
Normal file
|
@ -0,0 +1,38 @@
|
|||
import { Enum } from "@/utils/enum/enum";
|
||||
import { enumKeys } from "@/utils/enum/enum-key";
|
||||
|
||||
describe("enumKeys", () => {
|
||||
test("returns the correct keys for number-based built-in enums", () => {
|
||||
enum NumberEnum {
|
||||
A = 1,
|
||||
B = 2,
|
||||
C = 3,
|
||||
}
|
||||
|
||||
const keys = enumKeys(NumberEnum);
|
||||
|
||||
expect(keys).toEqual(["A", "B", "C"]);
|
||||
});
|
||||
|
||||
test("returns the correct keys for string-based built-in enums", () => {
|
||||
enum StringEnum {
|
||||
A = "a",
|
||||
B = "b",
|
||||
C = "c",
|
||||
}
|
||||
|
||||
const keys = enumKeys(StringEnum);
|
||||
expect(keys).toEqual(["A", "B", "C"]);
|
||||
});
|
||||
|
||||
test("returns the correct keys for custom enums created with Enum.create", () => {
|
||||
const CustomEnum = Enum.create({
|
||||
A: 1n,
|
||||
B: 2n,
|
||||
C: 3n,
|
||||
});
|
||||
|
||||
const keys = enumKeys(CustomEnum);
|
||||
expect(keys).toEqual(["A", "B", "C"]);
|
||||
});
|
||||
});
|
Loading…
Reference in a new issue