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: 30 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 (about 7 years ago)
- Default Branch: master
- Last Pushed: 2024-06-13T20:56:24.000Z (5 months ago)
- Last Synced: 2024-09-28T17:04:23.321Z (about 1 month ago)
- Topics: angular, angular2, aot, chrome, components, currency, directive, firefox, mask, money
- Language: TypeScript
- Homepage: https://nbfontana.github.io/ngx-currency
- Size: 3.45 MB
- Stars: 236
- Watchers: 12
- Forks: 123
- 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
[![Build Status](https://travis-ci.org/nbfontana/ngx-currency.svg?branch=master)](https://travis-ci.org/nbfontana/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
- [About](#about)
- [Installation](#installation)
- [Documentation](https://nbfontana.github.io/ngx-currency/docs/)
- [Development](#development)
- [License](#license)## About
## 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({
standalone: true,
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
Run `npm start` to start a development server.
### Testing
- Run `npm test` to run tests
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