Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kevinongko/vue-numeric
Input field component to display a formatted currency value based on Vue.js
https://github.com/kevinongko/vue-numeric
currency currency-prefix input maskedinput money numeric separator-symbol vue vue-numeric vue2
Last synced: 6 days ago
JSON representation
Input field component to display a formatted currency value based on Vue.js
- Host: GitHub
- URL: https://github.com/kevinongko/vue-numeric
- Owner: kevinongko
- License: mit
- Created: 2016-12-07T06:12:55.000Z (about 8 years ago)
- Default Branch: master
- Last Pushed: 2023-06-11T08:21:17.000Z (over 1 year ago)
- Last Synced: 2024-10-29T17:14:06.591Z (3 months ago)
- Topics: currency, currency-prefix, input, maskedinput, money, numeric, separator-symbol, vue, vue-numeric, vue2
- Language: JavaScript
- Homepage: https://kevinongko.github.io/vue-numeric/
- Size: 1.82 MB
- Stars: 461
- Watchers: 14
- Forks: 118
- Open Issues: 23
-
Metadata Files:
- Readme: README.md
- Contributing: .github/CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
# vue-numeric
[![npm](https://img.shields.io/npm/v/vue-numeric.svg?style=flat-square)](https://www.npmjs.com/package/vue-numeric)
[![npm](https://img.shields.io/npm/dt/vue-numeric.svg?style=flat-square)](https://www.npmjs.com/package/vue-numeric)
[![npm](https://img.shields.io/npm/dm/vue-numeric.svg?style=flat-square)](https://www.npmjs.com/package/vue-numeric)
[![Node.js CI](https://github.com/kevinongko/vue-numeric/actions/workflows/node.js.yml/badge.svg)](https://github.com/kevinongko/vue-numeric/actions/workflows/node.js.yml)
[![Codecov](https://img.shields.io/codecov/c/github/kevinongko/vue-numeric.svg?style=flat-square)](https://codecov.io/gh/kevinongko/vue-numeric)
[![npm](https://img.shields.io/npm/l/vue-numeric.svg?style=flat-square)](http://opensource.org/licenses/MIT)Input field component to display a formatted currency value based on [Vue](https://vuejs.org/).
[Live Demo](https://kevinongko.github.io/vue-numeric/)
**Works with Vue 2.***
## Installation
### Install via CDN
```htmlVue.use(VueNumeric.default)
```
### Install via NPM
```sh
$ npm install vue-numeric --save
```#### Register as Component
```js
import Vue from 'vue'
import VueNumeric from 'vue-numeric'export default {
name: 'App',components: {
VueNumeric
}
}
```#### Register as Plugin
```js
import Vue from 'vue'
import VueNumeric from 'vue-numeric'Vue.use(VueNumeric)
```## Usage
![screen shot 2016-12-08 at 2 19 31 pm](https://cloud.githubusercontent.com/assets/15880638/21001265/f2322438-bd51-11e6-8985-f31a45702484.png)
### Quick example
```vue
import VueNumeric from 'vue-numeric'
export default {
name: 'App',components: {
VueNumeric
},data: () => ({
price: ''
}),
}```
### Currency symbol
Set the `currency` prop to add a currency symbol within the input.
```vue
```
### Minimum & maximum constraint
Limit the minimum and maximum value by using `min` and `max` props.
- `min` defaults to `0`.
- `min` and `max` accept `String` or `Number` values.```vue
```
### Disable/enable negative values
`minus` defaults to `false` (no negative numbers).
```vue
```
### Enable decimal precision
By default the decimal value is disabled. To use decimals in the value, add the `precision` prop.
- `precision` accept a `String` or `Number` numeric value.```vue
```
### Thousands separator
- Default thousand separator's symbol is `,`.
- Use the `separator` prop to change the thousands separator.
- `separator` only accepts `space`, `,` or `.`.
- When using the `.` or `space` as thousand separator, the decimal separator will be `,`.```vue
```
### Input placeholder when empty
```vue```
### Value when empty
By default, when you clean the input the value is set to `0`. You can change this value to fit your needs.
```vue```
### Output Type
By default the value emitted for the input event is of type `Number`. However you may choose to get a `String` instead
by setting the property `output-type` to `String`.
```vue```
## Props
|Props|Description|Required|Type|Default|
|-----|-----------|--------|----|-------|
|currency|Currency prefix|false|String|-|
|currency-symbol-position|Position of the symbol (accepted values: `prefix` or `suffix`)|false|String|`prefix`|
|max|Maximum value allowed|false|Number|9007199254740991|
|min|Minimum value allowed|false|Number|-9007199254740991|
|minus|Enable/disable negative values|false|Boolean|`false`|
|placeholder|Input placeholder|false|String|-|
|empty-value|Value when input is empty|false|Number|0|
|output-type|Output Type for input event|false|String|`Number`|
|precision|Number of decimals|false|Number|-|
|separator|Thousand separator symbol (accepts `space`, `.` or `,`)|false|String|`,`|
|decimal-separator|Custom decimal separator|false|String|-|
|thousand-separator|Custom thousand separator|false|String|-|
|read-only|Hide input field and show the value as text|false|Boolean|false|
|read-only-class|Class for read-only element|false|String|''|
|allow-clear|Use input type search|false|Boolean|false|## License
Vue-Numeric is open-sourced software licensed under the [MIT license](http://opensource.org/licenses/MIT)
## Support
Hello, I'm Kevin the maintainer of this project in my free time (which is getting lessen these days), if this project does help you in any way please consider to support me. Thanks :smiley:
- [One-time donation via Paypal](https://www.paypal.me/kevinongko)