@ulisesgascon/normalize-boolean
Opinionated boolean conversion
About
Simple and very opinionated wrapper to manage Boolean conversions
❤️ Awesome Features:
- Simple and easy to use 🔥
- Typescript support 💪
- Zero dependencies 🚀
- Easy to use and great test coverage ✅
Installation
npm install @ulisesgascon/normalize-boolean
Usage
Simple example
Importation
const { normalizeBoolean } = require("@ulisesgascon/normalize-boolean");
import { normalizeBoolean } from "@ulisesgascon/normalize-boolean";
usage
// True and false alias
console.log(normalizeBoolean("true")); // true
console.log(normalizeBoolean("on")); // true
console.log(normalizeBoolean("yes")); // true
console.log(normalizeBoolean("y")); // true
console.log(normalizeBoolean("false")); // false
console.log(normalizeBoolean("off")); // false
console.log(normalizeBoolean("no")); // false
console.log(normalizeBoolean("n")); // false
// Numbers as string
console.log(normalizeBoolean("1")); // true
console.log(normalizeBoolean("1.0")); // true
console.log(normalizeBoolean("1,0")); // true
console.log(normalizeBoolean("0")); // false
console.log(normalizeBoolean("0.0")); // false
console.log(normalizeBoolean("0,0")); // false
// Numbers
console.log(normalizeBoolean(1)); // true
console.log(normalizeBoolean(-1)); // false
console.log(normalizeBoolean(0)); // false
console.log(normalizeBoolean(-123)); // false
console.log(normalizeBoolean(123)); // false
// Non-trimmed or capitalized
console.log(normalizeBoolean(" OFF")); // false
console.log(normalizeBoolean(" ON ")); // true
// Non-primary types
console.log(normalizeBoolean(() => {})); // false
console.log(normalizeBoolean({ hello: "world" })); // false
console.log(normalizeBoolean([1, 2, 3])); // false
// Classic Non-values
console.log(normalizeBoolean(null)); // false
console.log(normalizeBoolean(undefined)); // false
console.log(normalizeBoolean("")); // false
console.log(normalizeBoolean(NaN)); // false
Contributing
Please read CONTRIBUTING.md for details on our code of conduct, and the process for submitting pull requests to us.
Versioning
We use SemVer for versioning. For the versions available, see the tags on this repository.
Authors
- Ulises Gascón - Initial work- - @ulisesGascon
See also the list of contributors who participated in this project.
License
This project is licensed under the MIT License - see the LICENSE.md file for details
Acknowledgments
- This project is under development, but you can help us to improve it! We ❤️ FOSS!