@commodo/name

1.3.1 • Public • Published

@commodo/name

Decorates a function (and its instances) with a name, that can be used for various purposes.

For example, the @commodo/fields-storage package relies on the name in order to determine the database table in which the data will be saved.

Usage

import { withName } from "@commodo/name";
import { compose } from "ramda";

const User = compose(
  withName("User"),
  (...)
)();

const Company = compose(
  withName("Company"),
  (...)
)();

You can then use the hasName and getName functions in order to determine if a name was assigned to the passed value, or to get the actual name that was assigned, respectively.

import { withName, hasName, getName } from "@commodo/name";
import { compose } from "ramda";

// A function with a name assigned.
const User = compose(
  withName("User"),
  (...)
)();

// A function without a name assigned.
const Unknown = compose(
  // Name not assigned.
  // withName("Unknown"), 
  (...)
)();

console.log(hasName(User)); // true
console.log(getName(User)); // "User"

// The Unknown function doesn't have a name assigned.
console.log(hasName(Unknown)); // false
console.log(getName(Unknown)); // ""

// Also works on function instances.
const user = new User();
console.log(hasName(user)); // true
console.log(getName(user)); // "User"

const unknown = new Unknown();
console.log(hasName(unknown)); // false
console.log(getName(unknown)); // ""

Reference

withName(name: string): Function

Decorates a function (and its instances) with a name.

hasName(value: any): boolean

Checks if the passed value has a name assigned via the withName.

getName(value: any): string

Returns a name assigned to the passed value. Returns empty string if none assigned.

Package Sidebar

Install

npm i @commodo/name

Weekly Downloads

636

Version

1.3.1

License

MIT

Unpacked Size

6.67 kB

Total Files

10

Last publish

Collaborators

  • commodo-user