Nusantara Valid
Nusantara Valid is a data validator to validate any Indonesian specific civil data such as nik, nip, and many more.
Table of contents
What it can do?
- ATM Number (Nomor Rekening)
- Cellular Number / Mobile Number
- Credit Card Number
- E-Mail
- NIK (Nomor Induk Kependudukan)
- NIP (Nomor Induk Pegawai Negeri Sipil)
- NISN (Nomor Induk Siswa Nasional)
- NPWP (Nomor Pokok Wajib Pajak)
- TNKB (Tanda Nomor Kendaraan Bermotor)
- Telephon Number
- Zip Code
Getting started
There are some ways to import the package
The package includes multiple formats to support different build process.
- /cjs/nusantara-valid.js - CommonJS module.
- /esm/nusantara-valid.mjs - ES module.
- /umd/nusantara-valid.js - UMD module. Can be used in browser with
script
tag
Usage
CommonJS module way (require()
)
const NusantaraValid = require('nusantara-valid')
ES module way (import
)
import NusantaraValid from './node_modules/nusantara-valid/dist/esm/nusantara-valid.mjs'
Good-old-browser-way (<script></script>
)
Local
<script src="../dist/umd/nusantara-valid.min.js"></script>
CDN
<script src="https://cdn.jsdelivr.net/npm/nusantara-valid@0.2.0/dist/umd/nusantara-valid.min.js"></script>
API
ATM Number (Nomor Rekening)
isValidATMNumber(atm: string);
isValidATMNumber('87.800.000.00');
isValidATMNumberWithComparison(atm: string, bankKey: string);
isValidATMNumberWithComparison('1230005123000', 'MDRK');
Bank
getDataBank(bankKey: string);
getDataBank('BCAK');
getDataBanks();
Cellular Number (Nomor HP)
isValidCellularNumber(cel: string);
isValidCellularNumber('081212341234');
isValidCellularNumberWithComparison(cel: string, providerKey: string);
isValidCellularNumberWithComparison('081212341234', 'TELKOMSEL');
getDataCellularNumber(cel: string);
getDataCellularNumber('085612341234');
formatCellularNumber(cel: string, int:boolean = false)
formatCellularNumber('+6281812341234');
formatCellularNumber('085612341234', true);
Cellular Provider
getDataCellularProvider(key: string);
getDataCellularProvider('TELKOMSEL');
getDataCellularProviders();
Credit Card Number
isValidCCNumber(cc: string);
isValidCCNumber('4000123456789010');
isValidCCNumber('5000 1234 5678 9010');
formatCCNumber(cc: string);
formatCCNumber('4000123456789010');
formatCCNumber('5000 1234 5678 9010');
E-Mail
isValidEmail(email: string);
isValidEmail('myawesom-email@domain.tld');
Nomor Induk Kependudukan (NIK)
isValidNIK(nik: string);
isValidNIK('3101011212930001');
isValidNIKWithComparison(nik: string, comparison: { provinceKy?: string, birthday?: string });
isValidNIKWithComparison('3101011212930001', { provinceKey: 'JK', birthday: '1993-12-12' });
isValidNIKWithComparison('3401012012930001', { provinceKey: 'YO' });
getDataNIK(nik: string);
getDataNIK('3101011212930001');
Nomor Induk Pegawai Negeri Sipil (NIP)
isValidNIP(nip: string);
isValidNIP('198512262000051001');
Nomor Induk Siswa Nasional (NISN)
isValidNISN(nisn: string);
isValidNISN('0061230001');
Nomor Pokok Wajib Pajak (NPWP)
isValidNPWP(npwp: string);
isValidNPWP('09.123.123.1-123.123');
isValidNPWP('091231231123123');
formatNPWP(npwp: string);
formatNPWP('091231231123123');
Province
getDataProvince(key: string);
getDataProvince('YO');
getDataProvinces();
Tanda Nomor Kendaraan Bermotor (TNKB)
isValidTNKB(tnkb: string);
isValidTNKB('AB1234XYZ');
getDataTNKB(tnkb: string);
getDataTNKB('AB1234XYZ');
Telephone Number (Nomor Telefon)
isValidTelephoneNumber(tel: string);
isValidTelephoneNumber('0274123123');
getDataTelephoneNumber(cel: string);
getDataTelephoneNumber('0274123123');
formatTelephoneNumber(tel: string, int:boolean = false)
formatTelephoneNumber('0274123123');
formatTelephoneNumber('0274123123', true);
ZIP Code (Kode POS)
isValidZIP(zip: string | number);
isValidZIP('55524');
isValidZIP(55524);
isValidZIPWithComparison(zip: string | number, comparison: { provinceKy?: string });
isValidZIPWithComparison('55524', { provinceKey: 'YO' });
isValidZIPWithComparison(55524, { provinceKey: 'YO' });
License
Copyright (c) 2020 - Fajar Setya Budi
Nusantara Valid released under the MIT License.