npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

fincalc

v1.3.2

Published

Helper to perform proper basic arithmetic operations with monetary values in JavaScript, or else two decimal precision arithmetic in a floating point scenario

Downloads

27

Readme

Fincalc

Travis Coveralls npm David

Introduction

Fincalc is a helper to perform proper basic arithmetic operations with monetary values in JavaScript, or else two decimal precision arithmetic in a floating point scenario. It also offers a utility to calculate the percentual variation between two values. It can be imported as a browser script on the front-end, or as an npm module on the back-end.

Install

Back-end

npm install fincalc

(add "--save" if you want the module to be automatically added to your project's "package.json" dependencies)

var fin = require(fincalc)

Front-end

bower install fincalc

(add "--save" if you want the module to be automatically added to your project's "bower.json" dependencies)

<script src="bower_components/fincalc/fincalc.js"></script>

(keep in mind this script will define an object "fin" that contains the methods described below, and might conflict if your scope contains another variable with the same name, or an object named "module" with a truthy "exports" key).

Why

The problem

Fincalc is made to fix a simple problem with JavaScript floating point operations.

Try this in your JavaScript console:

0.1 + 0.2 returns 0.30000000000000004

2.18 * 100 returns 218.00000000000003

The solution

fin(0.1 + 0.2) returns 0.3

fin(2.18 * 100) returns 218

API

Fincalc methods accept numbers (or string representation of them) as input, and return a single number rounded up to two decimal precision (i.e. to the money cent).

Rounding

fin(x)

Where x can be a number or an arithmetic operation:

fin(893.15784) // -> 893.16
fin(148.4528 + 9285.8864) // -> 9434.34
fin(2.18 * 200) // -> 436
fin(100 / 3) // -> 33.33

Calculate percentual variation

fin.pervar(x, y)

Returns the percentual variation between two values.

fin.pervar(456.12, 487.35) // -> 6.85
fin.pervar(23, 21) // -> -8.7

MIT License