suicchi
Better and cleaner switch case made for everyone
Installation
You can start by installing this library using the command below:
npm i --save suicchi
Run Test
npm run coverage
Basic Usage
import { Suicchi } from "suicchi";
const switchCase = new Suicchi();
switchCase.addCase("car", "Ford GT");
switchCase.addCase("name", "Rye");
switchCase.addCase("gender", "female");
const name = switchCase.evaluate("name");
console.log(name);
Adding a default case
import { Suicchi } from "suicchi";
const defaultCase = "no-record";
const switchCase = new Suicchi(defaultCase);
switchCase.addCase("car", "Ford GT");
switchCase.addCase("name", "Rye");
switchCase.addCase("gender", "female");
const age = switchCase.evaluate("age");
console.log(age);
Multiple keys
import { Suicchi } from "suicchi";
const switchCase = new Suicchi();
switchCase.addCase(["car", "transportation"], "Ford GT");
switchCase.addCase("name", "Rye");
switchCase.addCase("gender", "female");
const car = switchCase.evaluate("car");
console.log(car);
API
Constructor
The Suicchi Object constructor only takes in 1 optional parameter which can either a value, a function, or an object. And it generates the case depending on the type of parameter you pass in.
If you only pass in a value or a function, like the following:
const Switch = new Suicchi(() => {
return 1 + 1;
});
const aSwitch = new Suicchi(() => ('aValue'));
const bSwitch = new Suicchi('anotherValue');
You'll be doing something equivalent to:
switch(x) {
default:
return 1 + 1;
}
switch(x) {
default:
return 'aValue';
}
switch(x) {
default:
return 'anotherValue';
}
But if you pass in an Object, you'll be able to pass in other cases and routines besides the default case and routine, like so: (Note: if you pass in an object - the 'default' property will be required)
const cSwitch = new Suicchi({
default: null;
case1: "What";
case2: () => (1234)
})
You'll be doing something similar to:
switch(x) {
case 'case1':
return 'What';
case 'case2':
return 1234;
default:
return null;
}
AddCase
The AddCase method allows you to add new or overwrite existing cases. It takes in 2 parameters - the case and the routine.
The case can be of the following types: string, string[], or object;
if the case is an object, then the 2nd parameter, the routine, is no longer required as it should be paired into the key-value case object.
Example of use:
const x = new Suicchi();
x.addCase("aValue", "anotherValue");
switch(X) {
case "aValue":
return "anotherValue";
default:
return null;
}
x.addCase(["val1", "val2"], "anotherValue");
switch(X) {
case "val1":
case "val2":
return "anotherValue";
default:
return null;
}
x.addCase({
condition1: "12345",
condition2: 12345,
});
switch(X) {
case "condition1":
return "12345";
case "condition2":
return 12345;
default:
return null;
}
GetCases
The GetCases method will return a string array containing the existing cases that you've set for the Suicchi instance.
const x = new Suicchi({
default: null;
case1: "What";
case2: () => (1234)
})
x.getCases();
EvaluateCase (a.k.a Evaluate)
The EvaluateCase (or Evaluate, as it's still supported atm) method lets you run a specific case by passing in the case as a parameter.
if the provided parameter is does not match any of the cases, it will run the default routine.
Also, the case parameter is case-sensitive.
const x = new Suicchi({
default: "Awesome",
Rye: "Gay",
rye: "Gay",
rYe: "Gay",
ryE: "Gay"
});
x.EvaluateCase("Ray");
x.EvaluateCase("Jacob");
x.EvaluateCase("Rye");
x.EvaluateCase("rye");
x.EvaluateCase("rYe");
x.EvaluateCase("ryE");
Forking the repo
- Fork it https://github.com/yakovmeister/suicchi/fork
- Create your feature branch (git checkout -b feature/fooBar)
- Commit your changes (git commit -am 'Add some fooBar')
- Push to the branch (git push origin feature/fooBar)
- Create a new Pull Request