@nexim/financial-calculate 1.0.0-alpha.2 → 1.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +8 -0
- package/README.md +2 -25
- package/dist/main.cjs +2 -3
- package/dist/main.cjs.map +2 -2
- package/dist/main.d.ts +8 -10
- package/dist/main.d.ts.map +1 -1
- package/dist/main.mjs +2 -3
- package/dist/main.mjs.map +2 -2
- package/dist/main.test.d.ts +2 -0
- package/dist/main.test.d.ts.map +1 -0
- package/docs/README.md +10 -0
- package/docs/functions/calculateDiscountAmount.md +25 -0
- package/docs/functions/calculateDiscountedPrice.md +25 -0
- package/docs/functions/calculatePercentageDiscount.md +26 -0
- package/docs/functions/calculatePercentageProfit.md +26 -0
- package/package.json +18 -11
- package/src/main.test.js +1 -2
- package/dist/main.cjs.LEGAL.txt +0 -0
- package/dist/main.mjs.LEGAL.txt +0 -0
package/CHANGELOG.md
CHANGED
|
@@ -3,6 +3,14 @@
|
|
|
3
3
|
All notable changes to this project will be documented in this file.
|
|
4
4
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
|
5
5
|
|
|
6
|
+
## [1.0.1](https://github.com/the-nexim/nanolib/compare/@nexim/financial-calculate@1.0.0...@nexim/financial-calculate@1.0.1) (2025-04-21)
|
|
7
|
+
|
|
8
|
+
**Note:** Version bump only for package @nexim/financial-calculate
|
|
9
|
+
|
|
10
|
+
## [1.0.0](https://github.com/the-nexim/nanolib/compare/@nexim/financial-calculate@1.0.0-alpha.2...@nexim/financial-calculate@1.0.0) (2025-04-20)
|
|
11
|
+
|
|
12
|
+
**Note:** Version bump only for package @nexim/financial-calculate
|
|
13
|
+
|
|
6
14
|
## [1.0.0-alpha.2](https://github.com/the-nexim/nanolib/compare/@nexim/financial-calculate@1.0.0-alpha.1...@nexim/financial-calculate@1.0.0-alpha.2) (2025-01-11)
|
|
7
15
|
|
|
8
16
|
### Features
|
package/README.md
CHANGED
|
@@ -19,29 +19,6 @@ npm install @nexim/financial-calculate
|
|
|
19
19
|
yarn add @nexim/financial-calculate
|
|
20
20
|
```
|
|
21
21
|
|
|
22
|
-
##
|
|
22
|
+
## Documentation
|
|
23
23
|
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
Calculate the price after applying a discount.
|
|
27
|
-
|
|
28
|
-
```ts
|
|
29
|
-
calculateDiscountedPrice(100, 10, 1); // returns 90.0
|
|
30
|
-
```
|
|
31
|
-
|
|
32
|
-
### calculateDiscountAmount
|
|
33
|
-
|
|
34
|
-
Calculate the discount amount from the original price.
|
|
35
|
-
|
|
36
|
-
```ts
|
|
37
|
-
calculateDiscountAmount(100, 10, 1); // returns 10.0
|
|
38
|
-
```
|
|
39
|
-
|
|
40
|
-
### calculateDiscountPercentage
|
|
41
|
-
|
|
42
|
-
Calculates the discount percentage between the market price and the sale price.
|
|
43
|
-
|
|
44
|
-
```ts
|
|
45
|
-
calculateDiscountPercentage(100, 80); // Returns 20.00
|
|
46
|
-
calculateDiscountPercentage(100, 80, 1, false); // Returns 25.0
|
|
47
|
-
```
|
|
24
|
+
Read full documentation [here](./docs/README.md).
|
package/dist/main.cjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/* @nexim/financial-calculate v1.0.
|
|
1
|
+
/* @nexim/financial-calculate v1.0.1 */
|
|
2
2
|
"use strict";
|
|
3
3
|
var __defProp = Object.defineProperty;
|
|
4
4
|
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
@@ -29,7 +29,7 @@ __export(main_exports, {
|
|
|
29
29
|
module.exports = __toCommonJS(main_exports);
|
|
30
30
|
var import_logger = require("@alwatr/logger");
|
|
31
31
|
var import_package_tracer = require("@alwatr/package-tracer");
|
|
32
|
-
__dev_mode__: import_package_tracer.packageTracer.add("@nexim/financial-calculate", "1.0.
|
|
32
|
+
__dev_mode__: import_package_tracer.packageTracer.add("@nexim/financial-calculate", "1.0.1");
|
|
33
33
|
var logger = (0, import_logger.createLogger)("@nexim/financial-calculate");
|
|
34
34
|
function calculateDiscountedPrice(price, discount, decimal = 2) {
|
|
35
35
|
logger.logMethodArgs?.("calculateDiscountedPrice", { price, discount, decimal });
|
|
@@ -51,5 +51,4 @@ function calculatePercentageDiscount(marketPrice, salePrice, decimal = 2) {
|
|
|
51
51
|
const percentage = (marketPrice - salePrice) / marketPrice * 100;
|
|
52
52
|
return parseFloat(percentage.toFixed(decimal));
|
|
53
53
|
}
|
|
54
|
-
/*! For license information please see main.cjs.LEGAL.txt */
|
|
55
54
|
//# sourceMappingURL=main.cjs.map
|
package/dist/main.cjs.map
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../src/main.ts"],
|
|
4
|
-
"sourcesContent": ["import {createLogger} from '@alwatr/logger';\nimport {packageTracer} from '@alwatr/package-tracer';\n\n__dev_mode__: packageTracer.add(__package_name__, __package_version__);\n\nconst logger = createLogger(__package_name__);\n\n/**\n * Calculate the price after applying a discount.\n *\n * @param price - The original price.\n * @param discount - The discount percentage to apply.\n * @param decimal - The number of decimal places to round to (default is 2).\n *\n * @example\n *
|
|
5
|
-
"mappings": ";;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,
|
|
4
|
+
"sourcesContent": ["import { createLogger } from '@alwatr/logger';\nimport { packageTracer } from '@alwatr/package-tracer';\n\n__dev_mode__: packageTracer.add(__package_name__, __package_version__);\n\nconst logger = createLogger(__package_name__);\n\n/**\n * Calculate the price after applying a discount.\n *\n * @param price - The original price.\n * @param discount - The discount percentage to apply.\n * @param decimal - The number of decimal places to round to (default is 2).\n *\n * @example\n * ```ts\n * calculateDiscountedPrice(100, 10, 1); // returns 90.0\n * ```\n */\nexport function calculateDiscountedPrice(price: number, discount: number, decimal = 2): number {\n logger.logMethodArgs?.('calculateDiscountedPrice', { price, discount, decimal });\n\n const discountedPrice = price * (1 - discount / 100);\n return parseFloat(discountedPrice.toFixed(decimal));\n}\n\n/**\n * Calculate the discount amount from the original price.\n *\n * @param price - The original price.\n * @param discount - The discount percentage.\n * @param decimal - The number of decimal places to round to (default is 2).\n *\n * @example\n * ```ts\n * calculateDiscountAmount(100, 10, 1); // returns 10.0\n * ```\n */\nexport function calculateDiscountAmount(price: number, discount: number, decimal = 2): number {\n logger.logMethodArgs?.('calculateDiscountAmount', { price, discount, decimal });\n\n const discountAmount = (price * discount) / 100;\n return parseFloat(discountAmount.toFixed(decimal));\n}\n\n/**\n * Calculates the discount percentage between the market price and the sale price for profit.\n *\n * @param marketPrice - The original market price of the item.\n * @param salePrice - The sale price of the item.\n * @param decimal - The number of decimal places to round the result to(optional with default value = 2).\n *\n * @example\n * ```ts\n * calculatePercentageProfit(100, 80); // Returns 20.00\n * calculatePercentageProfit(100, 80, 1, false); // Returns 25.0\n * ```\n */\nexport function calculatePercentageProfit(marketPrice: number, salePrice: number, decimal = 2): number {\n logger.logMethodArgs?.('calculatePercentageProfit', { marketPrice, salePrice, decimal });\n\n const percentage = ((marketPrice - salePrice) / salePrice) * 100;\n return parseFloat(percentage.toFixed(decimal));\n}\n\n/**\n * Calculates the discount percentage between the market price and the sale price for discount.\n *\n * @param marketPrice - The original market price of the item.\n * @param salePrice - The sale price of the item.\n * @param decimal - The number of decimal places to round the result to(optional with default value = 2).\n *\n * @example\n * ```ts\n * calculatePercentageDiscount(100, 80); // Returns 20.00\n * calculatePercentageDiscount(100, 80, 1, false); // Returns 25.0\n * ```\n */\nexport function calculatePercentageDiscount(marketPrice: number, salePrice: number, decimal = 2): number {\n logger.logMethodArgs?.('calculatePercentageDiscount', { marketPrice, salePrice, decimal });\n\n const percentage = ((marketPrice - salePrice) / marketPrice) * 100;\n return parseFloat(percentage.toFixed(decimal));\n}\n"],
|
|
5
|
+
"mappings": ";;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,oBAA6B;AAC7B,4BAA8B;AAE9B,aAAc,qCAAc,IAAI,8BAAkB,OAAmB;AAErE,IAAM,aAAS,4BAAa,4BAAgB;AAcrC,SAAS,yBAAyB,OAAe,UAAkB,UAAU,GAAW;AAC7F,SAAO,gBAAgB,4BAA4B,EAAE,OAAO,UAAU,QAAQ,CAAC;AAE/E,QAAM,kBAAkB,SAAS,IAAI,WAAW;AAChD,SAAO,WAAW,gBAAgB,QAAQ,OAAO,CAAC;AACpD;AAcO,SAAS,wBAAwB,OAAe,UAAkB,UAAU,GAAW;AAC5F,SAAO,gBAAgB,2BAA2B,EAAE,OAAO,UAAU,QAAQ,CAAC;AAE9E,QAAM,iBAAkB,QAAQ,WAAY;AAC5C,SAAO,WAAW,eAAe,QAAQ,OAAO,CAAC;AACnD;AAeO,SAAS,0BAA0B,aAAqB,WAAmB,UAAU,GAAW;AACrG,SAAO,gBAAgB,6BAA6B,EAAE,aAAa,WAAW,QAAQ,CAAC;AAEvF,QAAM,cAAe,cAAc,aAAa,YAAa;AAC7D,SAAO,WAAW,WAAW,QAAQ,OAAO,CAAC;AAC/C;AAeO,SAAS,4BAA4B,aAAqB,WAAmB,UAAU,GAAW;AACvG,SAAO,gBAAgB,+BAA+B,EAAE,aAAa,WAAW,QAAQ,CAAC;AAEzF,QAAM,cAAe,cAAc,aAAa,cAAe;AAC/D,SAAO,WAAW,WAAW,QAAQ,OAAO,CAAC;AAC/C;",
|
|
6
6
|
"names": []
|
|
7
7
|
}
|
package/dist/main.d.ts
CHANGED
|
@@ -6,7 +6,7 @@
|
|
|
6
6
|
* @param decimal - The number of decimal places to round to (default is 2).
|
|
7
7
|
*
|
|
8
8
|
* @example
|
|
9
|
-
* ```
|
|
9
|
+
* ```ts
|
|
10
10
|
* calculateDiscountedPrice(100, 10, 1); // returns 90.0
|
|
11
11
|
* ```
|
|
12
12
|
*/
|
|
@@ -19,7 +19,7 @@ export declare function calculateDiscountedPrice(price: number, discount: number
|
|
|
19
19
|
* @param decimal - The number of decimal places to round to (default is 2).
|
|
20
20
|
*
|
|
21
21
|
* @example
|
|
22
|
-
* ```
|
|
22
|
+
* ```ts
|
|
23
23
|
* calculateDiscountAmount(100, 10, 1); // returns 10.0
|
|
24
24
|
* ```
|
|
25
25
|
*/
|
|
@@ -30,12 +30,11 @@ export declare function calculateDiscountAmount(price: number, discount: number,
|
|
|
30
30
|
* @param marketPrice - The original market price of the item.
|
|
31
31
|
* @param salePrice - The sale price of the item.
|
|
32
32
|
* @param decimal - The number of decimal places to round the result to(optional with default value = 2).
|
|
33
|
-
* @param upSide - Determines the denominator for the percentage calculation (optional with default value = true).
|
|
34
33
|
*
|
|
35
34
|
* @example
|
|
36
|
-
* ```
|
|
37
|
-
*
|
|
38
|
-
*
|
|
35
|
+
* ```ts
|
|
36
|
+
* calculatePercentageProfit(100, 80); // Returns 20.00
|
|
37
|
+
* calculatePercentageProfit(100, 80, 1, false); // Returns 25.0
|
|
39
38
|
* ```
|
|
40
39
|
*/
|
|
41
40
|
export declare function calculatePercentageProfit(marketPrice: number, salePrice: number, decimal?: number): number;
|
|
@@ -45,12 +44,11 @@ export declare function calculatePercentageProfit(marketPrice: number, salePrice
|
|
|
45
44
|
* @param marketPrice - The original market price of the item.
|
|
46
45
|
* @param salePrice - The sale price of the item.
|
|
47
46
|
* @param decimal - The number of decimal places to round the result to(optional with default value = 2).
|
|
48
|
-
* @param upSide - Determines the denominator for the percentage calculation (optional with default value = true).
|
|
49
47
|
*
|
|
50
48
|
* @example
|
|
51
|
-
* ```
|
|
52
|
-
*
|
|
53
|
-
*
|
|
49
|
+
* ```ts
|
|
50
|
+
* calculatePercentageDiscount(100, 80); // Returns 20.00
|
|
51
|
+
* calculatePercentageDiscount(100, 80, 1, false); // Returns 25.0
|
|
54
52
|
* ```
|
|
55
53
|
*/
|
|
56
54
|
export declare function calculatePercentageDiscount(marketPrice: number, salePrice: number, decimal?: number): number;
|
package/dist/main.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"main.d.ts","sourceRoot":"","sources":["../src/main.ts"],"names":[],"mappings":"AAOA;;;;;;;;;;;GAWG;AACH,wBAAgB,wBAAwB,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,OAAO,SAAI,GAAG,MAAM,CAK7F;AAED;;;;;;;;;;;GAWG;AACH,wBAAgB,uBAAuB,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,OAAO,SAAI,GAAG,MAAM,CAK5F;AAED
|
|
1
|
+
{"version":3,"file":"main.d.ts","sourceRoot":"","sources":["../src/main.ts"],"names":[],"mappings":"AAOA;;;;;;;;;;;GAWG;AACH,wBAAgB,wBAAwB,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,OAAO,SAAI,GAAG,MAAM,CAK7F;AAED;;;;;;;;;;;GAWG;AACH,wBAAgB,uBAAuB,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,OAAO,SAAI,GAAG,MAAM,CAK5F;AAED;;;;;;;;;;;;GAYG;AACH,wBAAgB,yBAAyB,CAAC,WAAW,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,OAAO,SAAI,GAAG,MAAM,CAKrG;AAED;;;;;;;;;;;;GAYG;AACH,wBAAgB,2BAA2B,CAAC,WAAW,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,OAAO,SAAI,GAAG,MAAM,CAKvG"}
|
package/dist/main.mjs
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
/* @nexim/financial-calculate v1.0.
|
|
1
|
+
/* @nexim/financial-calculate v1.0.1 */
|
|
2
2
|
|
|
3
3
|
// src/main.ts
|
|
4
4
|
import { createLogger } from "@alwatr/logger";
|
|
5
5
|
import { packageTracer } from "@alwatr/package-tracer";
|
|
6
|
-
__dev_mode__: packageTracer.add("@nexim/financial-calculate", "1.0.
|
|
6
|
+
__dev_mode__: packageTracer.add("@nexim/financial-calculate", "1.0.1");
|
|
7
7
|
var logger = createLogger("@nexim/financial-calculate");
|
|
8
8
|
function calculateDiscountedPrice(price, discount, decimal = 2) {
|
|
9
9
|
logger.logMethodArgs?.("calculateDiscountedPrice", { price, discount, decimal });
|
|
@@ -31,5 +31,4 @@ export {
|
|
|
31
31
|
calculatePercentageDiscount,
|
|
32
32
|
calculatePercentageProfit
|
|
33
33
|
};
|
|
34
|
-
/*! For license information please see main.mjs.LEGAL.txt */
|
|
35
34
|
//# sourceMappingURL=main.mjs.map
|
package/dist/main.mjs.map
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../src/main.ts"],
|
|
4
|
-
"sourcesContent": ["import {createLogger} from '@alwatr/logger';\nimport {packageTracer} from '@alwatr/package-tracer';\n\n__dev_mode__: packageTracer.add(__package_name__, __package_version__);\n\nconst logger = createLogger(__package_name__);\n\n/**\n * Calculate the price after applying a discount.\n *\n * @param price - The original price.\n * @param discount - The discount percentage to apply.\n * @param decimal - The number of decimal places to round to (default is 2).\n *\n * @example\n *
|
|
5
|
-
"mappings": ";;;AAAA,
|
|
4
|
+
"sourcesContent": ["import { createLogger } from '@alwatr/logger';\nimport { packageTracer } from '@alwatr/package-tracer';\n\n__dev_mode__: packageTracer.add(__package_name__, __package_version__);\n\nconst logger = createLogger(__package_name__);\n\n/**\n * Calculate the price after applying a discount.\n *\n * @param price - The original price.\n * @param discount - The discount percentage to apply.\n * @param decimal - The number of decimal places to round to (default is 2).\n *\n * @example\n * ```ts\n * calculateDiscountedPrice(100, 10, 1); // returns 90.0\n * ```\n */\nexport function calculateDiscountedPrice(price: number, discount: number, decimal = 2): number {\n logger.logMethodArgs?.('calculateDiscountedPrice', { price, discount, decimal });\n\n const discountedPrice = price * (1 - discount / 100);\n return parseFloat(discountedPrice.toFixed(decimal));\n}\n\n/**\n * Calculate the discount amount from the original price.\n *\n * @param price - The original price.\n * @param discount - The discount percentage.\n * @param decimal - The number of decimal places to round to (default is 2).\n *\n * @example\n * ```ts\n * calculateDiscountAmount(100, 10, 1); // returns 10.0\n * ```\n */\nexport function calculateDiscountAmount(price: number, discount: number, decimal = 2): number {\n logger.logMethodArgs?.('calculateDiscountAmount', { price, discount, decimal });\n\n const discountAmount = (price * discount) / 100;\n return parseFloat(discountAmount.toFixed(decimal));\n}\n\n/**\n * Calculates the discount percentage between the market price and the sale price for profit.\n *\n * @param marketPrice - The original market price of the item.\n * @param salePrice - The sale price of the item.\n * @param decimal - The number of decimal places to round the result to(optional with default value = 2).\n *\n * @example\n * ```ts\n * calculatePercentageProfit(100, 80); // Returns 20.00\n * calculatePercentageProfit(100, 80, 1, false); // Returns 25.0\n * ```\n */\nexport function calculatePercentageProfit(marketPrice: number, salePrice: number, decimal = 2): number {\n logger.logMethodArgs?.('calculatePercentageProfit', { marketPrice, salePrice, decimal });\n\n const percentage = ((marketPrice - salePrice) / salePrice) * 100;\n return parseFloat(percentage.toFixed(decimal));\n}\n\n/**\n * Calculates the discount percentage between the market price and the sale price for discount.\n *\n * @param marketPrice - The original market price of the item.\n * @param salePrice - The sale price of the item.\n * @param decimal - The number of decimal places to round the result to(optional with default value = 2).\n *\n * @example\n * ```ts\n * calculatePercentageDiscount(100, 80); // Returns 20.00\n * calculatePercentageDiscount(100, 80, 1, false); // Returns 25.0\n * ```\n */\nexport function calculatePercentageDiscount(marketPrice: number, salePrice: number, decimal = 2): number {\n logger.logMethodArgs?.('calculatePercentageDiscount', { marketPrice, salePrice, decimal });\n\n const percentage = ((marketPrice - salePrice) / marketPrice) * 100;\n return parseFloat(percentage.toFixed(decimal));\n}\n"],
|
|
5
|
+
"mappings": ";;;AAAA,SAAS,oBAAoB;AAC7B,SAAS,qBAAqB;AAE9B,aAAc,eAAc,IAAI,8BAAkB,OAAmB;AAErE,IAAM,SAAS,aAAa,4BAAgB;AAcrC,SAAS,yBAAyB,OAAe,UAAkB,UAAU,GAAW;AAC7F,SAAO,gBAAgB,4BAA4B,EAAE,OAAO,UAAU,QAAQ,CAAC;AAE/E,QAAM,kBAAkB,SAAS,IAAI,WAAW;AAChD,SAAO,WAAW,gBAAgB,QAAQ,OAAO,CAAC;AACpD;AAcO,SAAS,wBAAwB,OAAe,UAAkB,UAAU,GAAW;AAC5F,SAAO,gBAAgB,2BAA2B,EAAE,OAAO,UAAU,QAAQ,CAAC;AAE9E,QAAM,iBAAkB,QAAQ,WAAY;AAC5C,SAAO,WAAW,eAAe,QAAQ,OAAO,CAAC;AACnD;AAeO,SAAS,0BAA0B,aAAqB,WAAmB,UAAU,GAAW;AACrG,SAAO,gBAAgB,6BAA6B,EAAE,aAAa,WAAW,QAAQ,CAAC;AAEvF,QAAM,cAAe,cAAc,aAAa,YAAa;AAC7D,SAAO,WAAW,WAAW,QAAQ,OAAO,CAAC;AAC/C;AAeO,SAAS,4BAA4B,aAAqB,WAAmB,UAAU,GAAW;AACvG,SAAO,gBAAgB,+BAA+B,EAAE,aAAa,WAAW,QAAQ,CAAC;AAEzF,QAAM,cAAe,cAAc,aAAa,cAAe;AAC/D,SAAO,WAAW,WAAW,QAAQ,OAAO,CAAC;AAC/C;",
|
|
6
6
|
"names": []
|
|
7
7
|
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"main.test.d.ts","sourceRoot":"","sources":["../src/main.test.js"],"names":[],"mappings":""}
|
package/docs/README.md
ADDED
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
# @nexim/financial-calculate
|
|
2
|
+
|
|
3
|
+
## Functions
|
|
4
|
+
|
|
5
|
+
| Function | Description |
|
|
6
|
+
| ----------------------------------------------------------------------- | -------------------------------------------------------------------------------------------- |
|
|
7
|
+
| [calculateDiscountAmount](functions/calculateDiscountAmount.md) | Calculate the discount amount from the original price. |
|
|
8
|
+
| [calculateDiscountedPrice](functions/calculateDiscountedPrice.md) | Calculate the price after applying a discount. |
|
|
9
|
+
| [calculatePercentageDiscount](functions/calculatePercentageDiscount.md) | Calculates the discount percentage between the market price and the sale price for discount. |
|
|
10
|
+
| [calculatePercentageProfit](functions/calculatePercentageProfit.md) | Calculates the discount percentage between the market price and the sale price for profit. |
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
[@nexim/financial-calculate](../README.md) / calculateDiscountAmount
|
|
2
|
+
|
|
3
|
+
# Function: calculateDiscountAmount()
|
|
4
|
+
|
|
5
|
+
> **calculateDiscountAmount**(`price`: `number`, `discount`: `number`, `decimal`: `number`): `number`
|
|
6
|
+
|
|
7
|
+
Calculate the discount amount from the original price.
|
|
8
|
+
|
|
9
|
+
## Parameters
|
|
10
|
+
|
|
11
|
+
| Parameter | Type | Default value | Description |
|
|
12
|
+
| ---------- | -------- | ------------- | -------------------------------------------------------- |
|
|
13
|
+
| `price` | `number` | `undefined` | The original price. |
|
|
14
|
+
| `discount` | `number` | `undefined` | The discount percentage. |
|
|
15
|
+
| `decimal` | `number` | `2` | The number of decimal places to round to (default is 2). |
|
|
16
|
+
|
|
17
|
+
## Returns
|
|
18
|
+
|
|
19
|
+
`number`
|
|
20
|
+
|
|
21
|
+
## Example
|
|
22
|
+
|
|
23
|
+
```ts
|
|
24
|
+
calculateDiscountAmount(100, 10, 1); // returns 10.0
|
|
25
|
+
```
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
[@nexim/financial-calculate](../README.md) / calculateDiscountedPrice
|
|
2
|
+
|
|
3
|
+
# Function: calculateDiscountedPrice()
|
|
4
|
+
|
|
5
|
+
> **calculateDiscountedPrice**(`price`: `number`, `discount`: `number`, `decimal`: `number`): `number`
|
|
6
|
+
|
|
7
|
+
Calculate the price after applying a discount.
|
|
8
|
+
|
|
9
|
+
## Parameters
|
|
10
|
+
|
|
11
|
+
| Parameter | Type | Default value | Description |
|
|
12
|
+
| ---------- | -------- | ------------- | -------------------------------------------------------- |
|
|
13
|
+
| `price` | `number` | `undefined` | The original price. |
|
|
14
|
+
| `discount` | `number` | `undefined` | The discount percentage to apply. |
|
|
15
|
+
| `decimal` | `number` | `2` | The number of decimal places to round to (default is 2). |
|
|
16
|
+
|
|
17
|
+
## Returns
|
|
18
|
+
|
|
19
|
+
`number`
|
|
20
|
+
|
|
21
|
+
## Example
|
|
22
|
+
|
|
23
|
+
```ts
|
|
24
|
+
calculateDiscountedPrice(100, 10, 1); // returns 90.0
|
|
25
|
+
```
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
[@nexim/financial-calculate](../README.md) / calculatePercentageDiscount
|
|
2
|
+
|
|
3
|
+
# Function: calculatePercentageDiscount()
|
|
4
|
+
|
|
5
|
+
> **calculatePercentageDiscount**(`marketPrice`: `number`, `salePrice`: `number`, `decimal`: `number`): `number`
|
|
6
|
+
|
|
7
|
+
Calculates the discount percentage between the market price and the sale price for discount.
|
|
8
|
+
|
|
9
|
+
## Parameters
|
|
10
|
+
|
|
11
|
+
| Parameter | Type | Default value | Description |
|
|
12
|
+
| ------------- | -------- | ------------- | ------------------------------------------------------------------------------------- |
|
|
13
|
+
| `marketPrice` | `number` | `undefined` | The original market price of the item. |
|
|
14
|
+
| `salePrice` | `number` | `undefined` | The sale price of the item. |
|
|
15
|
+
| `decimal` | `number` | `2` | The number of decimal places to round the result to(optional with default value = 2). |
|
|
16
|
+
|
|
17
|
+
## Returns
|
|
18
|
+
|
|
19
|
+
`number`
|
|
20
|
+
|
|
21
|
+
## Example
|
|
22
|
+
|
|
23
|
+
```ts
|
|
24
|
+
calculatePercentageDiscount(100, 80); // Returns 20.00
|
|
25
|
+
calculatePercentageDiscount(100, 80, 1, false); // Returns 25.0
|
|
26
|
+
```
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
[@nexim/financial-calculate](../README.md) / calculatePercentageProfit
|
|
2
|
+
|
|
3
|
+
# Function: calculatePercentageProfit()
|
|
4
|
+
|
|
5
|
+
> **calculatePercentageProfit**(`marketPrice`: `number`, `salePrice`: `number`, `decimal`: `number`): `number`
|
|
6
|
+
|
|
7
|
+
Calculates the discount percentage between the market price and the sale price for profit.
|
|
8
|
+
|
|
9
|
+
## Parameters
|
|
10
|
+
|
|
11
|
+
| Parameter | Type | Default value | Description |
|
|
12
|
+
| ------------- | -------- | ------------- | ------------------------------------------------------------------------------------- |
|
|
13
|
+
| `marketPrice` | `number` | `undefined` | The original market price of the item. |
|
|
14
|
+
| `salePrice` | `number` | `undefined` | The sale price of the item. |
|
|
15
|
+
| `decimal` | `number` | `2` | The number of decimal places to round the result to(optional with default value = 2). |
|
|
16
|
+
|
|
17
|
+
## Returns
|
|
18
|
+
|
|
19
|
+
`number`
|
|
20
|
+
|
|
21
|
+
## Example
|
|
22
|
+
|
|
23
|
+
```ts
|
|
24
|
+
calculatePercentageProfit(100, 80); // Returns 20.00
|
|
25
|
+
calculatePercentageProfit(100, 80, 1, false); // Returns 25.0
|
|
26
|
+
```
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@nexim/financial-calculate",
|
|
3
|
-
"version": "1.0.
|
|
3
|
+
"version": "1.0.1",
|
|
4
4
|
"description": "Provides a set of utils to handle common financial operations.",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"financial",
|
|
@@ -40,20 +40,24 @@
|
|
|
40
40
|
],
|
|
41
41
|
"scripts": {
|
|
42
42
|
"build": "wireit",
|
|
43
|
+
"doc": "wireit",
|
|
43
44
|
"test": "wireit",
|
|
44
45
|
"watch": "wireit"
|
|
45
46
|
},
|
|
46
47
|
"dependencies": {
|
|
47
|
-
"@alwatr/logger": "^5.
|
|
48
|
-
"@alwatr/package-tracer": "^5.
|
|
48
|
+
"@alwatr/logger": "^5.5.3",
|
|
49
|
+
"@alwatr/package-tracer": "^5.5.3"
|
|
49
50
|
},
|
|
50
51
|
"devDependencies": {
|
|
51
|
-
"@alwatr/nano-build": "^5.
|
|
52
|
-
"@alwatr/type-helper": "^5.
|
|
53
|
-
"@nexim/typescript-config": "^2.0.
|
|
52
|
+
"@alwatr/nano-build": "^5.5.3",
|
|
53
|
+
"@alwatr/type-helper": "^5.4.1",
|
|
54
|
+
"@nexim/typescript-config": "^2.0.1",
|
|
54
55
|
"ava": "^6.2.0",
|
|
55
|
-
"
|
|
56
|
-
"
|
|
56
|
+
"typedoc": "^0.28.3",
|
|
57
|
+
"typedoc-plugin-markdown": "^4.6.2",
|
|
58
|
+
"typedoc-plugin-no-inherit": "^1.6.1",
|
|
59
|
+
"typescript": "^5.8.3",
|
|
60
|
+
"wireit": "^0.14.12"
|
|
57
61
|
},
|
|
58
62
|
"publishConfig": {
|
|
59
63
|
"access": "public"
|
|
@@ -72,7 +76,7 @@
|
|
|
72
76
|
]
|
|
73
77
|
},
|
|
74
78
|
"build:es": {
|
|
75
|
-
"command": "nano-build --preset=module",
|
|
79
|
+
"command": "yarn nano-build --preset=module",
|
|
76
80
|
"files": [
|
|
77
81
|
"src",
|
|
78
82
|
"tsconfig.json"
|
|
@@ -98,9 +102,12 @@
|
|
|
98
102
|
]
|
|
99
103
|
},
|
|
100
104
|
"watch:es": {
|
|
101
|
-
"command": "nano-build --preset=module -- --watch",
|
|
105
|
+
"command": "yarn nano-build --preset=module -- --watch",
|
|
102
106
|
"service": true
|
|
107
|
+
},
|
|
108
|
+
"doc": {
|
|
109
|
+
"command": "typedoc"
|
|
103
110
|
}
|
|
104
111
|
},
|
|
105
|
-
"gitHead": "
|
|
112
|
+
"gitHead": "f20da89af20ee0c17c96e1ea15c6dfd831717ee6"
|
|
106
113
|
}
|
package/src/main.test.js
CHANGED
|
@@ -1,11 +1,10 @@
|
|
|
1
|
-
import test from 'ava';
|
|
2
|
-
|
|
3
1
|
import {
|
|
4
2
|
calculateDiscountAmount,
|
|
5
3
|
calculateDiscountedPrice,
|
|
6
4
|
calculatePercentageDiscount,
|
|
7
5
|
calculatePercentageProfit,
|
|
8
6
|
} from '@nexim/financial-calculate';
|
|
7
|
+
import test from 'ava';
|
|
9
8
|
|
|
10
9
|
test('calculate discount from price', (test) => {
|
|
11
10
|
test.is(calculateDiscountAmount(3, 4), 0.12);
|
package/dist/main.cjs.LEGAL.txt
DELETED
|
File without changes
|
package/dist/main.mjs.LEGAL.txt
DELETED
|
File without changes
|