0.7.0 • Published 3 months ago

rswitch v0.7.0

Weekly downloads
-
License
MIT
Repository
github
Last release
3 months ago

rswitch

The rswitch library provides a compact and flexible way to implement a switch-like functionality in TypeScript. It allows you to define cases and their corresponding actions using an object literal syntax.

Installation

Install the rswitch library using npm:

npm install rswitch

Usage

The rswitch function takes a key and an object containing cases and actions. It evaluates the key against the cases and returns the corresponding action.

Syntax

rswitch(key, casesObj, options);
  • key : The value to evaluate against the cases.
  • casesObj : An object containing cases and their actions.
  • options : (Optional) An object to customize the behavior of the rswitch function.
    • returnFn (optional, default: false): If set to false, the rswitch function will call actions that are functions and return their values. If set to true, the function will return the functions as is.

Example

import rswitch from "rswitch";
// const {rswitch} = require("rswitch") // commonjs

const result = rswitch(
  "dev",
  {
    designer: "Designer",
    "dev, web": "Developer",
    "": () => {
      console.log("Hello");
    },
  },
  {
    returnFn: true,
  }
);

console.log(result);
// Output: Developer

In this example, the rswitch function evaluates the key 'dev' against the cases defined in casesObj. Since it matches the case 'dev, web', the corresponding action 'Developer' is returned and assigned to the result variable. Finally, the value of result is logged to the console.

Case Definitions

Cases are defined as key-value pairs in the casesObj object.

  • Single Case: { caseKey: action }
  • Multiple Cases: { 'case1, case2, case3': action }
  • Default Case: { '': action }

Actions can be any value or a function that returns a value. If the action is a function, and the options object has returnFn set to false, it is called, and the returned value is returned.

If no cases match the evaluated key, the rswitch function checks for a default case. If a default case is defined, its corresponding action is performed. If no default case is defined or its action is not provided, undefined is returned.

In case you want support my work

"Buy Me A Coffee"

0.7.0-beta

3 months ago

0.7.0

3 months ago

0.5.0-beta

8 months ago

0.4.0

8 months ago

0.4.1-beta

8 months ago

0.4.0-beta

8 months ago

0.3.0

8 months ago

0.2.0

8 months ago

0.1.0

10 months ago