Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nbfontana/ngx-currency
Currency mask module for Angular 📦
https://github.com/nbfontana/ngx-currency
angular angular2 aot chrome components currency directive firefox mask money
Last synced: 2 days ago
JSON representation
Currency mask module for Angular 📦
- Host: GitHub
- URL: https://github.com/nbfontana/ngx-currency
- Owner: nbfontana
- License: mit
- Created: 2017-09-29T16:36:43.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2025-01-06T20:03:50.000Z (12 days ago)
- Last Synced: 2025-01-09T22:08:21.304Z (9 days ago)
- Topics: angular, angular2, aot, chrome, components, currency, directive, firefox, mask, money
- Language: TypeScript
- Homepage: https://nbfontana.github.io/ngx-currency
- Size: 3.74 MB
- Stars: 239
- Watchers: 12
- Forks: 122
- Open Issues: 80
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.txt
Awesome Lists containing this project
- awesome-angular - ngx-currency - Currency mask module for Angular. (Table of contents / Third Party Components)
- fucking-awesome-angular - ngx-currency - Currency mask module for Angular. (Table of contents / Third Party Components)
README
# ngx-currency
[![npm version](https://badge.fury.io/js/ngx-currency.png)](http://badge.fury.io/js/ngx-currency)
[![GitHub issues](https://img.shields.io/github/issues/nbfontana/ngx-currency.png)](https://github.com/nbfontana/ngx-currency/issues)
[![GitHub stars](https://img.shields.io/github/stars/nbfontana/ngx-currency.png)](https://github.com/nbfontana/ngx-currency/stargazers)
[![GitHub license](https://img.shields.io/badge/license-MIT-blue.png)](https://raw.githubusercontent.com/nbfontana/ngx-currency/master/LICENSE)## Demo
https://nbfontana.github.io/ngx-currency/
## Table of contents
- [Getting Started](#getting-started)
- [Documentation](https://nbfontana.github.io/ngx-currency/docs/)
- [Development](#development)
- [License](#license)## Getting Started
### Installing and Importing
Install the package by command:
```sh
npm install ngx-currency --save
```Import the directive
```ts
import { NgxCurrencyDirective } from "ngx-currency";@Component({
selector: "app-root",
templateUrl: "./app.component.html",
imports: [NgxCurrencyDirective],
})
export class AppComponent {}
```### Using
```html
```
- `ngModel` An attribute of type number. If is displayed `'$ 25.63'`, the attribute will be `'25.63'`.
### Options
You can set options...
```html
```
Available options:
- `align` - Text alignment in input. (default: `right`)
- `allowNegative` - If `true` can input negative values. (default: `true`)
- `decimal` - Separator of decimals (default: `'.'`)
- `precision` - Number of decimal places (default: `2`)
- `prefix` - Money prefix (default: `'$ '`)
- `suffix` - Money suffix (default: `''`)
- `thousands` - Separator of thousands (default: `','`)
- `nullable` - when true, the value of the clean field will be `null`, when false the value will be `0`
- `min` - The minimum value (default: `undefined`)
- `max` - The maximum value (default: `undefined`)
- `inputMode` - Determines how to handle numbers as the user types them (default: `Financial`)Input Modes:
- `Financial` - Numbers start at the highest precision decimal. Typing a number shifts numbers left.
The decimal character is ignored. Most cash registers work this way. For example:
- Typing `'12'` results in `'0.12'`
- Typing `'1234'` results in `'12.34'`
- Typing `'1.234'` results in `'12.34'`
- `Natural` - Numbers start to the left of the decimal. Typing a number to the left of the decimal shifts
numbers left; typing to the right of the decimal replaces the next number. Most text inputs
and spreadsheets work this way. For example:
- Typing `'1234'` results in `'1234'`
- Typing `'1.234'` results in `'1.23'`
- Typing `'12.34'` results in `'12.34'`
- Typing `'123.4'` results in `'123.40'`You can also set options globally...
```ts
import { provideEnvironmentNgxCurrency, NgxCurrencyInputMode } from 'ngx-currency';bootstrapApplication(AppComponent, {
providers: [
...
provideEnvironmentNgxCurrency({
align: "right",
allowNegative: true,
allowZero: true,
decimal: ",",
precision: 2,
prefix: "R$ ",
suffix: "",
thousands: ".",
nullable: true,
min: null,
max: null,
inputMode: NgxCurrencyInputMode.Financial,
}),
...
],
}).catch((err) => console.error(err));
```## Development
### Prepare your environment
- Install [Node.js](http://nodejs.org/) and NPM
- Install local dev dependencies: `npm install` while current directory is this repo### Development server
To start a local development server, run:
```bash
npm start
```### Building
To build the library run:
```bash
npm run build:lib
```### Testing
To execute unit tests with the [Karma](https://karma-runner.github.io) test runner, use the following command:
```bash
npm test
```When running in the Chrome browser, you can set code breakpoints to debug tests using these instructions:
- From the main Karma browser page, click the `Debug` button to open the debug window
- Press `ctrl + shift + i` to open Chrome developer tools
- Press `ctrl + p` to search for a file to debug
- Enter a file name like `input.handler.ts` and click the file
- Within the file, click on a row number to set a breakpoint
- Refresh the browser window to re-run tests and stop on the breakpoint## License
MIT @ Neri Bez Fontana