UNPKG

enum-plus

Version:

A drop-in replacement for native enum. Like native enum but much better!

413 lines (238 loc) 11.1 kB
<!-- markdownlint-disable MD009 MD024 --> # enum-plus Changelog ## 3.1.6 2025-11-26 ### Features - ✨ Expand the AnyEnum type to be compatible with all enumeration types. ## 3.1.5 2025-11-20 ### Features - ✨ Enhance enum creation to support function labels and enum name. ### Bug Fixes - 🐞 Fix the issue where `enum.meta` is always empty in `meta-only` mode. ## 3.1.4 2025-11-19 ### Features - ✨ Add `AnyEnum` type as a generic enum type that can be used to represent any enum collection. - 🛠 Improve the type of `enum.meta`. ## 3.1.3 2025-11-17 ### Features - ✨ Enhance `Enum.extends` method to support getter and setter properties in the extension object. ## 3.1.2 2025-11-7 ### Features - 🛠 Export the `./extension` subpath in package.json to fix the `Cannot find module 'enum-plus/extension'"` error. - 🛠 Exclude `label` field from the type of `autoLabel` option. ## 3.1.1 2025-10-22 ### Features - ✨ Introduce `meta-only` mode in `Enum` creation, allowing the creation of Enums without `value` and `label` fields. This is useful for scenarios where only metadata is needed for enum items. - ✨ Implementation `instanceof` operator of `Enum` method, and add type guard to provide type narrowing functionality. This allows you to use `instanceof` to check if an object is an enum object created by `Enum`. - ✨ Add type guard to `Enum.has` method. - 🛠️ Allow the type extending for `Enum.name`, just like enum labels. - 📝 Add documentation for TypeScript 5.0 upgrade instructions ## 3.1.0 2025-10-21 ### Features - ✨ Introduce `Enum.config` to manage global configuration for all Enums. - `Enum.config.autoLabel` to enable/disable automatic label generation for enum items by specifying the label prefix. - ✨ Add `options.labelPrefix` to specify the label prefix for enum items during Enum creation. - ✨ Add `options.autoLabel` to enable/disable automatic label generation on Enum creation. It overrides the global configuration. - ✨ Allow extending `EnumItemLabel` type to support IntelliSense. ## 3.0.1 2025-10-6 ### Features - 🛠 Improve type guard feature of `Enum.isEnum` method. - 📝 Add the badge of DeepWiki in README. ## 3.0.0 2025-10-5 > 🎉 **v3.0 is Arrived!** > > This is a milestone release that brings many exciting features and improvements. Enjoy the new version! > > Please refer to the [Release Notes](./docs/release-v3.md) and [Migration Guide](./docs/migration-guide-v2-to-v3.md) for details. ### Features - ✨ Introduce the new [Plugin System](./README.md#plugin-system). Many fantastic features can be shared as plugins, and you can enhance Enum by installing them. - 💄 Simplified enum initialization. No `as const` assertion is required on TypeScript ≥ 5.0. _Thanks to @otomad_. - ✨ New `enum.named` for quick access EnumItem by `key`. - ✨ New `enum.meta` to aggregate custom metadata fields across items. - ✨ New `enum.labels` returning a readonly array of labels. - ✨ New `enum.toList` to transform enum items to a list of `{ value, label }` objects. Supports remapping the field names via options. - ✨ New `enum.toMap` to transform enum items to a mapping object. Supports remapping the field names via options. - ✨ New `Enum.isEnum` for type guarding. - ✨ New `enum.findBy` to locate an item by built-in or metadata fields. - ✨ New `Enum.install` to install plugins. - 🛠️ Typing: `instanceof` narrowing for EnumCollection; updated `Enum.extend` typing; graceful downgrade across TS versions. - ✨ Ship UMD module format under `umd` folder for direct browser usage. ### Notable Changes - The typing declaration of extending Enums has [changed](./docs/migration-guide-v2-to-v3.md#-the-typing-declaration-of-extending-enums-has-changed) - Recommended to upgrade TypeScript to 5.0 ### Breaking Changes - The following deprecated methods are removed: - `enums.values` - `enums.options` - `enums.menus` - `enums.filters` - `enums.valuesEnum` - The following methods are removed from the core library and moved to the [@enum-plus/plugin-antd](https://www.npmjs.com/package/@enum-plus/plugin-antd) plugin. Please install the plugin to use them. - `enums.toSelect` - `enums.toMenu` - `enums.toFilter` - `enums.toValueMap` - The following symbols are renamed: - `ENUM_COLLECTION` symbol is renamed to `IS_ENUM`. - `ENUM_ITEM` symbol is renamed to `IS_ENUM_ITEM`. - `ENUM_ITEMS` symbol is renamed to `IS_ENUM_ITEMS`. - `EnumValuesArray` interface is renamed to `EnumItemsArray`, and the `...rest` parameter is removed. - `IEnumValues` interface is renamed to `IEnumItems`. ### Bug Fixes - 🐞 Fix sourcemap resolution issues in `CommonJS` mode ## 2.4.3 2025-9-4 ### Security - 🔒 Bump `sha.js` from `2.4.11` to `2.4.12` to address security vulnerabilities. ## 2.4.2 2025-7-8 ### Bug Fixes - 🐞 Fix the issue where `lib/extension.d.ts` was missing, which caused all enum types to default to `any`. ## 2.4.1 > ⚠️ This version is deprecated. Please use `v2.4.2` instead. 2025-7-7 ### Bug Fixes - 🐞 Fix `lib/extension.d.ts` missing issue, but failed. Please use `v2.4.2` instead. ## 2.4.0 > ⚠️ This version has a critical issue, please use `v2.4.2` instead. 2025-7-6 ### Features - 🛠 Support `Node.js ESM` - 🛠 Remove file circular dependencies ## 2.3.5 2025-7-6 ### Features - 🛠 Downgrade the requirement of TypeScript to `v3.8` ## 2.3.4 2025-7-2 ### Features - ✨ Enhance the type definitions for methods like `Enum.label`, `Enum.key`, and `Enum.raw` to ensure return types more accurately correspond to input values. When an input value can be matched within the enum, the return type will no longer include `undefined`. ## 2.3.3 2025-6-19 ### Features - 🔥 Allow naming Enum types, accept both plain text and localization keys, similar to the localization for enum members. - 🛠 Mark Enum collection fields as `readonly`. - 🛠 Improve the type of `Enum.label``Enum.key``Enum.raw` parameters, to accept the real value types. ## 2.3.2 2025-6-10 ### Features - ✨ Improve type IntelliSense for array initialization Enums, allowing enum items to be listed as literals. Thanks to @mudoo. ## 2.3.1 2025-6-7 ### Features - ✨ Add `IEnum` to packages exports ## 2.3.0 2025-5-23 ### Features - ✨ Export new symbols `ENUM_ITEM``ENUM_ITEMS` and `ENUM_COLLECTION` which are used to access some special internal properties. - ✨ Add `[ENUM_COLLECTION]: true` to the `Enum` class, which is used to indicates that this is as an enum collection. - ✨ Add `[ENUM_ITEM]: true` to the `EnumItem` class, which is used to indicates that this is as an enum item. - ✨ Add `[ENUM_ITEMS]: true` to `Enum.items` array, which is used to indicates that this is as an enum items array. ### Notable Changes - 💣 Remove `[Symbol.toStringTag]: "EnumItem"` from `EnumItem` class. The result of `Object.prototype.toString.call(enumItem)` is changed from `[object EnumItem]` back to `[object Object]`. If you are relying on this, please use `enumItem[ENUM_ITEM] === true` instead. - 💣 Remove `[Symbol.toStringTag]: "EnumCollection"` from `Enum` class. The result of `Object.prototype.toString.call(enum)` is changed from `[object EnumCollection]` to `[object Array]`. If you are relying on this, please use `enum[ENUM_COLLECTION] === true` instead. ## 2.2.11 2025-5-15 ### Features - 🛠 Remove `"type": "commonjs"` from package.json, which may breaks webpack bundling. ## 2.2.10 2025-5-14 ### Features - ✨ Enhance the type inference of the `raw` method. When the input value matches a specific enum item, it only returns the raw object of that enum item instead of returning the raw objects of all enum items. ## 2.2.9 2025-4-20 ### Features - 🛠 Emit a warning while trying to modify an `EnumItem` ### Bug Fixes - 🐞 the output `lib` directory structure is incorrect. This will break legacy Node.js applications using the `CommonJS` module spec, while modern Node.js applications using the `NodeNext` module spec remain unaffected. This issue was introduced in `v2.2.7`. For node.js applications, it's strongly recommended to upgrade. ## 2.2.8 2025-3-30 ### Bug Fixes - 🐞 Fix `exports` configuration for moduleResolution `ESNext` ## 2.2.7 2025-3-30 ### Features - 🛠 provide different versions of ESModule output for modern browsers and legacy browsers ## 2.2.6 2025-3-29 ### Features - 🛠 change compile transformer - 👀 support `ES2020` and `Chrome>=80`, if you need to support legacy browsers, please use use a modern bundler like `webpack` or `vite` and use `babel` to include proper polyfills on-demand. - 👀 for the Node.js environment, backward compatible down to ES2016. - 🛠 generate better sourcemaps - 🛠 package size reduces by 0.1k ## 2.2.5 2025-3-7 ### Features - 🛠 improve Enum typing, support `boolean` and `Date` as enum values ## 2.2.4 2025-2-24 ### Features - 🛠 Support global type extension for enum localization keys, providing better editor intelligence awareness ## 2.2.3 2025-2-19 ### Features - 🛠 `Enum.localize` supports delayed assignment, i.e. sets the function after the enum is created ## 2.2.2 2025-2-10 ### Features - 🛠 Change the return type of `Enum.options.getKey` - 📖 Update docs ## 2.2.1 2025-2-10 - 📖 Update docs ## 2.2.0 2025-2-9 ### Features - 🔥 Support initializing Enum with native enums - 🔥 Add `items` array, deprecated the _`values`_ array. Reduces package size. ## 2.1.1 2025-2-8 ### Bug Fixes - 🐞 Fix typing error in `EnumExtension` interface ## 2.1.0 2025-2-8 > **Note:** This version has a typing issue, please use `v2.1.1` ### Features - 🔥 Add `toSelect` method, deprecated the _`options`_ method - 🔥 Add `toMenu` method, deprecated the _`menus`_ method - 🔥 Add `toFilter` method, deprecated the _`filters`_ method - 🔥 Add `toValueMap` method, the _`valuesEnum`_ method - 🔥 Support global extension, custom methods can be added to Enums ## 2.0.3 2025-2-6 ### Features - 🛠 Downgrade EcmaScript version to `ES2015` ## 2.0.2 2025-2-3 ### Features - 🔥 The `firstOption` of `options` method supports localization ## 2.0.1 2025-2-2 ### Features - 🔥 Support for enum text localization - the `Enum` method now accepts a `localize` option that can be used to localize the enum text - you can also set the `Enum.localize` static method to localize all enums in a lower priority - 🔥 Add `menus` method ### Breaking Changes - 💣 All parameters after the first of the `Enum` method has been changed to an `options` object ## 1.0.3 2023-11-14 - 🛠 Both the `enum.raw` or `enumItem.raw` methods return the original array item, if an enum is created from array, ## 1.0.2 2023-07-31 - 🆕 Add `rawType` accessor ## 1.0.1 2023-03-09 - 🆕 Add a new `filters` method that returns an array of enumerated items that can be passed directly to the `Column.filters` of the AntDesign Table component as a list of filtered items for the column - ## 1.0.0 2022-10-08 - 🆕 The first release of `enum-plus` library