Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dalikewara/vcmcemtex
Universal & customable cemtex generator for batch transactions
https://github.com/dalikewara/vcmcemtex
banks cemtex helper javascript tool toolkit vascomm
Last synced: 17 days ago
JSON representation
Universal & customable cemtex generator for batch transactions
- Host: GitHub
- URL: https://github.com/dalikewara/vcmcemtex
- Owner: dalikewara
- License: mit
- Created: 2019-02-10T17:29:35.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2022-08-29T17:58:09.000Z (over 2 years ago)
- Last Synced: 2024-12-05T21:17:33.549Z (about 1 month ago)
- Topics: banks, cemtex, helper, javascript, tool, toolkit, vascomm
- Language: JavaScript
- Homepage:
- Size: 17.6 KB
- Stars: 2
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
[![npm package](https://nodei.co/npm/vcmcemtex.png?downloads=true&downloadRank=true&stars=true)](https://nodei.co/npm/vcmcemtex/)
[![version](https://img.shields.io/npm/v/vcmcemtex.svg?style=flat)](https://img.shields.io/npm/v/vcmcemtex.svg?style=flat)
[![build](https://img.shields.io/circleci/project/github/dalikewara/vcmcemtex.svg?style=flat)](https://img.shields.io/circleci/project/github/dalikewara/vcmcemtex.svg?style=flat)
[![language](https://img.shields.io/github/languages/top/dalikewara/vcmcemtex.svg?style=flat)](https://img.shields.io/github/languages/top/dalikewara/vcmcemtex.svg?style=flat)
[![download](https://img.shields.io/npm/dt/vcmcemtex.svg?style=flat)](https://img.shields.io/npm/dt/vcmcemtex.svg?style=flat)
[![dependents](https://img.shields.io/librariesio/dependents/npm/vcmcemtex.svg?style=flat)](https://img.shields.io/librariesio/dependents/npm/vcmcemtex.svg?style=flat)
[![issue](https://img.shields.io/github/issues/dalikewara/vcmcemtex.svg?style=flat)](https://img.shields.io/github/issues/dalikewara/vcmcemtex.svg?style=flat)
[![last_commit](https://img.shields.io/github/last-commit/dalikewara/vcmcemtex.svg?style=flat)](https://img.shields.io/github/last-commit/dalikewara/vcmcemtex.svg?style=flat)
[![license](https://img.shields.io/npm/l/vcmcemtex.svg?style=flat)](https://img.shields.io/npm/l/vcmcemtex.svg?style=flat)# An universal & customable cemtext generator for batch transactions
`Cemtext` file format is a format used by banks to allow for batch transactions. Some bank have adopted this format by default, but each others can have a different format style. This module allows you to create a cemtext format by your own style—that means you can use it to meet your bank cemtext requirements. This module is fast, easy to understand, and more humanable.### Installation
NPM```console
npm install vcmcemtex --save
```Browser
```js
// Bower
bower install vcmcemtex --save
```### Initialization
NPM```js
const vcmcemtex = require('vcmcemtex');
```Browser
```js
// Bower```
# Quickstart
```js
vcmcemtex(params, options[optional]).then(cemtex => {
console.log(cemtex);
});
```- Arguments
- *object* **params**
- *object* **header** [optional]
- *object* **detail** [optional]
- *object* **keys**
- *array* **data**
- *object* **footer** [optional]
- *object* **options** [optional]
- *string* **charlen** [optional]
- *default* 160
- *boolean* **enter** [optional]
- *default* false
- If *true* will add `\n` (enter) at every end of string.- Attributes
- *string* **type**
- *lps* | *lpz* | *rps* | *rpz*
- *default* rps
- LPS (*Left Padding Space*)
- LPZ (*Left Padding Zero*)
- RPS (*Right Padding Space*)
- RPZ (*Right Padding Zero*)
- *number* **length**
- *string|integer* **value**
- *default* ''
- *string|integer* **default**
- *default* ''
- The default value to be used if there is no given value.
- *string* **countFromDetail**
- Use this if you want to count a number value from a key in params `detail`. You can see the usage on examples bellow.
- Only works on `header` and `footer`.
- *boolean* **countAllData**
- *default* false
- This will count all data in params `detail` and made it as a value.
- Only works on `header` and `footer`.
- *boolean* **removeDot**
- *default* false
- This will remove all dots.
- *boolean* **removeSpace**
- *default* false
- This will remove all spaces.
- *boolean* **decimal**
- *default* true
- This will convert float or decimal format to number.Each successful generated row in a cemtext has length that equal to `charlen`—default is 160 characters. So it is 160 header length, 160 detail length (per 1 row), and 160 footer length. Example:
```js
// string | length 4
'char'
// string | length 8
'username'// and the cemtext output will be like this (in single string/one row):
'charusername '
```You can change default `charlen` value by passing an options in second argument.
A simple cemtext format can be done like this:
```js
vcmcemtex({
header: {
header1: { type: 'lps', length: 10, value: 'header' }
},
detail: {
keys: {
detail1: { type: 'lps', length: 10 }
},
data: [
{
detail1: 'detail'
}
]
},
footer: {
footer1: { type: 'lps', length: 10, value: 'footer' }
}
}).then(cemtex => {
console.log(cemtex);
});// output
// ' header detail footer '
````params` object has 3 main keys; `header`, `detail`, and `footer`. You don't have to use them (optional), but it's always good to use them for best practice style.
If you prefer to use key `detail`, the key must have key `keys` and `data`. `keys` is an object, and the `data` must be an array object. The object keys between `keys` and `data` should be same, for example if `keys` has a key called `detail1`, then key `data` should contains a key called `detail1`—similliar to attribute `value` in `header` and `footer`.
You can see other examples bellow:
```js
var data = [
{
name: 'John Doe',
username: 'johndoe',
email: '[email protected]',
accountNumber: '123456789',
testAmount: '12500'
},
{
name: 'John Smith',
username: 'johnsmith',
email: '[email protected]',
accountNumber: '123456789',
testAmount: '12500'
},
{
name: 'John Adam',
}
];vcmcemtex({
header: {
record: { type: 'lps', length: 1, value: '1' },
branch: { type: 'lpz', value: '1234' },
name: { type: 'rps', value: 'HEADER NAME' },
date: { type: 'lpz', value: '20190211' },
test1: { type: 'rps', value: 'test1' },
test2: { type: 'rps', value: 'test2' }
},
detail: {
keys: {
name: { type: 'rps', length: 10, default: '' },
username: { type: 'rps', length: 10, default: '' },
email: { type: 'rps', length: 20, default: '' },
accountNumber: { type: 'lpz', length: 10, default: '' },
testAmount: { type: 'lpz', length: 10, default: '' }
},
data: data
},
footer: {
record: { type: 'lpz', length: 1, value: '3' },
totalData: { type: 'lpz', length: 11, countAllData: true },
totalAmount: { type: 'lpz', length: 11, countFromDetail: 'testAmount' }
}
}, {
charlen: 200
}).then(cemtex => {
console.log(cemtex);
});// output
// '11234HEADER NAME20190211test1test2 John Doe johndoe [email protected] 01234567890000012500 John Smithjohnsmith [email protected] 01234567890000012500 John Adam 00000000000000000000 30000000000300000025000 '
```Using an option `enter`:
```js
vcmcemtex({
header: {
testHeader: { type: 'lps', length: 1, value: '1' },
branch: { type: 'lpz', value: '1234' },
name: { type: 'rps', value: 'HEADER NAME' },
date: { type: 'rpz', value: '20190211' },
test1: { type: 'rps', value: 'test1' },
test2: { type: 'rps', value: 'test2' }
},
footer: {
thisIsFooter: { type: 'lps', length: 1, value: '3' },
footer1: { type: 'lpz', value: '1000000' },
footer2: { type: 'rps', value: '2000000' }
}
}, {
enter: true
}).then(cemtex => {
console.log(cemtex);
});// output
// 11234HEADER NAME20190211test1test2
// 310000002000000
```# Release
### Changelog
See [https://github.com/dalikewara/vcmcemtex/blob/master/CHANGELOG.md](https://github.com/dalikewara/vcmcemtex/blob/master/CHANGELOG.md).### Credits
Copyright © 2019 [Dali Kewara](https://www.dalikewara.com).### License
[MIT License](https://github.com/dalikewara/vcmcemtex/blob/master/LICENSE)