vue-cleave-component
Version:
Vue.js component for cleave.js
142 lines (107 loc) • 4.61 kB
Markdown
# Vue Cleave Component
[](https://npm-stat.com/charts.html?package=vue-cleave-component&from=2018-01-01)
[](https://www.npmjs.com/package/vue-cleave-component)
[](https://github.com/ankurk91/vue-cleave-component/)
[](https://yarnpkg.com/en/package/vue-cleave-component)
[](https://github.com/ankurk91/vue-cleave-component/actions)
[](https://codecov.io/gh/ankurk91/vue-cleave-component)
Vue.js component for [Cleave.js](http://nosir.github.io/cleave.js/)
## Demo on [JSFiddle](https://jsfiddle.net/ankurk91/aza302c7/)
### Version matrix
| Vue.js version | Package version | Branch |
| :--- | :---: | ---: |
| 2.x | 2.x | [2.x](https://github.com/ankurk91/vue-cleave-component/tree/v2.x) |
| 3.x | 3.x | master |
## Features
* Reactive `v-model` value
- You can change input value programmatically
* Reactive [options](https://github.com/nosir/cleave.js/blob/master/doc/options.md)
- You can change config options dynamically
- Component will watch for any changes and redraw itself
* Compatible with [Bootstrap](http://getbootstrap.com/), [Bulma](http://bulma.io/) or any other CSS framework
* Works with validation libraries
* Option to disable `raw` mode to get masked value
## Installation
```bash
npm install vue-cleave-component --save
```
## Usage
```html
<template>
<div>
<cleave v-model="cardNumber"
:options="options"
class="form-control"
name="card"/>
</div>
</template>
<script>
import Cleave from 'vue-cleave-component';
export default {
data() {
return {
cardNumber: null,
options: {
creditCard: true,
delimiter: '-',
}
}
},
components: {
Cleave
}
}
</script>
```
### As plugin
```js
import {createApp} from 'vue';
import Cleave from 'vue-cleave-component';
// your app initilization logic goes here
const app = createApp({});
app.use(Cleave);
app.mount('#app');
```
This will register a global component `<cleave>`
## Available props
The component accepts these props:
| Attribute | Type | Default | Description |
| :--- | :---: | :---: | :--- |
| v-model | String / Number / `null` | `null` | Set or Get input value (required) |
| options | Object | `{}` | Cleave.js [options](https://github.com/nosir/cleave.js/blob/master/doc/options.md) |
| raw | Boolean | `true` | When set to `false`; emits formatted value with format pattern and delimiter |
## Install in non-module environments (without webpack)
* Include required files
```html
<!-- cleave.js -->
<script src="https://cdn.jsdelivr.net/npm/cleave.js@1"></script>
<!-- Vue.js -->
<script src="https://cdn.jsdelivr.net/npm/vue@3.2"></script>
<!-- Lastly add this package -->
<script src="https://cdn.jsdelivr.net/npm/vue-cleave-component@3"></script>
<script>
const app = Vue.createApp({});
app.use(VueCleave);
app.mount('#app');
</script>
```
## Run examples on your localhost
* Clone this repo
* Make sure you have node-js `>=18.9` and [pnpm](https://pnpm.io/) `>=7.x` pre-installed
* Install dependencies `pnpm install`
* Run webpack dev server `npm start`
* This should open the demo page in your default web browser
### Testing
* This package is using [Jest](https://github.com/facebook/jest)
and [vue-test-utils](https://github.com/vuejs/vue-test-utils-next) for testing.
* Tests can be found in `__test__` folder
* Execute tests with this command `npm test`
## Changelog
Please see [CHANGELOG](CHANGELOG.md) for more information what has changed recently.
## Alternatives
If you feel this component heavy, then you can consider these packages.
* [v-mask](https://github.com/probil/v-mask)
* [vue-input-facade](https://github.com/RonaldJerez/vue-input-facade)
* [maska](https://github.com/beholdr/maska)
## License
[MIT](LICENSE.txt) License