/enum-mixin

Enum() mixin

Primary LanguageJavaScriptCreative Commons Zero v1.0 UniversalCC0-1.0

Package enum-mixin

Enum mixin for declaring "Java-like" enums.

Usage

Class statement:

class Fruit extends Enum() {
    apple;
    banana;
    orange;
    strawberry;
}

Class expression:

const Fruit = class extends Enum() {
    apple;
    orange;
    strawberry;
    banana = "berry";
}

Comparisons:

Fruit.apple == Fruit.orange; // false

Type check:

Fruit.banana instanceof Fruit; // true

Access by key name:

const key = "strawberry";
Fruit[key]; // Fruit.strawberry

Access by value:

Fruit.byValue("orange"); // Fruit.orange
Fruit.byValue("berry"); // Fruit.banana

String representation:

Fruit.banana.toString(); // [enum Fruit(banana)]

JSON representation:

JSON.stringify({fruit: Fruit.banana}); // {"fruit": "berry"}

Notes

Enum members are lazy loaded to the static context of the class on first access.

class Lazy extends Enum() {
    one;
    two;
    three;
}

// Before loading
Object.keys(Lazy); // []

// Trying to access any property will trigger the mixin
Lazy._;

// After loading
Object.keys(Lazy); // ["one", "two", "three"]

To explicitly load the static context you may use the static method initialize.

class Forced extends Enum() {
    one;
    two;
    three;
}
Forced.initialize();

Object.keys(Forced); // ["one", "two", "three"]

Thanks

Pay me a coffee:

nano_3ntf6crkan6114rfb39d51udqdw4mrbt1x7n8uphx44ojhxcjo3exhk6dsme

nano_3ntf6crkan6114rfb39d51udqdw4mrbt1x7n8uphx44ojhxcjo3exhk6dsme