diff --git a/README.md b/README.md
index 4ff35520..56db4310 100644
--- a/README.md
+++ b/README.md
@@ -129,7 +129,7 @@ As you can see, here you simply use `` as a normal `` field
- Pass in the custom `options` prop
- Add ReactJS `onChange` event listener
-See more in documentation: [ReactJS component usage](https://github.com/nosir/cleave.js/blob/master/doc/reactjs-component-usage.md) section
+Usage for `Webpack`, `Browserify` and more in documentation: [ReactJS component usage](https://github.com/nosir/cleave.js/blob/master/doc/reactjs-component-usage.md)
## Playground
diff --git a/bower.json b/bower.json
index 749b9fde..73e152ad 100644
--- a/bower.json
+++ b/bower.json
@@ -8,7 +8,7 @@
"form",
"input"
],
- "version": "0.5.1",
+ "version": "0.5.2",
"author": {
"name": "Max Huang",
"email": "risonhuang@gmail.com",
diff --git a/dist/cleave-react.js b/dist/cleave-react.js
index 7b87b2a2..446ca324 100644
--- a/dist/cleave-react.js
+++ b/dist/cleave-react.js
@@ -1,777 +1,862 @@
-(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }
+
+ var React = __webpack_require__(1);
+
+ var NumeralFormatter = __webpack_require__(2);
+ var DateFormatter = __webpack_require__(4);
+ var PhoneFormatter = __webpack_require__(5);
+ var CreditCardDetector = __webpack_require__(6);
+ var Util = __webpack_require__(7);
+ var DefaultProperties = __webpack_require__(8);
+
+ var Cleave = React.createClass({
+ displayName: 'Cleave',
+
+ componentDidMount: function componentDidMount() {
+ this.init();
+ },
+
+ componentWillReceiveProps: function componentWillReceiveProps(nextProps) {
+ var owner = this,
+ phoneRegionCode = nextProps.options.phoneRegionCode,
+ newValue = nextProps.value;
+
+ if (newValue) {
+ owner.onInput(newValue);
+ }
+
+ // update phone region code
+ if (phoneRegionCode && phoneRegionCode !== owner.properties.phoneRegionCode) {
+ owner.properties.phoneRegionCode = phoneRegionCode;
+ owner.initPhoneFormatter();
+ owner.onInput(owner.properties.result);
+ }
+ },
+
+ getInitialState: function getInitialState() {
+ var owner = this;
+ var _owner$props = owner.props;
+ var value = _owner$props.value;
+ var options = _owner$props.options;
+ var onKeyDown = _owner$props.onKeyDown;
+ var onChange = _owner$props.onChange;
+
+ var other = _objectWithoutProperties(_owner$props, ['value', 'options', 'onKeyDown', 'onChange']);
+
+ owner.registeredEvents = {
+ onChange: onChange || Util.noop,
+ onKeyDown: onKeyDown || Util.noop
+ };
+
+ options.initValue = value;
+
+ owner.properties = DefaultProperties.assign({}, options);
+
+ return {
+ other: other,
+ value: owner.properties.result
+ };
+ },
+
+ init: function init() {
+ var owner = this,
+ pps = owner.properties;
+
+ // so no need for this lib at all
+ if (!pps.numeral && !pps.phone && !pps.creditCard && !pps.date && pps.blocksLength === 0 && !pps.prefix) {
+ return;
+ }
+
+ pps.maxLength = Util.getMaxLength(pps.blocks);
+
+ owner.initPhoneFormatter();
+ owner.initDateFormatter();
+ owner.initNumeralFormatter();
+
+ owner.onInput(pps.initValue);
+ },
+
+ initNumeralFormatter: function initNumeralFormatter() {
+ var owner = this,
+ pps = owner.properties;
+
+ if (!pps.numeral) {
+ return;
+ }
+
+ pps.numeralFormatter = new NumeralFormatter(pps.numeralDecimalMark, pps.numeralDecimalScale, pps.numeralThousandsGroupStyle, pps.delimiter);
+ },
+
+ initDateFormatter: function initDateFormatter() {
+ var owner = this,
+ pps = owner.properties;
+
+ if (!pps.date) {
+ return;
+ }
+
+ pps.dateFormatter = new DateFormatter(pps.datePattern);
+ pps.blocks = pps.dateFormatter.getBlocks();
+ pps.blocksLength = pps.blocks.length;
+ pps.maxLength = Util.getMaxLength(pps.blocks);
+ },
+
+ initPhoneFormatter: function initPhoneFormatter() {
+ var owner = this,
+ pps = owner.properties;
+
+ if (!pps.phone) {
+ return;
+ }
+
+ // Cleave.AsYouTypeFormatter should be provided by
+ // external google closure lib
+ try {
+ pps.phoneFormatter = new PhoneFormatter(new window.Cleave.AsYouTypeFormatter(pps.phoneRegionCode), pps.delimiter);
+ } catch (ex) {
+ throw new Error('Please include phone-type-formatter.{country}.js lib');
+ }
+ },
+
+ onKeyDown: function onKeyDown(event) {
+ var owner = this,
+ pps = owner.properties,
+ charCode = event.which || event.keyCode;
+
+ // hit backspace when last character is delimiter
+ if (charCode === 8 && pps.result.slice(-1) === pps.delimiter) {
+ pps.backspace = true;
+ } else {
+ pps.backspace = false;
+ }
+
+ owner.registeredEvents.onKeyDown(event);
+ },
+
+ onChange: function onChange(event) {
+ var owner = this,
+ pps = owner.properties;
+
+ owner.onInput(event.target.value);
+
+ if (pps.numeral) {
+ event.target.rawValue = pps.numeralFormatter.getRawValue(pps.result);
+ } else {
+ event.target.rawValue = Util.strip(pps.result, pps.delimiterRE);
+ }
+
+ owner.registeredEvents.onChange(event);
+ },
+
+ onInput: function onInput(value) {
+ var owner = this,
+ pps = owner.properties,
+ prev = pps.result;
+
+ // case 1: delete one more character "4"
+ // 1234*| -> hit backspace -> 123|
+ // case 2: last character is not delimiter which is:
+ // 12|34* -> hit backspace -> 1|34*
+
+ if (!pps.numeral && pps.backspace && value.slice(-1) !== pps.delimiter) {
+ value = Util.headStr(value, value.length - 1);
+ }
+
+ // phone formatter
+ if (pps.phone) {
+ pps.result = pps.phoneFormatter.format(value);
+ owner.updateValueState();
+
+ return;
+ }
+
+ // numeral formatter
+ if (pps.numeral) {
+ pps.result = pps.prefix + pps.numeralFormatter.format(value);
+ owner.updateValueState();
+
+ return;
+ }
+
+ // date
+ if (pps.date) {
+ value = pps.dateFormatter.getValidatedDate(value);
+ }
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-
-var _Cleave = require('./src/Cleave.react');
-
-var _Cleave2 = _interopRequireDefault(_Cleave);
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-exports.default = _Cleave2.default;
-
-},{"./src/Cleave.react":2}],2:[function(require,module,exports){
-(function (global){
-'use strict';
-
-var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
-
-function _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }
-
-var React = (typeof window !== "undefined" ? window['React'] : typeof global !== "undefined" ? global['React'] : null);
-
-var NumeralFormatter = require('./shortcuts/NumeralFormatter');
-var DateFormatter = require('./shortcuts/DateFormatter');
-var PhoneFormatter = require('./shortcuts/PhoneFormatter');
-var CreditCardDetector = require('./shortcuts/CreditCardDetector');
-var Util = require('./utils/Util');
-var DefaultProperties = require('./common/DefaultProperties');
-
-var Cleave = React.createClass({
- displayName: 'Cleave',
-
- componentDidMount: function componentDidMount() {
- this.init();
- },
-
- componentWillReceiveProps: function componentWillReceiveProps(nextProps) {
- var owner = this,
- phoneRegionCode = nextProps.options.phoneRegionCode,
- newValue = nextProps.value;
-
- if (newValue) {
- owner.onInput(newValue);
- }
-
- // update phone region code
- if (phoneRegionCode && phoneRegionCode !== owner.properties.phoneRegionCode) {
- owner.properties.phoneRegionCode = phoneRegionCode;
- owner.initPhoneFormatter();
- owner.onInput(owner.properties.result);
- }
- },
-
- getInitialState: function getInitialState() {
- var owner = this;
- var _owner$props = owner.props;
- var value = _owner$props.value;
- var options = _owner$props.options;
- var onKeyDown = _owner$props.onKeyDown;
- var onChange = _owner$props.onChange;
-
- var other = _objectWithoutProperties(_owner$props, ['value', 'options', 'onKeyDown', 'onChange']);
-
- owner.registeredEvents = {
- onChange: onChange || Util.noop,
- onKeyDown: onKeyDown || Util.noop
- };
-
- options.initValue = value;
-
- owner.properties = DefaultProperties.assign({}, options);
-
- return {
- other: other,
- value: owner.properties.result
- };
- },
-
- init: function init() {
- var owner = this,
- pps = owner.properties;
-
- // so no need for this lib at all
- if (!pps.numeral && !pps.phone && !pps.creditCard && !pps.date && pps.blocksLength === 0 && !pps.prefix) {
- return;
- }
-
- pps.maxLength = Util.getMaxLength(pps.blocks);
-
- owner.initPhoneFormatter();
- owner.initDateFormatter();
- owner.initNumeralFormatter();
+ // strip delimiters
+ value = Util.strip(value, pps.delimiterRE);
- owner.onInput(pps.initValue);
- },
+ // strip prefix
+ value = Util.getPrefixStrippedValue(value, pps.prefixLength);
+
+ // strip non-numeric characters
+ value = pps.numericOnly ? Util.strip(value, /[^\d]/g) : value;
+
+ // convert case
+ value = pps.uppercase ? value.toUpperCase() : value;
+ value = pps.lowercase ? value.toLowerCase() : value;
+
+ // prefix
+ if (pps.prefix) {
+ value = pps.prefix + value;
+
+ // no blocks specified, no need to do formatting
+ if (pps.blocksLength === 0) {
+ pps.result = value;
+ owner.updateValueState();
+
+ return;
+ }
+ }
+
+ // update credit card props
+ if (pps.creditCard) {
+ owner.updateCreditCardPropsByValue(value);
+ }
+
+ // strip over length characters
+ value = Util.headStr(value, pps.maxLength);
- initNumeralFormatter: function initNumeralFormatter() {
- var owner = this,
- pps = owner.properties;
+ // apply blocks
+ pps.result = Util.getFormattedValue(value, pps.blocks, pps.blocksLength, pps.delimiter);
- if (!pps.numeral) {
- return;
- }
+ // nothing changed
+ // prevent update value to avoid caret position change
+ if (prev === pps.result && prev !== pps.prefix) {
+ return;
+ }
- pps.numeralFormatter = new NumeralFormatter(pps.numeralDecimalMark, pps.numeralDecimalScale, pps.numeralThousandsGroupStyle, pps.delimiter);
- },
-
- initDateFormatter: function initDateFormatter() {
- var owner = this,
- pps = owner.properties;
-
- if (!pps.date) {
- return;
- }
-
- pps.dateFormatter = new DateFormatter(pps.datePattern);
- pps.blocks = pps.dateFormatter.getBlocks();
- pps.blocksLength = pps.blocks.length;
- pps.maxLength = Util.getMaxLength(pps.blocks);
- },
-
- initPhoneFormatter: function initPhoneFormatter() {
- var owner = this,
- pps = owner.properties;
-
- if (!pps.phone) {
- return;
- }
-
- // Cleave.AsYouTypeFormatter should be provided by
- // external google closure lib
- try {
- pps.phoneFormatter = new PhoneFormatter(new window.Cleave.AsYouTypeFormatter(pps.phoneRegionCode), pps.delimiter);
- } catch (ex) {
- throw new Error('Please include phone-type-formatter.{country}.js lib');
- }
- },
-
- onKeyDown: function onKeyDown(event) {
- var owner = this,
- pps = owner.properties,
- charCode = event.which || event.keyCode;
-
- // hit backspace when last character is delimiter
- if (charCode === 8 && pps.result.slice(-1) === pps.delimiter) {
- pps.backspace = true;
- } else {
- pps.backspace = false;
- }
-
- owner.registeredEvents.onKeyDown(event);
- },
-
- onChange: function onChange(event) {
- var owner = this,
- pps = owner.properties;
-
- owner.onInput(event.target.value);
-
- if (pps.numeral) {
- event.target.rawValue = pps.numeralFormatter.getRawValue(pps.result);
- } else {
- event.target.rawValue = Util.strip(pps.result, pps.delimiterRE);
- }
-
- owner.registeredEvents.onChange(event);
- },
-
- onInput: function onInput(value) {
- var owner = this,
- pps = owner.properties,
- prev = pps.result;
-
- // case 1: delete one more character "4"
- // 1234*| -> hit backspace -> 123|
- // case 2: last character is not delimiter which is:
- // 12|34* -> hit backspace -> 1|34*
-
- if (!pps.numeral && pps.backspace && value.slice(-1) !== pps.delimiter) {
- value = Util.headStr(value, value.length - 1);
- }
-
- // phone formatter
- if (pps.phone) {
- pps.result = pps.phoneFormatter.format(value);
- owner.updateValueState();
-
- return;
- }
-
- // numeral formatter
- if (pps.numeral) {
- pps.result = pps.prefix + pps.numeralFormatter.format(value);
- owner.updateValueState();
-
- return;
- }
-
- // date
- if (pps.date) {
- value = pps.dateFormatter.getValidatedDate(value);
- }
-
- // strip delimiters
- value = Util.strip(value, pps.delimiterRE);
-
- // strip prefix
- value = Util.getPrefixStrippedValue(value, pps.prefixLength);
-
- // strip non-numeric characters
- value = pps.numericOnly ? Util.strip(value, /[^\d]/g) : value;
-
- // convert case
- value = pps.uppercase ? value.toUpperCase() : value;
- value = pps.lowercase ? value.toLowerCase() : value;
-
- // prefix
- if (pps.prefix) {
- value = pps.prefix + value;
-
- // no blocks specified, no need to do formatting
- if (pps.blocksLength === 0) {
- pps.result = value;
- owner.updateValueState();
-
- return;
- }
- }
-
- // update credit card props
- if (pps.creditCard) {
- owner.updateCreditCardPropsByValue(value);
- }
-
- // strip over length characters
- value = Util.headStr(value, pps.maxLength);
-
- // apply blocks
- pps.result = Util.getFormattedValue(value, pps.blocks, pps.blocksLength, pps.delimiter);
-
- // nothing changed
- // prevent update value to avoid caret position change
- if (prev === pps.result && prev !== pps.prefix) {
- return;
- }
-
- owner.updateValueState();
- },
+ owner.updateValueState();
+ },
- updateCreditCardPropsByValue: function updateCreditCardPropsByValue(value) {
- var owner = this,
- pps = owner.properties,
- creditCardInfo;
-
- // At least one of the first 4 characters has changed
- if (Util.headStr(pps.result, 4) === Util.headStr(value, 4)) {
- return;
- }
+ updateCreditCardPropsByValue: function updateCreditCardPropsByValue(value) {
+ var owner = this,
+ pps = owner.properties,
+ creditCardInfo;
- creditCardInfo = CreditCardDetector.getInfo(value, pps.creditCardStrictMode);
-
- pps.blocks = creditCardInfo.blocks;
- pps.blocksLength = pps.blocks.length;
- pps.maxLength = Util.getMaxLength(pps.blocks);
+ // At least one of the first 4 characters has changed
+ if (Util.headStr(pps.result, 4) === Util.headStr(value, 4)) {
+ return;
+ }
- // credit card type changed
- if (pps.creditCardType !== creditCardInfo.type) {
- pps.creditCardType = creditCardInfo.type;
-
- pps.onCreditCardTypeChanged.call(owner, pps.creditCardType);
- }
- },
+ creditCardInfo = CreditCardDetector.getInfo(value, pps.creditCardStrictMode);
- updateValueState: function updateValueState() {
- this.setState({ value: this.properties.result });
- },
+ pps.blocks = creditCardInfo.blocks;
+ pps.blocksLength = pps.blocks.length;
+ pps.maxLength = Util.getMaxLength(pps.blocks);
- render: function render() {
- var owner = this;
+ // credit card type changed
+ if (pps.creditCardType !== creditCardInfo.type) {
+ pps.creditCardType = creditCardInfo.type;
- return React.createElement('input', _extends({ type: 'text' }, owner.state.other, {
- value: owner.state.value,
- onKeyDown: owner.onKeyDown,
- onChange: owner.onChange }));
- }
-});
-
-module.exports = window.Cleave = Cleave;
-
-}).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {})
-
-},{"./common/DefaultProperties":3,"./shortcuts/CreditCardDetector":4,"./shortcuts/DateFormatter":5,"./shortcuts/NumeralFormatter":6,"./shortcuts/PhoneFormatter":7,"./utils/Util":8}],3:[function(require,module,exports){
-'use strict';
-
-/**
- * Props Assignment
- *
- * Separate this, so react module can share the usage
- */
-
-var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol ? "symbol" : typeof obj; };
-
-var DefaultProperties = {
- // Maybe change to object-assign
- // for now just keep it as simple
- assign: function assign(target, opts) {
- target = target || {};
- opts = opts || {};
-
- // credit card
- target.creditCard = !!opts.creditCard;
- target.creditCardStrictMode = !!opts.creditCardStrictMode;
- target.creditCardType = '';
- target.onCreditCardTypeChanged = opts.onCreditCardTypeChanged || function () {};
-
- // phone
- target.phone = !!opts.phone;
- target.phoneRegionCode = opts.phoneRegionCode || 'AU';
- target.phoneFormatter = {};
-
- // date
- target.date = !!opts.date;
- target.datePattern = opts.datePattern || ['d', 'm', 'Y'];
- target.dateFormatter = {};
-
- // numeral
- target.numeral = !!opts.numeral;
- target.numeralDecimalScale = opts.numeralDecimalScale >= 0 ? opts.numeralDecimalScale : 2;
- target.numeralDecimalMark = opts.numeralDecimalMark || '.';
- target.numeralThousandsGroupStyle = opts.numeralThousandsGroupStyle || 'thousand';
-
- // others
- target.numericOnly = target.creditCard || target.date || !!opts.numericOnly;
-
- target.uppercase = !!opts.uppercase;
- target.lowercase = !!opts.lowercase;
-
- target.prefix = target.creditCard || target.phone || target.date ? '' : opts.prefix || '';
- target.prefixLength = target.prefix.length;
-
- target.initValue = opts.initValue || '';
-
- target.delimiter = opts.delimiter || opts.delimiter === '' ? opts.delimiter : opts.date ? '/' : opts.numeral ? ',' : opts.phone ? ' ' : ' ';
- target.delimiterRE = new RegExp('\\' + (target.delimiter || ' '), 'g');
-
- target.blocks = opts.blocks || [];
- target.blocksLength = target.blocks.length;
-
- target.maxLength = 0;
-
- target.backspace = false;
- target.result = '';
-
- return target;
- }
-};
-
-if ((typeof module === 'undefined' ? 'undefined' : _typeof(module)) === 'object' && _typeof(module.exports) === 'object') {
- module.exports = exports = DefaultProperties;
-}
-
-},{}],4:[function(require,module,exports){
-'use strict';
-
-var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol ? "symbol" : typeof obj; };
-
-var CreditCardDetector = {
- blocks: {
- uatp: [4, 5, 6],
- amex: [4, 6, 5],
- diners: [4, 6, 4],
- discover: [4, 4, 4, 4],
- mastercard: [4, 4, 4, 4],
- dankort: [4, 4, 4, 4],
- instapayment: [4, 4, 4, 4],
- jcb: [4, 4, 4, 4],
- maestro: [4, 4, 4, 4],
- visa: [4, 4, 4, 4],
- generalLoose: [4, 4, 4, 4],
- generalStrict: [4, 4, 4, 7]
- },
-
- re: {
- // starts with 1; 15 digits, not starts with 1800 (jcb card)
- uatp: /^(?!1800)1\d{0,14}/,
-
- // starts with 34/37; 15 digits
- amex: /^3[47]\d{0,13}/,
-
- // starts with 6011/65/644-649; 16 digits
- discover: /^(?:6011|65\d{0,2}|64[4-9]\d?)\d{0,12}/,
-
- // starts with 300-305/309 or 36/38/39; 14 digits
- diners: /^3(?:0([0-5]|9)|[689]\d?)\d{0,11}/,
-
- // starts with 51-55/22-27; 16 digits
- mastercard: /^(5[1-5]|2[2-7])\d{0,14}/,
-
- // starts with 5019/4175/4571; 16 digits
- dankort: /^(5019|4175|4571)\d{0,12}/,
-
- // starts with 637-639; 16 digits
- instapayment: /^63[7-9]\d{0,13}/,
-
- // starts with 2131/1800/35; 16 digits
- jcb: /^(?:2131|1800|35\d{0,2})\d{0,12}/,
-
- // starts with 50/56-58/6304/67; 16 digits
- maestro: /^(?:5[0678]\d{0,2}|6304|67\d{0,2})\d{0,12}/,
-
- // starts with 4; 16 digits
- visa: /^4\d{0,15}/
- },
-
- getInfo: function getInfo(value, strictMode) {
- var blocks = CreditCardDetector.blocks,
- re = CreditCardDetector.re;
-
- // In theory, visa credit card can have up to 19 digits number.
- // Set strictMode to true will remove the 16 max-length restrain,
- // however, I never found any website validate card number like
- // this, hence probably you don't need to enable this option.
- strictMode = !!strictMode;
-
- if (re.amex.test(value)) {
- return {
- type: 'amex',
- blocks: blocks.amex
- };
- } else if (re.uatp.test(value)) {
- return {
- type: 'uatp',
- blocks: blocks.uatp
- };
- } else if (re.diners.test(value)) {
- return {
- type: 'diners',
- blocks: blocks.diners
- };
- } else if (re.discover.test(value)) {
- return {
- type: 'discover',
- blocks: blocks.discover
- };
- } else if (re.mastercard.test(value)) {
- return {
- type: 'mastercard',
- blocks: blocks.mastercard
- };
- } else if (re.dankort.test(value)) {
- return {
- type: 'dankort',
- blocks: blocks.dankort
- };
- } else if (re.instapayment.test(value)) {
- return {
- type: 'instapayment',
- blocks: blocks.instapayment
- };
- } else if (re.jcb.test(value)) {
- return {
- type: 'jcb',
- blocks: blocks.jcb
- };
- } else if (re.maestro.test(value)) {
- return {
- type: 'maestro',
- blocks: blocks.maestro
- };
- } else if (re.visa.test(value)) {
- return {
- type: 'visa',
- blocks: blocks.visa
- };
- } else if (strictMode) {
- return {
- type: 'unknown',
- blocks: blocks.generalStrict
- };
- } else {
- return {
- type: 'unknown',
- blocks: blocks.generalLoose
- };
- }
- }
-};
-
-if ((typeof module === 'undefined' ? 'undefined' : _typeof(module)) === 'object' && _typeof(module.exports) === 'object') {
- module.exports = exports = CreditCardDetector;
-}
-
-},{}],5:[function(require,module,exports){
-'use strict';
-
-var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol ? "symbol" : typeof obj; };
-
-var DateFormatter = function DateFormatter(datePattern) {
- var owner = this;
-
- owner.blocks = [];
- owner.datePattern = datePattern;
- owner.initBlocks();
-};
-
-DateFormatter.prototype = {
- initBlocks: function initBlocks() {
- var owner = this;
- owner.datePattern.forEach(function (value) {
- if (value === 'Y') {
- owner.blocks.push(4);
- } else {
- owner.blocks.push(2);
- }
- });
- },
-
- getBlocks: function getBlocks() {
- return this.blocks;
- },
-
- getValidatedDate: function getValidatedDate(value) {
- var owner = this,
- result = '';
-
- value = value.replace(/[^\d]/g, '');
-
- owner.blocks.forEach(function (length, index) {
- if (value.length > 0) {
- var sub = value.slice(0, length),
- sub0 = sub.slice(0, 1),
- rest = value.slice(length);
-
- switch (owner.datePattern[index]) {
- case 'd':
- if (sub === '00') {
- sub = '01';
- } else if (parseInt(sub0, 10) > 3) {
- sub = '0' + sub0;
- } else if (parseInt(sub, 10) > 31) {
- sub = '31';
- }
-
- break;
-
- case 'm':
- if (sub === '00') {
- sub = '01';
- } else if (parseInt(sub0, 10) > 1) {
- sub = '0' + sub0;
- } else if (parseInt(sub, 10) > 12) {
- sub = '12';
- }
-
- break;
- }
-
- result += sub;
-
- // update remaining string
- value = rest;
- }
- });
-
- return result;
- }
-};
-
-if ((typeof module === 'undefined' ? 'undefined' : _typeof(module)) === 'object' && _typeof(module.exports) === 'object') {
- module.exports = exports = DateFormatter;
-}
-
-},{}],6:[function(require,module,exports){
-'use strict';
-
-var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol ? "symbol" : typeof obj; };
-
-var NumeralFormatter = function NumeralFormatter(numeralDecimalMark, numeralDecimalScale, numeralThousandsGroupStyle, delimiter) {
- var owner = this;
-
- owner.numeralDecimalMark = numeralDecimalMark || '.';
- owner.numeralDecimalScale = numeralDecimalScale >= 0 ? numeralDecimalScale : 2;
- owner.numeralThousandsGroupStyle = numeralThousandsGroupStyle || NumeralFormatter.groupStyle.thousand;
- owner.delimiter = delimiter || delimiter === '' ? delimiter : ',';
- owner.delimiterRE = delimiter ? new RegExp('\\' + delimiter, 'g') : '';
-};
+ pps.onCreditCardTypeChanged.call(owner, pps.creditCardType);
+ }
+ },
-NumeralFormatter.groupStyle = {
- thousand: 'thousand',
- lakh: 'lakh',
- wan: 'wan'
-};
+ updateValueState: function updateValueState() {
+ this.setState({ value: this.properties.result });
+ },
-NumeralFormatter.prototype = {
- getRawValue: function getRawValue(value) {
- return value.replace(this.delimiterRE, '').replace(this.numeralDecimalMark, '.');
- },
-
- format: function format(value) {
- var owner = this,
- parts,
- partInteger,
- partDecimal = '';
-
- // strip alphabet letters
- value = value.replace(/[A-Za-z]/g, '')
-
- // replace the first decimal mark with reserved placeholder
- .replace(owner.numeralDecimalMark, 'M')
-
- // strip the non numeric letters except M
- .replace(/[^\dM]/g, '')
+ render: function render() {
+ var owner = this;
- // replace mark
- .replace('M', owner.numeralDecimalMark)
+ return React.createElement('input', _extends({ type: 'text' }, owner.state.other, {
+ value: owner.state.value,
+ onKeyDown: owner.onKeyDown,
+ onChange: owner.onChange }));
+ }
+ });
- // strip leading 0
- .replace(/^(-)?0+(?=\d)/, '$1');
+ module.exports = window.Cleave = Cleave;
- partInteger = value;
+/***/ },
+/* 1 */
+/***/ function(module, exports) {
- if (value.indexOf(owner.numeralDecimalMark) >= 0) {
- parts = value.split(owner.numeralDecimalMark);
- partInteger = parts[0];
- partDecimal = owner.numeralDecimalMark + parts[1].slice(0, owner.numeralDecimalScale);
- }
+ module.exports = __WEBPACK_EXTERNAL_MODULE_1__;
- switch (owner.numeralThousandsGroupStyle) {
- case NumeralFormatter.groupStyle.lakh:
- partInteger = partInteger.replace(/(\d)(?=(\d\d)+\d$)/g, '$1' + owner.delimiter);
+/***/ },
+/* 2 */
+/***/ function(module, exports, __webpack_require__) {
- break;
+ /* WEBPACK VAR INJECTION */(function(module) {'use strict';
- case NumeralFormatter.groupStyle.wan:
- partInteger = partInteger.replace(/(\d)(?=(\d{4})+$)/g, '$1' + owner.delimiter);
+ var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol ? "symbol" : typeof obj; };
- break;
+ var NumeralFormatter = function NumeralFormatter(numeralDecimalMark, numeralDecimalScale, numeralThousandsGroupStyle, delimiter) {
+ var owner = this;
- default:
- partInteger = partInteger.replace(/(\d)(?=(\d{3})+$)/g, '$1' + owner.delimiter);
- }
+ owner.numeralDecimalMark = numeralDecimalMark || '.';
+ owner.numeralDecimalScale = numeralDecimalScale >= 0 ? numeralDecimalScale : 2;
+ owner.numeralThousandsGroupStyle = numeralThousandsGroupStyle || NumeralFormatter.groupStyle.thousand;
+ owner.delimiter = delimiter || delimiter === '' ? delimiter : ',';
+ owner.delimiterRE = delimiter ? new RegExp('\\' + delimiter, 'g') : '';
+ };
- return partInteger.toString() + (owner.numeralDecimalScale > 0 ? partDecimal.toString() : '');
- }
-};
+ NumeralFormatter.groupStyle = {
+ thousand: 'thousand',
+ lakh: 'lakh',
+ wan: 'wan'
+ };
-if ((typeof module === 'undefined' ? 'undefined' : _typeof(module)) === 'object' && _typeof(module.exports) === 'object') {
- module.exports = exports = NumeralFormatter;
-}
+ NumeralFormatter.prototype = {
+ getRawValue: function getRawValue(value) {
+ return value.replace(this.delimiterRE, '').replace(this.numeralDecimalMark, '.');
+ },
-},{}],7:[function(require,module,exports){
-'use strict';
+ format: function format(value) {
+ var owner = this,
+ parts,
+ partInteger,
+ partDecimal = '';
-var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol ? "symbol" : typeof obj; };
+ // strip alphabet letters
+ value = value.replace(/[A-Za-z]/g, '')
-var PhoneFormatter = function PhoneFormatter(formatter, delimiter) {
- var owner = this;
+ // replace the first decimal mark with reserved placeholder
+ .replace(owner.numeralDecimalMark, 'M')
- owner.delimiter = delimiter || delimiter === '' ? delimiter : ' ';
- owner.delimiterRE = delimiter ? new RegExp('\\' + delimiter, 'g') : '';
+ // strip the non numeric letters except M
+ .replace(/[^\dM]/g, '')
- owner.formatter = formatter;
-};
+ // replace mark
+ .replace('M', owner.numeralDecimalMark)
+
+ // strip leading 0
+ .replace(/^(-)?0+(?=\d)/, '$1');
+
+ partInteger = value;
+
+ if (value.indexOf(owner.numeralDecimalMark) >= 0) {
+ parts = value.split(owner.numeralDecimalMark);
+ partInteger = parts[0];
+ partDecimal = owner.numeralDecimalMark + parts[1].slice(0, owner.numeralDecimalScale);
+ }
+
+ switch (owner.numeralThousandsGroupStyle) {
+ case NumeralFormatter.groupStyle.lakh:
+ partInteger = partInteger.replace(/(\d)(?=(\d\d)+\d$)/g, '$1' + owner.delimiter);
+
+ break;
+
+ case NumeralFormatter.groupStyle.wan:
+ partInteger = partInteger.replace(/(\d)(?=(\d{4})+$)/g, '$1' + owner.delimiter);
+
+ break;
+
+ default:
+ partInteger = partInteger.replace(/(\d)(?=(\d{3})+$)/g, '$1' + owner.delimiter);
+ }
+
+ return partInteger.toString() + (owner.numeralDecimalScale > 0 ? partDecimal.toString() : '');
+ }
+ };
+
+ if (( false ? 'undefined' : _typeof(module)) === 'object' && _typeof(module.exports) === 'object') {
+ module.exports = exports = NumeralFormatter;
+ }
+ /* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(3)(module)))
+
+/***/ },
+/* 3 */
+/***/ function(module, exports) {
+
+ module.exports = function(module) {
+ if(!module.webpackPolyfill) {
+ module.deprecate = function() {};
+ module.paths = [];
+ // module.parent = undefined by default
+ module.children = [];
+ module.webpackPolyfill = 1;
+ }
+ return module;
+ }
-PhoneFormatter.prototype = {
- setFormatter: function setFormatter(formatter) {
- this.formatter = formatter;
- },
- format: function format(phoneNumber) {
- var owner = this;
+/***/ },
+/* 4 */
+/***/ function(module, exports, __webpack_require__) {
+
+ /* WEBPACK VAR INJECTION */(function(module) {'use strict';
- owner.formatter.clear();
+ var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol ? "symbol" : typeof obj; };
+
+ var DateFormatter = function DateFormatter(datePattern) {
+ var owner = this;
+
+ owner.blocks = [];
+ owner.datePattern = datePattern;
+ owner.initBlocks();
+ };
+
+ DateFormatter.prototype = {
+ initBlocks: function initBlocks() {
+ var owner = this;
+ owner.datePattern.forEach(function (value) {
+ if (value === 'Y') {
+ owner.blocks.push(4);
+ } else {
+ owner.blocks.push(2);
+ }
+ });
+ },
- // only keep number and +
- phoneNumber = phoneNumber.replace(/[^\d+]/g, '');
+ getBlocks: function getBlocks() {
+ return this.blocks;
+ },
- // strip delimiter
- phoneNumber = phoneNumber.replace(owner.delimiterRE, '');
+ getValidatedDate: function getValidatedDate(value) {
+ var owner = this,
+ result = '';
- var result = '',
- current,
- validated = false;
+ value = value.replace(/[^\d]/g, '');
- for (var i = 0, iMax = phoneNumber.length; i < iMax; i++) {
- current = owner.formatter.inputDigit(phoneNumber.charAt(i));
+ owner.blocks.forEach(function (length, index) {
+ if (value.length > 0) {
+ var sub = value.slice(0, length),
+ sub0 = sub.slice(0, 1),
+ rest = value.slice(length);
+
+ switch (owner.datePattern[index]) {
+ case 'd':
+ if (sub === '00') {
+ sub = '01';
+ } else if (parseInt(sub0, 10) > 3) {
+ sub = '0' + sub0;
+ } else if (parseInt(sub, 10) > 31) {
+ sub = '31';
+ }
+
+ break;
+
+ case 'm':
+ if (sub === '00') {
+ sub = '01';
+ } else if (parseInt(sub0, 10) > 1) {
+ sub = '0' + sub0;
+ } else if (parseInt(sub, 10) > 12) {
+ sub = '12';
+ }
+
+ break;
+ }
+
+ result += sub;
+
+ // update remaining string
+ value = rest;
+ }
+ });
+
+ return result;
+ }
+ };
+
+ if (( false ? 'undefined' : _typeof(module)) === 'object' && _typeof(module.exports) === 'object') {
+ module.exports = exports = DateFormatter;
+ }
+ /* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(3)(module)))
+
+/***/ },
+/* 5 */
+/***/ function(module, exports, __webpack_require__) {
+
+ /* WEBPACK VAR INJECTION */(function(module) {'use strict';
+
+ var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol ? "symbol" : typeof obj; };
+
+ var PhoneFormatter = function PhoneFormatter(formatter, delimiter) {
+ var owner = this;
+
+ owner.delimiter = delimiter || delimiter === '' ? delimiter : ' ';
+ owner.delimiterRE = delimiter ? new RegExp('\\' + delimiter, 'g') : '';
+
+ owner.formatter = formatter;
+ };
+
+ PhoneFormatter.prototype = {
+ setFormatter: function setFormatter(formatter) {
+ this.formatter = formatter;
+ },
+
+ format: function format(phoneNumber) {
+ var owner = this;
+
+ owner.formatter.clear();
+
+ // only keep number and +
+ phoneNumber = phoneNumber.replace(/[^\d+]/g, '');
+
+ // strip delimiter
+ phoneNumber = phoneNumber.replace(owner.delimiterRE, '');
+
+ var result = '',
+ current,
+ validated = false;
+
+ for (var i = 0, iMax = phoneNumber.length; i < iMax; i++) {
+ current = owner.formatter.inputDigit(phoneNumber.charAt(i));
+
+ // has ()- or space inside
+ if (/[\s()-]/g.test(current)) {
+ result = current;
+
+ validated = true;
+ } else {
+ if (!validated) {
+ result = current;
+ }
+ // else: over length input
+ // it turns to invalid number again
+ }
+ }
+
+ // strip ()
+ // e.g. US: 7161234567 returns (716) 123-4567
+ result = result.replace(/[()]/g, '');
+ // replace library delimiter with user customized delimiter
+ result = result.replace(/[\s-]/g, owner.delimiter);
+
+ return result;
+ }
+ };
+
+ if (( false ? 'undefined' : _typeof(module)) === 'object' && _typeof(module.exports) === 'object') {
+ module.exports = exports = PhoneFormatter;
+ }
+ /* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(3)(module)))
+
+/***/ },
+/* 6 */
+/***/ function(module, exports, __webpack_require__) {
+
+ /* WEBPACK VAR INJECTION */(function(module) {'use strict';
+
+ var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol ? "symbol" : typeof obj; };
+
+ var CreditCardDetector = {
+ blocks: {
+ uatp: [4, 5, 6],
+ amex: [4, 6, 5],
+ diners: [4, 6, 4],
+ discover: [4, 4, 4, 4],
+ mastercard: [4, 4, 4, 4],
+ dankort: [4, 4, 4, 4],
+ instapayment: [4, 4, 4, 4],
+ jcb: [4, 4, 4, 4],
+ maestro: [4, 4, 4, 4],
+ visa: [4, 4, 4, 4],
+ generalLoose: [4, 4, 4, 4],
+ generalStrict: [4, 4, 4, 7]
+ },
+
+ re: {
+ // starts with 1; 15 digits, not starts with 1800 (jcb card)
+ uatp: /^(?!1800)1\d{0,14}/,
+
+ // starts with 34/37; 15 digits
+ amex: /^3[47]\d{0,13}/,
+
+ // starts with 6011/65/644-649; 16 digits
+ discover: /^(?:6011|65\d{0,2}|64[4-9]\d?)\d{0,12}/,
+
+ // starts with 300-305/309 or 36/38/39; 14 digits
+ diners: /^3(?:0([0-5]|9)|[689]\d?)\d{0,11}/,
+
+ // starts with 51-55/22-27; 16 digits
+ mastercard: /^(5[1-5]|2[2-7])\d{0,14}/,
+
+ // starts with 5019/4175/4571; 16 digits
+ dankort: /^(5019|4175|4571)\d{0,12}/,
+
+ // starts with 637-639; 16 digits
+ instapayment: /^63[7-9]\d{0,13}/,
+
+ // starts with 2131/1800/35; 16 digits
+ jcb: /^(?:2131|1800|35\d{0,2})\d{0,12}/,
+
+ // starts with 50/56-58/6304/67; 16 digits
+ maestro: /^(?:5[0678]\d{0,2}|6304|67\d{0,2})\d{0,12}/,
+
+ // starts with 4; 16 digits
+ visa: /^4\d{0,15}/
+ },
+
+ getInfo: function getInfo(value, strictMode) {
+ var blocks = CreditCardDetector.blocks,
+ re = CreditCardDetector.re;
+
+ // In theory, visa credit card can have up to 19 digits number.
+ // Set strictMode to true will remove the 16 max-length restrain,
+ // however, I never found any website validate card number like
+ // this, hence probably you don't need to enable this option.
+ strictMode = !!strictMode;
+
+ if (re.amex.test(value)) {
+ return {
+ type: 'amex',
+ blocks: blocks.amex
+ };
+ } else if (re.uatp.test(value)) {
+ return {
+ type: 'uatp',
+ blocks: blocks.uatp
+ };
+ } else if (re.diners.test(value)) {
+ return {
+ type: 'diners',
+ blocks: blocks.diners
+ };
+ } else if (re.discover.test(value)) {
+ return {
+ type: 'discover',
+ blocks: blocks.discover
+ };
+ } else if (re.mastercard.test(value)) {
+ return {
+ type: 'mastercard',
+ blocks: blocks.mastercard
+ };
+ } else if (re.dankort.test(value)) {
+ return {
+ type: 'dankort',
+ blocks: blocks.dankort
+ };
+ } else if (re.instapayment.test(value)) {
+ return {
+ type: 'instapayment',
+ blocks: blocks.instapayment
+ };
+ } else if (re.jcb.test(value)) {
+ return {
+ type: 'jcb',
+ blocks: blocks.jcb
+ };
+ } else if (re.maestro.test(value)) {
+ return {
+ type: 'maestro',
+ blocks: blocks.maestro
+ };
+ } else if (re.visa.test(value)) {
+ return {
+ type: 'visa',
+ blocks: blocks.visa
+ };
+ } else if (strictMode) {
+ return {
+ type: 'unknown',
+ blocks: blocks.generalStrict
+ };
+ } else {
+ return {
+ type: 'unknown',
+ blocks: blocks.generalLoose
+ };
+ }
+ }
+ };
+
+ if (( false ? 'undefined' : _typeof(module)) === 'object' && _typeof(module.exports) === 'object') {
+ module.exports = exports = CreditCardDetector;
+ }
+ /* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(3)(module)))
+
+/***/ },
+/* 7 */
+/***/ function(module, exports, __webpack_require__) {
+
+ /* WEBPACK VAR INJECTION */(function(module) {'use strict';
+
+ var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol ? "symbol" : typeof obj; };
+
+ var Util = {
+ noop: function noop() {},
+
+ strip: function strip(value, re) {
+ return value.replace(re, '');
+ },
+
+ headStr: function headStr(str, length) {
+ return str.slice(0, length);
+ },
+
+ getMaxLength: function getMaxLength(blocks) {
+ return blocks.reduce(function (previous, current) {
+ return previous + current;
+ }, 0);
+ },
+
+ // strip value by prefix length
+ // for prefix: PRE
+ // (PRE123, 3) -> 123
+ // (PR123, 3) -> 23 this happens when user hits backspace in front of "PRE"
+ getPrefixStrippedValue: function getPrefixStrippedValue(value, prefixLength) {
+ return value.slice(prefixLength);
+ },
+
+ getFormattedValue: function getFormattedValue(value, blocks, blocksLength, delimiter) {
+ var result = '';
+
+ blocks.forEach(function (length, index) {
+ if (value.length > 0) {
+ var sub = value.slice(0, length),
+ rest = value.slice(length);
+
+ result += sub;
+
+ if (sub.length === length && index < blocksLength - 1) {
+ result += delimiter;
+ }
+
+ // update remaining string
+ value = rest;
+ }
+ });
+
+ return result;
+ }
+ };
+
+ if (( false ? 'undefined' : _typeof(module)) === 'object' && _typeof(module.exports) === 'object') {
+ module.exports = exports = Util;
+ }
+ /* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(3)(module)))
+
+/***/ },
+/* 8 */
+/***/ function(module, exports, __webpack_require__) {
+
+ /* WEBPACK VAR INJECTION */(function(module) {'use strict';
+
+ /**
+ * Props Assignment
+ *
+ * Separate this, so react module can share the usage
+ */
+
+ var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol ? "symbol" : typeof obj; };
+
+ var DefaultProperties = {
+ // Maybe change to object-assign
+ // for now just keep it as simple
+ assign: function assign(target, opts) {
+ target = target || {};
+ opts = opts || {};
+
+ // credit card
+ target.creditCard = !!opts.creditCard;
+ target.creditCardStrictMode = !!opts.creditCardStrictMode;
+ target.creditCardType = '';
+ target.onCreditCardTypeChanged = opts.onCreditCardTypeChanged || function () {};
+
+ // phone
+ target.phone = !!opts.phone;
+ target.phoneRegionCode = opts.phoneRegionCode || 'AU';
+ target.phoneFormatter = {};
- // has ()- or space inside
- if (/[\s()-]/g.test(current)) {
- result = current;
+ // date
+ target.date = !!opts.date;
+ target.datePattern = opts.datePattern || ['d', 'm', 'Y'];
+ target.dateFormatter = {};
- validated = true;
- } else {
- if (!validated) {
- result = current;
- }
- // else: over length input
- // it turns to invalid number again
- }
- }
+ // numeral
+ target.numeral = !!opts.numeral;
+ target.numeralDecimalScale = opts.numeralDecimalScale >= 0 ? opts.numeralDecimalScale : 2;
+ target.numeralDecimalMark = opts.numeralDecimalMark || '.';
+ target.numeralThousandsGroupStyle = opts.numeralThousandsGroupStyle || 'thousand';
- // strip ()
- // e.g. US: 7161234567 returns (716) 123-4567
- result = result.replace(/[()]/g, '');
- // replace library delimiter with user customized delimiter
- result = result.replace(/[\s-]/g, owner.delimiter);
+ // others
+ target.numericOnly = target.creditCard || target.date || !!opts.numericOnly;
- return result;
- }
-};
+ target.uppercase = !!opts.uppercase;
+ target.lowercase = !!opts.lowercase;
+
+ target.prefix = target.creditCard || target.phone || target.date ? '' : opts.prefix || '';
+ target.prefixLength = target.prefix.length;
+
+ target.initValue = opts.initValue || '';
-if ((typeof module === 'undefined' ? 'undefined' : _typeof(module)) === 'object' && _typeof(module.exports) === 'object') {
- module.exports = exports = PhoneFormatter;
-}
+ target.delimiter = opts.delimiter || opts.delimiter === '' ? opts.delimiter : opts.date ? '/' : opts.numeral ? ',' : opts.phone ? ' ' : ' ';
+ target.delimiterRE = new RegExp('\\' + (target.delimiter || ' '), 'g');
+
+ target.blocks = opts.blocks || [];
+ target.blocksLength = target.blocks.length;
+
+ target.maxLength = 0;
-},{}],8:[function(require,module,exports){
-'use strict';
+ target.backspace = false;
+ target.result = '';
+
+ return target;
+ }
+ };
-var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol ? "symbol" : typeof obj; };
+ if (( false ? 'undefined' : _typeof(module)) === 'object' && _typeof(module.exports) === 'object') {
+ module.exports = exports = DefaultProperties;
+ }
+ /* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(3)(module)))
-var Util = {
- noop: function noop() {},
-
- strip: function strip(value, re) {
- return value.replace(re, '');
- },
-
- headStr: function headStr(str, length) {
- return str.slice(0, length);
- },
-
- getMaxLength: function getMaxLength(blocks) {
- return blocks.reduce(function (previous, current) {
- return previous + current;
- }, 0);
- },
-
- // strip value by prefix length
- // for prefix: PRE
- // (PRE123, 3) -> 123
- // (PR123, 3) -> 23 this happens when user hits backspace in front of "PRE"
- getPrefixStrippedValue: function getPrefixStrippedValue(value, prefixLength) {
- return value.slice(prefixLength);
- },
-
- getFormattedValue: function getFormattedValue(value, blocks, blocksLength, delimiter) {
- var result = '';
-
- blocks.forEach(function (length, index) {
- if (value.length > 0) {
- var sub = value.slice(0, length),
- rest = value.slice(length);
-
- result += sub;
-
- if (sub.length === length && index < blocksLength - 1) {
- result += delimiter;
- }
-
- // update remaining string
- value = rest;
- }
- });
-
- return result;
- }
-};
-
-if ((typeof module === 'undefined' ? 'undefined' : _typeof(module)) === 'object' && _typeof(module.exports) === 'object') {
- module.exports = exports = Util;
-}
-
-},{}]},{},[1])
-//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["node_modules/browserify/node_modules/browser-pack/_prelude.js","react.js","src/Cleave.react.js","src/common/DefaultProperties.js","src/shortcuts/CreditCardDetector.js","src/shortcuts/DateFormatter.js","src/shortcuts/NumeralFormatter.js","src/shortcuts/PhoneFormatter.js","src/utils/Util.js"],"names":[],"mappings":"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","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","import Cleave from './src/Cleave.react';\n\nexport default Cleave;\n","'use strict';\n\nvar React = require('react');\n\nvar NumeralFormatter = require('./shortcuts/NumeralFormatter');\nvar DateFormatter = require('./shortcuts/DateFormatter');\nvar PhoneFormatter = require('./shortcuts/PhoneFormatter');\nvar CreditCardDetector = require('./shortcuts/CreditCardDetector');\nvar Util = require('./utils/Util');\nvar DefaultProperties = require('./common/DefaultProperties');\n\nvar Cleave = React.createClass({\n    componentDidMount: function () {\n        this.init();\n    },\n\n    componentWillReceiveProps: function (nextProps) {\n        var owner = this,\n            phoneRegionCode = nextProps.options.phoneRegionCode,\n            newValue = nextProps.value;\n\n        if (newValue) {\n            owner.onInput(newValue);\n        }\n\n        // update phone region code\n        if (phoneRegionCode && phoneRegionCode !== owner.properties.phoneRegionCode) {\n            owner.properties.phoneRegionCode = phoneRegionCode;\n            owner.initPhoneFormatter();\n            owner.onInput(owner.properties.result);\n        }\n    },\n\n    getInitialState: function () {\n        var owner = this,\n            { value, options, onKeyDown, onChange, ...other } = owner.props;\n\n        owner.registeredEvents = {\n            onChange:  onChange || Util.noop,\n            onKeyDown: onKeyDown || Util.noop\n        };\n\n        options.initValue = value;\n\n        owner.properties = DefaultProperties.assign({}, options);\n\n        return {\n            other: other,\n            value: owner.properties.result\n        };\n    },\n\n    init: function () {\n        var owner = this,\n            pps = owner.properties;\n\n        // so no need for this lib at all\n        if (!pps.numeral && !pps.phone && !pps.creditCard && !pps.date && (pps.blocksLength === 0 && !pps.prefix)) {\n            return;\n        }\n\n        pps.maxLength = Util.getMaxLength(pps.blocks);\n\n        owner.initPhoneFormatter();\n        owner.initDateFormatter();\n        owner.initNumeralFormatter();\n\n        owner.onInput(pps.initValue);\n    },\n\n    initNumeralFormatter: function () {\n        var owner = this,\n            pps = owner.properties;\n\n        if (!pps.numeral) {\n            return;\n        }\n\n        pps.numeralFormatter = new NumeralFormatter(\n            pps.numeralDecimalMark,\n            pps.numeralDecimalScale,\n            pps.numeralThousandsGroupStyle,\n            pps.delimiter\n        );\n    },\n\n    initDateFormatter: function () {\n        var owner = this,\n            pps = owner.properties;\n\n        if (!pps.date) {\n            return;\n        }\n\n        pps.dateFormatter = new DateFormatter(pps.datePattern);\n        pps.blocks = pps.dateFormatter.getBlocks();\n        pps.blocksLength = pps.blocks.length;\n        pps.maxLength = Util.getMaxLength(pps.blocks);\n    },\n\n    initPhoneFormatter: function () {\n        var owner = this,\n            pps = owner.properties;\n\n        if (!pps.phone) {\n            return;\n        }\n\n        // Cleave.AsYouTypeFormatter should be provided by\n        // external google closure lib\n        try {\n            pps.phoneFormatter = new PhoneFormatter(\n                new window.Cleave.AsYouTypeFormatter(pps.phoneRegionCode),\n                pps.delimiter\n            );\n        } catch (ex) {\n            throw new Error('Please include phone-type-formatter.{country}.js lib');\n        }\n    },\n\n    onKeyDown: function (event) {\n        var owner = this,\n            pps = owner.properties,\n            charCode = event.which || event.keyCode;\n\n        // hit backspace when last character is delimiter\n        if (charCode === 8 && pps.result.slice(-1) === pps.delimiter) {\n            pps.backspace = true;\n        } else {\n            pps.backspace = false;\n        }\n\n        owner.registeredEvents.onKeyDown(event);\n    },\n\n    onChange: function (event) {\n        var owner = this, pps = owner.properties;\n\n        owner.onInput(event.target.value);\n\n        if (pps.numeral) {\n            event.target.rawValue = pps.numeralFormatter.getRawValue(pps.result);\n        } else {\n            event.target.rawValue = Util.strip(pps.result, pps.delimiterRE);\n        }\n\n        owner.registeredEvents.onChange(event);\n    },\n\n    onInput: function (value) {\n        var owner = this, pps = owner.properties,\n            prev = pps.result;\n\n        // case 1: delete one more character \"4\"\n        // 1234*| -> hit backspace -> 123|\n        // case 2: last character is not delimiter which is:\n        // 12|34* -> hit backspace -> 1|34*\n\n        if (!pps.numeral && pps.backspace && value.slice(-1) !== pps.delimiter) {\n            value = Util.headStr(value, value.length - 1);\n        }\n\n        // phone formatter\n        if (pps.phone) {\n            pps.result = pps.phoneFormatter.format(value);\n            owner.updateValueState();\n\n            return;\n        }\n\n        // numeral formatter\n        if (pps.numeral) {\n            pps.result = pps.prefix + pps.numeralFormatter.format(value);\n            owner.updateValueState();\n\n            return;\n        }\n\n        // date\n        if (pps.date) {\n            value = pps.dateFormatter.getValidatedDate(value);\n        }\n\n        // strip delimiters\n        value = Util.strip(value, pps.delimiterRE);\n\n        // strip prefix\n        value = Util.getPrefixStrippedValue(value, pps.prefixLength);\n\n        // strip non-numeric characters\n        value = pps.numericOnly ? Util.strip(value, /[^\\d]/g) : value;\n\n        // convert case\n        value = pps.uppercase ? value.toUpperCase() : value;\n        value = pps.lowercase ? value.toLowerCase() : value;\n\n        // prefix\n        if (pps.prefix) {\n            value = pps.prefix + value;\n\n            // no blocks specified, no need to do formatting\n            if (pps.blocksLength === 0) {\n                pps.result = value;\n                owner.updateValueState();\n\n                return;\n            }\n        }\n\n        // update credit card props\n        if (pps.creditCard) {\n            owner.updateCreditCardPropsByValue(value);\n        }\n\n        // strip over length characters\n        value = Util.headStr(value, pps.maxLength);\n\n        // apply blocks\n        pps.result = Util.getFormattedValue(value, pps.blocks, pps.blocksLength, pps.delimiter);\n\n        // nothing changed\n        // prevent update value to avoid caret position change\n        if (prev === pps.result && prev !== pps.prefix) {\n            return;\n        }\n\n        owner.updateValueState();\n    },\n\n    updateCreditCardPropsByValue: function (value) {\n        var owner = this, pps = owner.properties,\n            creditCardInfo;\n\n        // At least one of the first 4 characters has changed\n        if (Util.headStr(pps.result, 4) === Util.headStr(value, 4)) {\n            return;\n        }\n\n        creditCardInfo = CreditCardDetector.getInfo(value, pps.creditCardStrictMode);\n\n        pps.blocks = creditCardInfo.blocks;\n        pps.blocksLength = pps.blocks.length;\n        pps.maxLength = Util.getMaxLength(pps.blocks);\n\n        // credit card type changed\n        if (pps.creditCardType !== creditCardInfo.type) {\n            pps.creditCardType = creditCardInfo.type;\n\n            pps.onCreditCardTypeChanged.call(owner, pps.creditCardType);\n        }\n    },\n\n    updateValueState: function () {\n        this.setState({value: this.properties.result});\n    },\n\n    render: function () {\n        var owner = this;\n\n        return (\n            <input type=\"text\" {...owner.state.other}\n                   value={owner.state.value}\n                   onKeyDown={owner.onKeyDown}\n                   onChange={owner.onChange}/>\n        );\n    }\n});\n\nmodule.exports = window.Cleave = Cleave;\n","'use strict';\n\n/**\n * Props Assignment\n *\n * Separate this, so react module can share the usage\n */\nvar DefaultProperties = {\n    // Maybe change to object-assign\n    // for now just keep it as simple\n    assign: function (target, opts) {\n        target = target || {};\n        opts = opts || {};\n\n        // credit card\n        target.creditCard = !!opts.creditCard;\n        target.creditCardStrictMode = !!opts.creditCardStrictMode;\n        target.creditCardType = '';\n        target.onCreditCardTypeChanged = opts.onCreditCardTypeChanged || (function () {});\n\n        // phone\n        target.phone = !!opts.phone;\n        target.phoneRegionCode = opts.phoneRegionCode || 'AU';\n        target.phoneFormatter = {};\n\n        // date\n        target.date = !!opts.date;\n        target.datePattern = opts.datePattern || ['d', 'm', 'Y'];\n        target.dateFormatter = {};\n\n        // numeral\n        target.numeral = !!opts.numeral;\n        target.numeralDecimalScale = opts.numeralDecimalScale >= 0 ? opts.numeralDecimalScale : 2;\n        target.numeralDecimalMark = opts.numeralDecimalMark || '.';\n        target.numeralThousandsGroupStyle = opts.numeralThousandsGroupStyle || 'thousand';\n\n        // others\n        target.numericOnly = target.creditCard || target.date || !!opts.numericOnly;\n\n        target.uppercase = !!opts.uppercase;\n        target.lowercase = !!opts.lowercase;\n\n        target.prefix = (target.creditCard || target.phone || target.date) ? '' : (opts.prefix || '');\n        target.prefixLength = target.prefix.length;\n\n        target.initValue = opts.initValue || '';\n\n        target.delimiter =\n            (opts.delimiter || opts.delimiter === '') ? opts.delimiter :\n                (opts.date ? '/' :\n                    (opts.numeral ? ',' :\n                        (opts.phone ? ' ' :\n                            ' ')));\n        target.delimiterRE = new RegExp('\\\\' + (target.delimiter || ' '), 'g');\n\n        target.blocks = opts.blocks || [];\n        target.blocksLength = target.blocks.length;\n\n        target.maxLength = 0;\n\n        target.backspace = false;\n        target.result = '';\n\n        return target;\n    }\n};\n\nif (typeof module === 'object' && typeof module.exports === 'object') {\n    module.exports = exports = DefaultProperties;\n}\n","'use strict';\n\nvar CreditCardDetector = {\n    blocks: {\n        uatp:          [4, 5, 6],\n        amex:          [4, 6, 5],\n        diners:        [4, 6, 4],\n        discover:      [4, 4, 4, 4],\n        mastercard:    [4, 4, 4, 4],\n        dankort:       [4, 4, 4, 4],\n        instapayment:  [4, 4, 4, 4],\n        jcb:           [4, 4, 4, 4],\n        maestro:       [4, 4, 4, 4],\n        visa:          [4, 4, 4, 4],\n        generalLoose:  [4, 4, 4, 4],\n        generalStrict: [4, 4, 4, 7]\n    },\n\n    re: {\n        // starts with 1; 15 digits, not starts with 1800 (jcb card)\n        uatp: /^(?!1800)1\\d{0,14}/,\n\n        // starts with 34/37; 15 digits\n        amex: /^3[47]\\d{0,13}/,\n\n        // starts with 6011/65/644-649; 16 digits\n        discover: /^(?:6011|65\\d{0,2}|64[4-9]\\d?)\\d{0,12}/,\n\n        // starts with 300-305/309 or 36/38/39; 14 digits\n        diners: /^3(?:0([0-5]|9)|[689]\\d?)\\d{0,11}/,\n\n        // starts with 51-55/22-27; 16 digits\n        mastercard: /^(5[1-5]|2[2-7])\\d{0,14}/,\n\n        // starts with 5019/4175/4571; 16 digits\n        dankort: /^(5019|4175|4571)\\d{0,12}/,\n\n        // starts with 637-639; 16 digits\n        instapayment: /^63[7-9]\\d{0,13}/,\n\n        // starts with 2131/1800/35; 16 digits\n        jcb: /^(?:2131|1800|35\\d{0,2})\\d{0,12}/,\n\n        // starts with 50/56-58/6304/67; 16 digits\n        maestro: /^(?:5[0678]\\d{0,2}|6304|67\\d{0,2})\\d{0,12}/,\n\n        // starts with 4; 16 digits\n        visa: /^4\\d{0,15}/\n    },\n\n    getInfo: function (value, strictMode) {\n        var blocks = CreditCardDetector.blocks,\n            re = CreditCardDetector.re;\n\n        // In theory, visa credit card can have up to 19 digits number.\n        // Set strictMode to true will remove the 16 max-length restrain,\n        // however, I never found any website validate card number like\n        // this, hence probably you don't need to enable this option.\n        strictMode = !!strictMode;\n\n        if (re.amex.test(value)) {\n            return {\n                type:   'amex',\n                blocks: blocks.amex\n            };\n        } else if (re.uatp.test(value)) {\n            return {\n                type:   'uatp',\n                blocks: blocks.uatp\n            };\n        } else if (re.diners.test(value)) {\n            return {\n                type:   'diners',\n                blocks: blocks.diners\n            };\n        } else if (re.discover.test(value)) {\n            return {\n                type:   'discover',\n                blocks: blocks.discover\n            };\n        } else if (re.mastercard.test(value)) {\n            return {\n                type:   'mastercard',\n                blocks: blocks.mastercard\n            };\n        } else if (re.dankort.test(value)) {\n            return {\n                type:   'dankort',\n                blocks: blocks.dankort\n            };\n        } else if (re.instapayment.test(value)) {\n            return {\n                type:   'instapayment',\n                blocks: blocks.instapayment\n            };\n        } else if (re.jcb.test(value)) {\n            return {\n                type:   'jcb',\n                blocks: blocks.jcb\n            };\n        } else if (re.maestro.test(value)) {\n            return {\n                type:   'maestro',\n                blocks: blocks.maestro\n            };\n        } else if (re.visa.test(value)) {\n            return {\n                type:   'visa',\n                blocks: blocks.visa\n            };\n        } else if (strictMode) {\n            return {\n                type:   'unknown',\n                blocks: blocks.generalStrict\n            };\n        } else {\n            return {\n                type:   'unknown',\n                blocks: blocks.generalLoose\n            };\n        }\n    }\n};\n\nif (typeof module === 'object' && typeof module.exports === 'object') {\n    module.exports = exports = CreditCardDetector;\n}\n","'use strict';\n\nvar DateFormatter = function (datePattern) {\n    var owner = this;\n\n    owner.blocks = [];\n    owner.datePattern = datePattern;\n    owner.initBlocks();\n};\n\nDateFormatter.prototype = {\n    initBlocks: function () {\n        var owner = this;\n        owner.datePattern.forEach(function (value) {\n            if (value === 'Y') {\n                owner.blocks.push(4);\n            } else {\n                owner.blocks.push(2);\n            }\n        });\n    },\n\n    getBlocks: function () {\n        return this.blocks;\n    },\n\n    getValidatedDate: function (value) {\n        var owner = this, result = '';\n\n        value = value.replace(/[^\\d]/g, '');\n\n        owner.blocks.forEach(function (length, index) {\n            if (value.length > 0) {\n                var sub = value.slice(0, length),\n                    sub0 = sub.slice(0, 1),\n                    rest = value.slice(length);\n\n                switch (owner.datePattern[index]) {\n                case 'd':\n                    if (sub === '00') {\n                        sub = '01';\n                    } else if (parseInt(sub0, 10) > 3) {\n                        sub = '0' + sub0;\n                    } else if (parseInt(sub, 10) > 31) {\n                        sub = '31';\n                    }\n\n                    break;\n\n                case 'm':\n                    if (sub === '00') {\n                        sub = '01';\n                    } else if (parseInt(sub0, 10) > 1) {\n                        sub = '0' + sub0;\n                    } else if (parseInt(sub, 10) > 12) {\n                        sub = '12';\n                    }\n\n                    break;\n                }\n\n                result += sub;\n\n                // update remaining string\n                value = rest;\n            }\n        });\n\n        return result;\n    }\n};\n\nif (typeof module === 'object' && typeof module.exports === 'object') {\n    module.exports = exports = DateFormatter;\n}\n","'use strict';\n\nvar NumeralFormatter = function (numeralDecimalMark,\n                                 numeralDecimalScale,\n                                 numeralThousandsGroupStyle,\n                                 delimiter) {\n    var owner = this;\n\n    owner.numeralDecimalMark = numeralDecimalMark || '.';\n    owner.numeralDecimalScale = numeralDecimalScale >= 0 ? numeralDecimalScale : 2;\n    owner.numeralThousandsGroupStyle = numeralThousandsGroupStyle || NumeralFormatter.groupStyle.thousand;\n    owner.delimiter = (delimiter || delimiter === '') ? delimiter : ',';\n    owner.delimiterRE = delimiter ? new RegExp('\\\\' + delimiter, 'g') : '';\n};\n\nNumeralFormatter.groupStyle = {\n    thousand: 'thousand',\n    lakh:     'lakh',\n    wan:      'wan'\n};\n\nNumeralFormatter.prototype = {\n    getRawValue: function (value) {\n        return value.replace(this.delimiterRE, '').replace(this.numeralDecimalMark, '.');\n    },\n\n    format: function (value) {\n        var owner = this, parts, partInteger, partDecimal = '';\n\n        // strip alphabet letters\n        value = value.replace(/[A-Za-z]/g, '')\n\n            // replace the first decimal mark with reserved placeholder\n            .replace(owner.numeralDecimalMark, 'M')\n\n            // strip the non numeric letters except M\n            .replace(/[^\\dM]/g, '')\n\n            // replace mark\n            .replace('M', owner.numeralDecimalMark)\n\n            // strip leading 0\n            .replace(/^(-)?0+(?=\\d)/, '$1');\n\n        partInteger = value;\n\n        if (value.indexOf(owner.numeralDecimalMark) >= 0) {\n            parts = value.split(owner.numeralDecimalMark);\n            partInteger = parts[0];\n            partDecimal = owner.numeralDecimalMark + parts[1].slice(0, owner.numeralDecimalScale);\n        }\n\n        switch (owner.numeralThousandsGroupStyle) {\n        case NumeralFormatter.groupStyle.lakh:\n            partInteger = partInteger.replace(/(\\d)(?=(\\d\\d)+\\d$)/g, '$1' + owner.delimiter);\n\n            break;\n\n        case NumeralFormatter.groupStyle.wan:\n            partInteger = partInteger.replace(/(\\d)(?=(\\d{4})+$)/g, '$1' + owner.delimiter);\n\n            break;\n\n        default:\n            partInteger = partInteger.replace(/(\\d)(?=(\\d{3})+$)/g, '$1' + owner.delimiter);\n        }\n\n        return partInteger.toString() + (owner.numeralDecimalScale > 0 ? partDecimal.toString() : '');\n    }\n};\n\nif (typeof module === 'object' && typeof module.exports === 'object') {\n    module.exports = exports = NumeralFormatter;\n}\n","'use strict';\n\nvar PhoneFormatter = function (formatter, delimiter) {\n    var owner = this;\n\n    owner.delimiter = (delimiter || delimiter === '') ? delimiter : ' ';\n    owner.delimiterRE = delimiter ? new RegExp('\\\\' + delimiter, 'g') : '';\n\n    owner.formatter = formatter;\n};\n\nPhoneFormatter.prototype = {\n    setFormatter: function (formatter) {\n        this.formatter = formatter;\n    },\n\n    format: function (phoneNumber) {\n        var owner = this;\n\n        owner.formatter.clear();\n\n        // only keep number and +\n        phoneNumber = phoneNumber.replace(/[^\\d+]/g, '');\n\n        // strip delimiter\n        phoneNumber = phoneNumber.replace(owner.delimiterRE, '');\n\n        var result = '', current, validated = false;\n\n        for (var i = 0, iMax = phoneNumber.length; i < iMax; i++) {\n            current = owner.formatter.inputDigit(phoneNumber.charAt(i));\n\n            // has ()- or space inside\n            if (/[\\s()-]/g.test(current)) {\n                result = current;\n\n                validated = true;\n            } else {\n                if (!validated) {\n                    result = current;\n                }\n                // else: over length input\n                // it turns to invalid number again\n            }\n        }\n\n        // strip ()\n        // e.g. US: 7161234567 returns (716) 123-4567\n        result = result.replace(/[()]/g, '');\n        // replace library delimiter with user customized delimiter\n        result = result.replace(/[\\s-]/g, owner.delimiter);\n\n        return result;\n    }\n};\n\nif (typeof module === 'object' && typeof module.exports === 'object') {\n    module.exports = exports = PhoneFormatter;\n}\n","'use strict';\n\nvar Util = {\n    noop: function () {\n    },\n\n    strip: function (value, re) {\n        return value.replace(re, '');\n    },\n\n    headStr: function (str, length) {\n        return str.slice(0, length);\n    },\n\n    getMaxLength: function (blocks) {\n        return blocks.reduce(function (previous, current) {\n            return previous + current;\n        }, 0);\n    },\n\n    // strip value by prefix length\n    // for prefix: PRE\n    // (PRE123, 3) -> 123\n    // (PR123, 3) -> 23 this happens when user hits backspace in front of \"PRE\"\n    getPrefixStrippedValue: function (value, prefixLength) {\n        return value.slice(prefixLength);\n    },\n\n    getFormattedValue: function (value, blocks, blocksLength, delimiter) {\n        var result = '';\n\n        blocks.forEach(function (length, index) {\n            if (value.length > 0) {\n                var sub = value.slice(0, length),\n                    rest = value.slice(length);\n\n                result += sub;\n\n                if (sub.length === length && index < blocksLength - 1) {\n                    result += delimiter;\n                }\n\n                // update remaining string\n                value = rest;\n            }\n        });\n\n        return result;\n    }\n};\n\nif (typeof module === 'object' && typeof module.exports === 'object') {\n    module.exports = exports = Util;\n}\n"]}
+/***/ }
+/******/ ])
+});
+;
\ No newline at end of file
diff --git a/dist/cleave-react.min.js b/dist/cleave-react.min.js
index e4929734..552652fe 100644
--- a/dist/cleave-react.min.js
+++ b/dist/cleave-react.min.js
@@ -1,8 +1,8 @@
/*!
- * cleave.js - 0.5.0
+ * cleave.js - 0.5.2
* https://github.com/nosir/cleave.js
* Apache License Version 2.0
*
* Copyright (C) 2012-2016 Max Huang https://github.com/nosir/
*/
-!function e(t,r,o){function n(i,l){if(!r[i]){if(!t[i]){var s="function"==typeof require&&require;if(!l&&s)return s(i,!0);if(a)return a(i,!0);var c=new Error("Cannot find module '"+i+"'");throw c.code="MODULE_NOT_FOUND",c}var u=r[i]={exports:{}};t[i][0].call(u.exports,function(e){var r=t[i][1][e];return n(r?r:e)},u,u.exports,e,t,r,o)}return r[i].exports}for(var a="function"==typeof require&&require,i=0;i=0||Object.prototype.hasOwnProperty.call(e,o)&&(r[o]=e[o]);return r}var n=Object.assign||function(e){for(var t=1;t=0?t.numeralDecimalScale:2,e.numeralDecimalMark=t.numeralDecimalMark||".",e.numeralThousandsGroupStyle=t.numeralThousandsGroupStyle||"thousand",e.numericOnly=e.creditCard||e.date||!!t.numericOnly,e.uppercase=!!t.uppercase,e.lowercase=!!t.lowercase,e.prefix=e.creditCard||e.phone||e.date?"":t.prefix||"",e.prefixLength=e.prefix.length,e.initValue=t.initValue||"",e.delimiter=t.delimiter||""===t.delimiter?t.delimiter:t.date?"/":t.numeral?",":(t.phone," "),e.delimiterRE=new RegExp("\\"+(e.delimiter||" "),"g"),e.blocks=t.blocks||[],e.blocksLength=e.blocks.length,e.maxLength=0,e.backspace=!1,e.result="",e}};"object"===("undefined"==typeof t?"undefined":o(t))&&"object"===o(t.exports)&&(t.exports=r=n)},{}],4:[function(e,t,r){"use strict";var o="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol?"symbol":typeof e},n={blocks:{uatp:[4,5,6],amex:[4,6,5],diners:[4,6,4],discover:[4,4,4,4],mastercard:[4,4,4,4],dankort:[4,4,4,4],instapayment:[4,4,4,4],jcb:[4,4,4,4],maestro:[4,4,4,4],visa:[4,4,4,4],generalLoose:[4,4,4,4],generalStrict:[4,4,4,7]},re:{uatp:/^(?!1800)1\d{0,14}/,amex:/^3[47]\d{0,13}/,discover:/^(?:6011|65\d{0,2}|64[4-9]\d?)\d{0,12}/,diners:/^3(?:0([0-5]|9)|[689]\d?)\d{0,11}/,mastercard:/^(5[1-5]|2[2-7])\d{0,14}/,dankort:/^(5019|4175|4571)\d{0,12}/,instapayment:/^63[7-9]\d{0,13}/,jcb:/^(?:2131|1800|35\d{0,2})\d{0,12}/,maestro:/^(?:5[0678]\d{0,2}|6304|67\d{0,2})\d{0,12}/,visa:/^4\d{0,15}/},getInfo:function(e,t){var r=n.blocks,o=n.re;return t=!!t,o.amex.test(e)?{type:"amex",blocks:r.amex}:o.uatp.test(e)?{type:"uatp",blocks:r.uatp}:o.diners.test(e)?{type:"diners",blocks:r.diners}:o.discover.test(e)?{type:"discover",blocks:r.discover}:o.mastercard.test(e)?{type:"mastercard",blocks:r.mastercard}:o.dankort.test(e)?{type:"dankort",blocks:r.dankort}:o.instapayment.test(e)?{type:"instapayment",blocks:r.instapayment}:o.jcb.test(e)?{type:"jcb",blocks:r.jcb}:o.maestro.test(e)?{type:"maestro",blocks:r.maestro}:o.visa.test(e)?{type:"visa",blocks:r.visa}:t?{type:"unknown",blocks:r.generalStrict}:{type:"unknown",blocks:r.generalLoose}}};"object"===("undefined"==typeof t?"undefined":o(t))&&"object"===o(t.exports)&&(t.exports=r=n)},{}],5:[function(e,t,r){"use strict";var o="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol?"symbol":typeof e},n=function(e){var t=this;t.blocks=[],t.datePattern=e,t.initBlocks()};n.prototype={initBlocks:function(){var e=this;e.datePattern.forEach(function(t){"Y"===t?e.blocks.push(4):e.blocks.push(2)})},getBlocks:function(){return this.blocks},getValidatedDate:function(e){var t=this,r="";return e=e.replace(/[^\d]/g,""),t.blocks.forEach(function(o,n){if(e.length>0){var a=e.slice(0,o),i=a.slice(0,1),l=e.slice(o);switch(t.datePattern[n]){case"d":"00"===a?a="01":parseInt(i,10)>3?a="0"+i:parseInt(a,10)>31&&(a="31");break;case"m":"00"===a?a="01":parseInt(i,10)>1?a="0"+i:parseInt(a,10)>12&&(a="12")}r+=a,e=l}}),r}},"object"===("undefined"==typeof t?"undefined":o(t))&&"object"===o(t.exports)&&(t.exports=r=n)},{}],6:[function(e,t,r){"use strict";var o="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol?"symbol":typeof e},n=function a(e,t,r,o){var n=this;n.numeralDecimalMark=e||".",n.numeralDecimalScale=t>=0?t:2,n.numeralThousandsGroupStyle=r||a.groupStyle.thousand,n.delimiter=o||""===o?o:",",n.delimiterRE=o?new RegExp("\\"+o,"g"):""};n.groupStyle={thousand:"thousand",lakh:"lakh",wan:"wan"},n.prototype={getRawValue:function(e){return e.replace(this.delimiterRE,"").replace(this.numeralDecimalMark,".")},format:function(e){var t,r,o=this,a="";switch(e=e.replace(/[A-Za-z]/g,"").replace(o.numeralDecimalMark,"M").replace(/[^\dM]/g,"").replace("M",o.numeralDecimalMark).replace(/^(-)?0+(?=\d)/,"$1"),r=e,e.indexOf(o.numeralDecimalMark)>=0&&(t=e.split(o.numeralDecimalMark),r=t[0],a=o.numeralDecimalMark+t[1].slice(0,o.numeralDecimalScale)),o.numeralThousandsGroupStyle){case n.groupStyle.lakh:r=r.replace(/(\d)(?=(\d\d)+\d$)/g,"$1"+o.delimiter);break;case n.groupStyle.wan:r=r.replace(/(\d)(?=(\d{4})+$)/g,"$1"+o.delimiter);break;default:r=r.replace(/(\d)(?=(\d{3})+$)/g,"$1"+o.delimiter)}return r.toString()+(o.numeralDecimalScale>0?a.toString():"")}},"object"===("undefined"==typeof t?"undefined":o(t))&&"object"===o(t.exports)&&(t.exports=r=n)},{}],7:[function(e,t,r){"use strict";var o="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol?"symbol":typeof e},n=function(e,t){var r=this;r.delimiter=t||""===t?t:" ",r.delimiterRE=t?new RegExp("\\"+t,"g"):"",r.formatter=e};n.prototype={setFormatter:function(e){this.formatter=e},format:function(e){var t=this;t.formatter.clear(),e=e.replace(/[^\d+]/g,""),e=e.replace(t.delimiterRE,"");for(var r,o="",n=!1,a=0,i=e.length;i>a;a++)r=t.formatter.inputDigit(e.charAt(a)),/[\s()-]/g.test(r)?(o=r,n=!0):n||(o=r);return o=o.replace(/[()]/g,""),o=o.replace(/[\s-]/g,t.delimiter)}},"object"===("undefined"==typeof t?"undefined":o(t))&&"object"===o(t.exports)&&(t.exports=r=n)},{}],8:[function(e,t,r){"use strict";var o="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol?"symbol":typeof e},n={noop:function(){},strip:function(e,t){return e.replace(t,"")},headStr:function(e,t){return e.slice(0,t)},getMaxLength:function(e){return e.reduce(function(e,t){return e+t},0)},getPrefixStrippedValue:function(e,t){return e.slice(t)},getFormattedValue:function(e,t,r,o){var n="";return t.forEach(function(t,a){if(e.length>0){var i=e.slice(0,t),l=e.slice(t);n+=i,i.length===t&&r-1>a&&(n+=o),e=l}}),n}};"object"===("undefined"==typeof t?"undefined":o(t))&&"object"===o(t.exports)&&(t.exports=r=n)},{}]},{},[1]);
\ No newline at end of file
+!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t(require("react")):"function"==typeof define&&define.amd?define(["react"],t):"object"==typeof exports?exports.Cleave=t(require("react")):e.Cleave=t(e.React)}(this,function(e){return function(e){function t(o){if(r[o])return r[o].exports;var n=r[o]={exports:{},id:o,loaded:!1};return e[o].call(n.exports,n,n.exports,t),n.loaded=!0,n.exports}var r={};return t.m=e,t.c=r,t.p="",t(0)}([function(e,t,r){"use strict";function o(e,t){var r={};for(var o in e)t.indexOf(o)>=0||Object.prototype.hasOwnProperty.call(e,o)&&(r[o]=e[o]);return r}var n=Object.assign||function(e){for(var t=1;t=0?t:2,a.numeralThousandsGroupStyle=r||n.groupStyle.thousand,a.delimiter=o||""===o?o:",",a.delimiterRE=o?new RegExp("\\"+o,"g"):""};o.groupStyle={thousand:"thousand",lakh:"lakh",wan:"wan"},o.prototype={getRawValue:function(e){return e.replace(this.delimiterRE,"").replace(this.numeralDecimalMark,".")},format:function(e){var t,r,n=this,a="";switch(e=e.replace(/[A-Za-z]/g,"").replace(n.numeralDecimalMark,"M").replace(/[^\dM]/g,"").replace("M",n.numeralDecimalMark).replace(/^(-)?0+(?=\d)/,"$1"),r=e,e.indexOf(n.numeralDecimalMark)>=0&&(t=e.split(n.numeralDecimalMark),r=t[0],a=n.numeralDecimalMark+t[1].slice(0,n.numeralDecimalScale)),n.numeralThousandsGroupStyle){case o.groupStyle.lakh:r=r.replace(/(\d)(?=(\d\d)+\d$)/g,"$1"+n.delimiter);break;case o.groupStyle.wan:r=r.replace(/(\d)(?=(\d{4})+$)/g,"$1"+n.delimiter);break;default:r=r.replace(/(\d)(?=(\d{3})+$)/g,"$1"+n.delimiter)}return r.toString()+(n.numeralDecimalScale>0?a.toString():"")}},"object"===r(e)&&"object"===r(e.exports)&&(e.exports=t=o)}).call(t,r(3)(e))},function(e,t){e.exports=function(e){return e.webpackPolyfill||(e.deprecate=function(){},e.paths=[],e.children=[],e.webpackPolyfill=1),e}},function(e,t,r){(function(e){"use strict";var r="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol?"symbol":typeof e},o=function(e){var t=this;t.blocks=[],t.datePattern=e,t.initBlocks()};o.prototype={initBlocks:function(){var e=this;e.datePattern.forEach(function(t){"Y"===t?e.blocks.push(4):e.blocks.push(2)})},getBlocks:function(){return this.blocks},getValidatedDate:function(e){var t=this,r="";return e=e.replace(/[^\d]/g,""),t.blocks.forEach(function(o,n){if(e.length>0){var a=e.slice(0,o),i=a.slice(0,1),l=e.slice(o);switch(t.datePattern[n]){case"d":"00"===a?a="01":parseInt(i,10)>3?a="0"+i:parseInt(a,10)>31&&(a="31");break;case"m":"00"===a?a="01":parseInt(i,10)>1?a="0"+i:parseInt(a,10)>12&&(a="12")}r+=a,e=l}}),r}},"object"===r(e)&&"object"===r(e.exports)&&(e.exports=t=o)}).call(t,r(3)(e))},function(e,t,r){(function(e){"use strict";var r="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol?"symbol":typeof e},o=function(e,t){var r=this;r.delimiter=t||""===t?t:" ",r.delimiterRE=t?new RegExp("\\"+t,"g"):"",r.formatter=e};o.prototype={setFormatter:function(e){this.formatter=e},format:function(e){var t=this;t.formatter.clear(),e=e.replace(/[^\d+]/g,""),e=e.replace(t.delimiterRE,"");for(var r,o="",n=!1,a=0,i=e.length;i>a;a++)r=t.formatter.inputDigit(e.charAt(a)),/[\s()-]/g.test(r)?(o=r,n=!0):n||(o=r);return o=o.replace(/[()]/g,""),o=o.replace(/[\s-]/g,t.delimiter)}},"object"===r(e)&&"object"===r(e.exports)&&(e.exports=t=o)}).call(t,r(3)(e))},function(e,t,r){(function(e){"use strict";var r="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol?"symbol":typeof e},o={blocks:{uatp:[4,5,6],amex:[4,6,5],diners:[4,6,4],discover:[4,4,4,4],mastercard:[4,4,4,4],dankort:[4,4,4,4],instapayment:[4,4,4,4],jcb:[4,4,4,4],maestro:[4,4,4,4],visa:[4,4,4,4],generalLoose:[4,4,4,4],generalStrict:[4,4,4,7]},re:{uatp:/^(?!1800)1\d{0,14}/,amex:/^3[47]\d{0,13}/,discover:/^(?:6011|65\d{0,2}|64[4-9]\d?)\d{0,12}/,diners:/^3(?:0([0-5]|9)|[689]\d?)\d{0,11}/,mastercard:/^(5[1-5]|2[2-7])\d{0,14}/,dankort:/^(5019|4175|4571)\d{0,12}/,instapayment:/^63[7-9]\d{0,13}/,jcb:/^(?:2131|1800|35\d{0,2})\d{0,12}/,maestro:/^(?:5[0678]\d{0,2}|6304|67\d{0,2})\d{0,12}/,visa:/^4\d{0,15}/},getInfo:function(e,t){var r=o.blocks,n=o.re;return t=!!t,n.amex.test(e)?{type:"amex",blocks:r.amex}:n.uatp.test(e)?{type:"uatp",blocks:r.uatp}:n.diners.test(e)?{type:"diners",blocks:r.diners}:n.discover.test(e)?{type:"discover",blocks:r.discover}:n.mastercard.test(e)?{type:"mastercard",blocks:r.mastercard}:n.dankort.test(e)?{type:"dankort",blocks:r.dankort}:n.instapayment.test(e)?{type:"instapayment",blocks:r.instapayment}:n.jcb.test(e)?{type:"jcb",blocks:r.jcb}:n.maestro.test(e)?{type:"maestro",blocks:r.maestro}:n.visa.test(e)?{type:"visa",blocks:r.visa}:t?{type:"unknown",blocks:r.generalStrict}:{type:"unknown",blocks:r.generalLoose}}};"object"===r(e)&&"object"===r(e.exports)&&(e.exports=t=o)}).call(t,r(3)(e))},function(e,t,r){(function(e){"use strict";var r="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol?"symbol":typeof e},o={noop:function(){},strip:function(e,t){return e.replace(t,"")},headStr:function(e,t){return e.slice(0,t)},getMaxLength:function(e){return e.reduce(function(e,t){return e+t},0)},getPrefixStrippedValue:function(e,t){return e.slice(t)},getFormattedValue:function(e,t,r,o){var n="";return t.forEach(function(t,a){if(e.length>0){var i=e.slice(0,t),l=e.slice(t);n+=i,i.length===t&&r-1>a&&(n+=o),e=l}}),n}};"object"===r(e)&&"object"===r(e.exports)&&(e.exports=t=o)}).call(t,r(3)(e))},function(e,t,r){(function(e){"use strict";var r="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol?"symbol":typeof e},o={assign:function(e,t){return e=e||{},t=t||{},e.creditCard=!!t.creditCard,e.creditCardStrictMode=!!t.creditCardStrictMode,e.creditCardType="",e.onCreditCardTypeChanged=t.onCreditCardTypeChanged||function(){},e.phone=!!t.phone,e.phoneRegionCode=t.phoneRegionCode||"AU",e.phoneFormatter={},e.date=!!t.date,e.datePattern=t.datePattern||["d","m","Y"],e.dateFormatter={},e.numeral=!!t.numeral,e.numeralDecimalScale=t.numeralDecimalScale>=0?t.numeralDecimalScale:2,e.numeralDecimalMark=t.numeralDecimalMark||".",e.numeralThousandsGroupStyle=t.numeralThousandsGroupStyle||"thousand",e.numericOnly=e.creditCard||e.date||!!t.numericOnly,e.uppercase=!!t.uppercase,e.lowercase=!!t.lowercase,e.prefix=e.creditCard||e.phone||e.date?"":t.prefix||"",e.prefixLength=e.prefix.length,e.initValue=t.initValue||"",e.delimiter=t.delimiter||""===t.delimiter?t.delimiter:t.date?"/":t.numeral?",":(t.phone," "),e.delimiterRE=new RegExp("\\"+(e.delimiter||" "),"g"),e.blocks=t.blocks||[],e.blocksLength=e.blocks.length,e.maxLength=0,e.backspace=!1,e.result="",e}};"object"===r(e)&&"object"===r(e.exports)&&(e.exports=t=o)}).call(t,r(3)(e))}])});
\ No newline at end of file
diff --git a/dist/cleave-react.webpack.js b/dist/cleave-react.webpack.js
deleted file mode 100644
index 446ca324..00000000
--- a/dist/cleave-react.webpack.js
+++ /dev/null
@@ -1,862 +0,0 @@
-(function webpackUniversalModuleDefinition(root, factory) {
- if(typeof exports === 'object' && typeof module === 'object')
- module.exports = factory(require("react"));
- else if(typeof define === 'function' && define.amd)
- define(["react"], factory);
- else if(typeof exports === 'object')
- exports["Cleave"] = factory(require("react"));
- else
- root["Cleave"] = factory(root["React"]);
-})(this, function(__WEBPACK_EXTERNAL_MODULE_1__) {
-return /******/ (function(modules) { // webpackBootstrap
-/******/ // The module cache
-/******/ var installedModules = {};
-
-/******/ // The require function
-/******/ function __webpack_require__(moduleId) {
-
-/******/ // Check if module is in cache
-/******/ if(installedModules[moduleId])
-/******/ return installedModules[moduleId].exports;
-
-/******/ // Create a new module (and put it into the cache)
-/******/ var module = installedModules[moduleId] = {
-/******/ exports: {},
-/******/ id: moduleId,
-/******/ loaded: false
-/******/ };
-
-/******/ // Execute the module function
-/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
-
-/******/ // Flag the module as loaded
-/******/ module.loaded = true;
-
-/******/ // Return the exports of the module
-/******/ return module.exports;
-/******/ }
-
-
-/******/ // expose the modules object (__webpack_modules__)
-/******/ __webpack_require__.m = modules;
-
-/******/ // expose the module cache
-/******/ __webpack_require__.c = installedModules;
-
-/******/ // __webpack_public_path__
-/******/ __webpack_require__.p = "";
-
-/******/ // Load entry module and return exports
-/******/ return __webpack_require__(0);
-/******/ })
-/************************************************************************/
-/******/ ([
-/* 0 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
-
- function _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }
-
- var React = __webpack_require__(1);
-
- var NumeralFormatter = __webpack_require__(2);
- var DateFormatter = __webpack_require__(4);
- var PhoneFormatter = __webpack_require__(5);
- var CreditCardDetector = __webpack_require__(6);
- var Util = __webpack_require__(7);
- var DefaultProperties = __webpack_require__(8);
-
- var Cleave = React.createClass({
- displayName: 'Cleave',
-
- componentDidMount: function componentDidMount() {
- this.init();
- },
-
- componentWillReceiveProps: function componentWillReceiveProps(nextProps) {
- var owner = this,
- phoneRegionCode = nextProps.options.phoneRegionCode,
- newValue = nextProps.value;
-
- if (newValue) {
- owner.onInput(newValue);
- }
-
- // update phone region code
- if (phoneRegionCode && phoneRegionCode !== owner.properties.phoneRegionCode) {
- owner.properties.phoneRegionCode = phoneRegionCode;
- owner.initPhoneFormatter();
- owner.onInput(owner.properties.result);
- }
- },
-
- getInitialState: function getInitialState() {
- var owner = this;
- var _owner$props = owner.props;
- var value = _owner$props.value;
- var options = _owner$props.options;
- var onKeyDown = _owner$props.onKeyDown;
- var onChange = _owner$props.onChange;
-
- var other = _objectWithoutProperties(_owner$props, ['value', 'options', 'onKeyDown', 'onChange']);
-
- owner.registeredEvents = {
- onChange: onChange || Util.noop,
- onKeyDown: onKeyDown || Util.noop
- };
-
- options.initValue = value;
-
- owner.properties = DefaultProperties.assign({}, options);
-
- return {
- other: other,
- value: owner.properties.result
- };
- },
-
- init: function init() {
- var owner = this,
- pps = owner.properties;
-
- // so no need for this lib at all
- if (!pps.numeral && !pps.phone && !pps.creditCard && !pps.date && pps.blocksLength === 0 && !pps.prefix) {
- return;
- }
-
- pps.maxLength = Util.getMaxLength(pps.blocks);
-
- owner.initPhoneFormatter();
- owner.initDateFormatter();
- owner.initNumeralFormatter();
-
- owner.onInput(pps.initValue);
- },
-
- initNumeralFormatter: function initNumeralFormatter() {
- var owner = this,
- pps = owner.properties;
-
- if (!pps.numeral) {
- return;
- }
-
- pps.numeralFormatter = new NumeralFormatter(pps.numeralDecimalMark, pps.numeralDecimalScale, pps.numeralThousandsGroupStyle, pps.delimiter);
- },
-
- initDateFormatter: function initDateFormatter() {
- var owner = this,
- pps = owner.properties;
-
- if (!pps.date) {
- return;
- }
-
- pps.dateFormatter = new DateFormatter(pps.datePattern);
- pps.blocks = pps.dateFormatter.getBlocks();
- pps.blocksLength = pps.blocks.length;
- pps.maxLength = Util.getMaxLength(pps.blocks);
- },
-
- initPhoneFormatter: function initPhoneFormatter() {
- var owner = this,
- pps = owner.properties;
-
- if (!pps.phone) {
- return;
- }
-
- // Cleave.AsYouTypeFormatter should be provided by
- // external google closure lib
- try {
- pps.phoneFormatter = new PhoneFormatter(new window.Cleave.AsYouTypeFormatter(pps.phoneRegionCode), pps.delimiter);
- } catch (ex) {
- throw new Error('Please include phone-type-formatter.{country}.js lib');
- }
- },
-
- onKeyDown: function onKeyDown(event) {
- var owner = this,
- pps = owner.properties,
- charCode = event.which || event.keyCode;
-
- // hit backspace when last character is delimiter
- if (charCode === 8 && pps.result.slice(-1) === pps.delimiter) {
- pps.backspace = true;
- } else {
- pps.backspace = false;
- }
-
- owner.registeredEvents.onKeyDown(event);
- },
-
- onChange: function onChange(event) {
- var owner = this,
- pps = owner.properties;
-
- owner.onInput(event.target.value);
-
- if (pps.numeral) {
- event.target.rawValue = pps.numeralFormatter.getRawValue(pps.result);
- } else {
- event.target.rawValue = Util.strip(pps.result, pps.delimiterRE);
- }
-
- owner.registeredEvents.onChange(event);
- },
-
- onInput: function onInput(value) {
- var owner = this,
- pps = owner.properties,
- prev = pps.result;
-
- // case 1: delete one more character "4"
- // 1234*| -> hit backspace -> 123|
- // case 2: last character is not delimiter which is:
- // 12|34* -> hit backspace -> 1|34*
-
- if (!pps.numeral && pps.backspace && value.slice(-1) !== pps.delimiter) {
- value = Util.headStr(value, value.length - 1);
- }
-
- // phone formatter
- if (pps.phone) {
- pps.result = pps.phoneFormatter.format(value);
- owner.updateValueState();
-
- return;
- }
-
- // numeral formatter
- if (pps.numeral) {
- pps.result = pps.prefix + pps.numeralFormatter.format(value);
- owner.updateValueState();
-
- return;
- }
-
- // date
- if (pps.date) {
- value = pps.dateFormatter.getValidatedDate(value);
- }
-
- // strip delimiters
- value = Util.strip(value, pps.delimiterRE);
-
- // strip prefix
- value = Util.getPrefixStrippedValue(value, pps.prefixLength);
-
- // strip non-numeric characters
- value = pps.numericOnly ? Util.strip(value, /[^\d]/g) : value;
-
- // convert case
- value = pps.uppercase ? value.toUpperCase() : value;
- value = pps.lowercase ? value.toLowerCase() : value;
-
- // prefix
- if (pps.prefix) {
- value = pps.prefix + value;
-
- // no blocks specified, no need to do formatting
- if (pps.blocksLength === 0) {
- pps.result = value;
- owner.updateValueState();
-
- return;
- }
- }
-
- // update credit card props
- if (pps.creditCard) {
- owner.updateCreditCardPropsByValue(value);
- }
-
- // strip over length characters
- value = Util.headStr(value, pps.maxLength);
-
- // apply blocks
- pps.result = Util.getFormattedValue(value, pps.blocks, pps.blocksLength, pps.delimiter);
-
- // nothing changed
- // prevent update value to avoid caret position change
- if (prev === pps.result && prev !== pps.prefix) {
- return;
- }
-
- owner.updateValueState();
- },
-
- updateCreditCardPropsByValue: function updateCreditCardPropsByValue(value) {
- var owner = this,
- pps = owner.properties,
- creditCardInfo;
-
- // At least one of the first 4 characters has changed
- if (Util.headStr(pps.result, 4) === Util.headStr(value, 4)) {
- return;
- }
-
- creditCardInfo = CreditCardDetector.getInfo(value, pps.creditCardStrictMode);
-
- pps.blocks = creditCardInfo.blocks;
- pps.blocksLength = pps.blocks.length;
- pps.maxLength = Util.getMaxLength(pps.blocks);
-
- // credit card type changed
- if (pps.creditCardType !== creditCardInfo.type) {
- pps.creditCardType = creditCardInfo.type;
-
- pps.onCreditCardTypeChanged.call(owner, pps.creditCardType);
- }
- },
-
- updateValueState: function updateValueState() {
- this.setState({ value: this.properties.result });
- },
-
- render: function render() {
- var owner = this;
-
- return React.createElement('input', _extends({ type: 'text' }, owner.state.other, {
- value: owner.state.value,
- onKeyDown: owner.onKeyDown,
- onChange: owner.onChange }));
- }
- });
-
- module.exports = window.Cleave = Cleave;
-
-/***/ },
-/* 1 */
-/***/ function(module, exports) {
-
- module.exports = __WEBPACK_EXTERNAL_MODULE_1__;
-
-/***/ },
-/* 2 */
-/***/ function(module, exports, __webpack_require__) {
-
- /* WEBPACK VAR INJECTION */(function(module) {'use strict';
-
- var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol ? "symbol" : typeof obj; };
-
- var NumeralFormatter = function NumeralFormatter(numeralDecimalMark, numeralDecimalScale, numeralThousandsGroupStyle, delimiter) {
- var owner = this;
-
- owner.numeralDecimalMark = numeralDecimalMark || '.';
- owner.numeralDecimalScale = numeralDecimalScale >= 0 ? numeralDecimalScale : 2;
- owner.numeralThousandsGroupStyle = numeralThousandsGroupStyle || NumeralFormatter.groupStyle.thousand;
- owner.delimiter = delimiter || delimiter === '' ? delimiter : ',';
- owner.delimiterRE = delimiter ? new RegExp('\\' + delimiter, 'g') : '';
- };
-
- NumeralFormatter.groupStyle = {
- thousand: 'thousand',
- lakh: 'lakh',
- wan: 'wan'
- };
-
- NumeralFormatter.prototype = {
- getRawValue: function getRawValue(value) {
- return value.replace(this.delimiterRE, '').replace(this.numeralDecimalMark, '.');
- },
-
- format: function format(value) {
- var owner = this,
- parts,
- partInteger,
- partDecimal = '';
-
- // strip alphabet letters
- value = value.replace(/[A-Za-z]/g, '')
-
- // replace the first decimal mark with reserved placeholder
- .replace(owner.numeralDecimalMark, 'M')
-
- // strip the non numeric letters except M
- .replace(/[^\dM]/g, '')
-
- // replace mark
- .replace('M', owner.numeralDecimalMark)
-
- // strip leading 0
- .replace(/^(-)?0+(?=\d)/, '$1');
-
- partInteger = value;
-
- if (value.indexOf(owner.numeralDecimalMark) >= 0) {
- parts = value.split(owner.numeralDecimalMark);
- partInteger = parts[0];
- partDecimal = owner.numeralDecimalMark + parts[1].slice(0, owner.numeralDecimalScale);
- }
-
- switch (owner.numeralThousandsGroupStyle) {
- case NumeralFormatter.groupStyle.lakh:
- partInteger = partInteger.replace(/(\d)(?=(\d\d)+\d$)/g, '$1' + owner.delimiter);
-
- break;
-
- case NumeralFormatter.groupStyle.wan:
- partInteger = partInteger.replace(/(\d)(?=(\d{4})+$)/g, '$1' + owner.delimiter);
-
- break;
-
- default:
- partInteger = partInteger.replace(/(\d)(?=(\d{3})+$)/g, '$1' + owner.delimiter);
- }
-
- return partInteger.toString() + (owner.numeralDecimalScale > 0 ? partDecimal.toString() : '');
- }
- };
-
- if (( false ? 'undefined' : _typeof(module)) === 'object' && _typeof(module.exports) === 'object') {
- module.exports = exports = NumeralFormatter;
- }
- /* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(3)(module)))
-
-/***/ },
-/* 3 */
-/***/ function(module, exports) {
-
- module.exports = function(module) {
- if(!module.webpackPolyfill) {
- module.deprecate = function() {};
- module.paths = [];
- // module.parent = undefined by default
- module.children = [];
- module.webpackPolyfill = 1;
- }
- return module;
- }
-
-
-/***/ },
-/* 4 */
-/***/ function(module, exports, __webpack_require__) {
-
- /* WEBPACK VAR INJECTION */(function(module) {'use strict';
-
- var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol ? "symbol" : typeof obj; };
-
- var DateFormatter = function DateFormatter(datePattern) {
- var owner = this;
-
- owner.blocks = [];
- owner.datePattern = datePattern;
- owner.initBlocks();
- };
-
- DateFormatter.prototype = {
- initBlocks: function initBlocks() {
- var owner = this;
- owner.datePattern.forEach(function (value) {
- if (value === 'Y') {
- owner.blocks.push(4);
- } else {
- owner.blocks.push(2);
- }
- });
- },
-
- getBlocks: function getBlocks() {
- return this.blocks;
- },
-
- getValidatedDate: function getValidatedDate(value) {
- var owner = this,
- result = '';
-
- value = value.replace(/[^\d]/g, '');
-
- owner.blocks.forEach(function (length, index) {
- if (value.length > 0) {
- var sub = value.slice(0, length),
- sub0 = sub.slice(0, 1),
- rest = value.slice(length);
-
- switch (owner.datePattern[index]) {
- case 'd':
- if (sub === '00') {
- sub = '01';
- } else if (parseInt(sub0, 10) > 3) {
- sub = '0' + sub0;
- } else if (parseInt(sub, 10) > 31) {
- sub = '31';
- }
-
- break;
-
- case 'm':
- if (sub === '00') {
- sub = '01';
- } else if (parseInt(sub0, 10) > 1) {
- sub = '0' + sub0;
- } else if (parseInt(sub, 10) > 12) {
- sub = '12';
- }
-
- break;
- }
-
- result += sub;
-
- // update remaining string
- value = rest;
- }
- });
-
- return result;
- }
- };
-
- if (( false ? 'undefined' : _typeof(module)) === 'object' && _typeof(module.exports) === 'object') {
- module.exports = exports = DateFormatter;
- }
- /* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(3)(module)))
-
-/***/ },
-/* 5 */
-/***/ function(module, exports, __webpack_require__) {
-
- /* WEBPACK VAR INJECTION */(function(module) {'use strict';
-
- var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol ? "symbol" : typeof obj; };
-
- var PhoneFormatter = function PhoneFormatter(formatter, delimiter) {
- var owner = this;
-
- owner.delimiter = delimiter || delimiter === '' ? delimiter : ' ';
- owner.delimiterRE = delimiter ? new RegExp('\\' + delimiter, 'g') : '';
-
- owner.formatter = formatter;
- };
-
- PhoneFormatter.prototype = {
- setFormatter: function setFormatter(formatter) {
- this.formatter = formatter;
- },
-
- format: function format(phoneNumber) {
- var owner = this;
-
- owner.formatter.clear();
-
- // only keep number and +
- phoneNumber = phoneNumber.replace(/[^\d+]/g, '');
-
- // strip delimiter
- phoneNumber = phoneNumber.replace(owner.delimiterRE, '');
-
- var result = '',
- current,
- validated = false;
-
- for (var i = 0, iMax = phoneNumber.length; i < iMax; i++) {
- current = owner.formatter.inputDigit(phoneNumber.charAt(i));
-
- // has ()- or space inside
- if (/[\s()-]/g.test(current)) {
- result = current;
-
- validated = true;
- } else {
- if (!validated) {
- result = current;
- }
- // else: over length input
- // it turns to invalid number again
- }
- }
-
- // strip ()
- // e.g. US: 7161234567 returns (716) 123-4567
- result = result.replace(/[()]/g, '');
- // replace library delimiter with user customized delimiter
- result = result.replace(/[\s-]/g, owner.delimiter);
-
- return result;
- }
- };
-
- if (( false ? 'undefined' : _typeof(module)) === 'object' && _typeof(module.exports) === 'object') {
- module.exports = exports = PhoneFormatter;
- }
- /* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(3)(module)))
-
-/***/ },
-/* 6 */
-/***/ function(module, exports, __webpack_require__) {
-
- /* WEBPACK VAR INJECTION */(function(module) {'use strict';
-
- var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol ? "symbol" : typeof obj; };
-
- var CreditCardDetector = {
- blocks: {
- uatp: [4, 5, 6],
- amex: [4, 6, 5],
- diners: [4, 6, 4],
- discover: [4, 4, 4, 4],
- mastercard: [4, 4, 4, 4],
- dankort: [4, 4, 4, 4],
- instapayment: [4, 4, 4, 4],
- jcb: [4, 4, 4, 4],
- maestro: [4, 4, 4, 4],
- visa: [4, 4, 4, 4],
- generalLoose: [4, 4, 4, 4],
- generalStrict: [4, 4, 4, 7]
- },
-
- re: {
- // starts with 1; 15 digits, not starts with 1800 (jcb card)
- uatp: /^(?!1800)1\d{0,14}/,
-
- // starts with 34/37; 15 digits
- amex: /^3[47]\d{0,13}/,
-
- // starts with 6011/65/644-649; 16 digits
- discover: /^(?:6011|65\d{0,2}|64[4-9]\d?)\d{0,12}/,
-
- // starts with 300-305/309 or 36/38/39; 14 digits
- diners: /^3(?:0([0-5]|9)|[689]\d?)\d{0,11}/,
-
- // starts with 51-55/22-27; 16 digits
- mastercard: /^(5[1-5]|2[2-7])\d{0,14}/,
-
- // starts with 5019/4175/4571; 16 digits
- dankort: /^(5019|4175|4571)\d{0,12}/,
-
- // starts with 637-639; 16 digits
- instapayment: /^63[7-9]\d{0,13}/,
-
- // starts with 2131/1800/35; 16 digits
- jcb: /^(?:2131|1800|35\d{0,2})\d{0,12}/,
-
- // starts with 50/56-58/6304/67; 16 digits
- maestro: /^(?:5[0678]\d{0,2}|6304|67\d{0,2})\d{0,12}/,
-
- // starts with 4; 16 digits
- visa: /^4\d{0,15}/
- },
-
- getInfo: function getInfo(value, strictMode) {
- var blocks = CreditCardDetector.blocks,
- re = CreditCardDetector.re;
-
- // In theory, visa credit card can have up to 19 digits number.
- // Set strictMode to true will remove the 16 max-length restrain,
- // however, I never found any website validate card number like
- // this, hence probably you don't need to enable this option.
- strictMode = !!strictMode;
-
- if (re.amex.test(value)) {
- return {
- type: 'amex',
- blocks: blocks.amex
- };
- } else if (re.uatp.test(value)) {
- return {
- type: 'uatp',
- blocks: blocks.uatp
- };
- } else if (re.diners.test(value)) {
- return {
- type: 'diners',
- blocks: blocks.diners
- };
- } else if (re.discover.test(value)) {
- return {
- type: 'discover',
- blocks: blocks.discover
- };
- } else if (re.mastercard.test(value)) {
- return {
- type: 'mastercard',
- blocks: blocks.mastercard
- };
- } else if (re.dankort.test(value)) {
- return {
- type: 'dankort',
- blocks: blocks.dankort
- };
- } else if (re.instapayment.test(value)) {
- return {
- type: 'instapayment',
- blocks: blocks.instapayment
- };
- } else if (re.jcb.test(value)) {
- return {
- type: 'jcb',
- blocks: blocks.jcb
- };
- } else if (re.maestro.test(value)) {
- return {
- type: 'maestro',
- blocks: blocks.maestro
- };
- } else if (re.visa.test(value)) {
- return {
- type: 'visa',
- blocks: blocks.visa
- };
- } else if (strictMode) {
- return {
- type: 'unknown',
- blocks: blocks.generalStrict
- };
- } else {
- return {
- type: 'unknown',
- blocks: blocks.generalLoose
- };
- }
- }
- };
-
- if (( false ? 'undefined' : _typeof(module)) === 'object' && _typeof(module.exports) === 'object') {
- module.exports = exports = CreditCardDetector;
- }
- /* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(3)(module)))
-
-/***/ },
-/* 7 */
-/***/ function(module, exports, __webpack_require__) {
-
- /* WEBPACK VAR INJECTION */(function(module) {'use strict';
-
- var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol ? "symbol" : typeof obj; };
-
- var Util = {
- noop: function noop() {},
-
- strip: function strip(value, re) {
- return value.replace(re, '');
- },
-
- headStr: function headStr(str, length) {
- return str.slice(0, length);
- },
-
- getMaxLength: function getMaxLength(blocks) {
- return blocks.reduce(function (previous, current) {
- return previous + current;
- }, 0);
- },
-
- // strip value by prefix length
- // for prefix: PRE
- // (PRE123, 3) -> 123
- // (PR123, 3) -> 23 this happens when user hits backspace in front of "PRE"
- getPrefixStrippedValue: function getPrefixStrippedValue(value, prefixLength) {
- return value.slice(prefixLength);
- },
-
- getFormattedValue: function getFormattedValue(value, blocks, blocksLength, delimiter) {
- var result = '';
-
- blocks.forEach(function (length, index) {
- if (value.length > 0) {
- var sub = value.slice(0, length),
- rest = value.slice(length);
-
- result += sub;
-
- if (sub.length === length && index < blocksLength - 1) {
- result += delimiter;
- }
-
- // update remaining string
- value = rest;
- }
- });
-
- return result;
- }
- };
-
- if (( false ? 'undefined' : _typeof(module)) === 'object' && _typeof(module.exports) === 'object') {
- module.exports = exports = Util;
- }
- /* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(3)(module)))
-
-/***/ },
-/* 8 */
-/***/ function(module, exports, __webpack_require__) {
-
- /* WEBPACK VAR INJECTION */(function(module) {'use strict';
-
- /**
- * Props Assignment
- *
- * Separate this, so react module can share the usage
- */
-
- var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol ? "symbol" : typeof obj; };
-
- var DefaultProperties = {
- // Maybe change to object-assign
- // for now just keep it as simple
- assign: function assign(target, opts) {
- target = target || {};
- opts = opts || {};
-
- // credit card
- target.creditCard = !!opts.creditCard;
- target.creditCardStrictMode = !!opts.creditCardStrictMode;
- target.creditCardType = '';
- target.onCreditCardTypeChanged = opts.onCreditCardTypeChanged || function () {};
-
- // phone
- target.phone = !!opts.phone;
- target.phoneRegionCode = opts.phoneRegionCode || 'AU';
- target.phoneFormatter = {};
-
- // date
- target.date = !!opts.date;
- target.datePattern = opts.datePattern || ['d', 'm', 'Y'];
- target.dateFormatter = {};
-
- // numeral
- target.numeral = !!opts.numeral;
- target.numeralDecimalScale = opts.numeralDecimalScale >= 0 ? opts.numeralDecimalScale : 2;
- target.numeralDecimalMark = opts.numeralDecimalMark || '.';
- target.numeralThousandsGroupStyle = opts.numeralThousandsGroupStyle || 'thousand';
-
- // others
- target.numericOnly = target.creditCard || target.date || !!opts.numericOnly;
-
- target.uppercase = !!opts.uppercase;
- target.lowercase = !!opts.lowercase;
-
- target.prefix = target.creditCard || target.phone || target.date ? '' : opts.prefix || '';
- target.prefixLength = target.prefix.length;
-
- target.initValue = opts.initValue || '';
-
- target.delimiter = opts.delimiter || opts.delimiter === '' ? opts.delimiter : opts.date ? '/' : opts.numeral ? ',' : opts.phone ? ' ' : ' ';
- target.delimiterRE = new RegExp('\\' + (target.delimiter || ' '), 'g');
-
- target.blocks = opts.blocks || [];
- target.blocksLength = target.blocks.length;
-
- target.maxLength = 0;
-
- target.backspace = false;
- target.result = '';
-
- return target;
- }
- };
-
- if (( false ? 'undefined' : _typeof(module)) === 'object' && _typeof(module.exports) === 'object') {
- module.exports = exports = DefaultProperties;
- }
- /* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(3)(module)))
-
-/***/ }
-/******/ ])
-});
-;
\ No newline at end of file
diff --git a/dist/cleave.min.js b/dist/cleave.min.js
index ff151fae..0ed68a00 100644
--- a/dist/cleave.min.js
+++ b/dist/cleave.min.js
@@ -1,5 +1,5 @@
/*!
- * cleave.js - 0.5.0
+ * cleave.js - 0.5.2
* https://github.com/nosir/cleave.js
* Apache License Version 2.0
*
diff --git a/doc/reactjs-component-usage.md b/doc/reactjs-component-usage.md
index 0e2a33ea..d62f799b 100644
--- a/doc/reactjs-component-usage.md
+++ b/doc/reactjs-component-usage.md
@@ -6,21 +6,31 @@
- [React JSFiddle](https://jsfiddle.net/nosir/gLLsrxxf/)
-## Usage
-
-### Babel compiler
+## Babel usage
Cleave.js uses ES6 spread / rest feature, and we recommend using Babel compiler to transfer ES6 code.
-However, if your project doesn't support it, you can still refer to the [legacy way](#legacy-way).
+However, if for some reason you would like to just refer to the final bundled script, check the [legacy way](#legacy-way).
-First install babel presets:
+First, install babel presets:
```bash
npm install --save babel-preset-es2015 babel-preset-react babel-preset-stage-0
```
-And in `.babelrc`:
+For `Browserify`, also do:
+
+```bash
+npm install --save babelify
+```
+
+For `Webpack`, also do:
+
+```bask
+npm install --save babel-core babel-loader
+```
+
+Second, add `.babelrc` to your project root:
```json
{
@@ -93,15 +103,45 @@ class MyComponent extends React.Component {
ReactDOM.render(, document.getElementById('content'));
```
-### Legacy way
+### Webpack and Browserify config
-If your project doesn't support ES6 compiling, just include cleave.js like this. It will expose `Cleave` variable to global:
+#### Webpack
```js
-var React = require('...');
+loaders: [
+ {
+ test: ...,
+ exclude: /node_modules\/(?!cleave.js)/,
+ loader: 'babel',
+ query: {
+ presets: ['es2015', 'react', 'stage-0']
+ }
+ }
+]
+```
+
+#### Browserify
-require('cleave.js/dist/cleave-react');
-require('cleave.js/dist/addons/cleave-phone.{country}.js');
+```js
+browserify(...).transform('babelify', {presets: ['es2015', 'react', 'stage-0']})...
+```
+
+## Legacy way
+
+If for some reason you would like to just refer to the final bundled script (e.g. your project doesn't support ES6 compiling), you can include cleave.js like this.
+
+It will also expose `Cleave` variable to global:
+
+```js
+import Cleave from 'cleave.js/dist/cleave-react';
+import CleavePhone from 'cleave.js/dist/addons/cleave-phone.{country}';
+```
+
+or
+
+```js
+var Cleave = require('cleave.js/dist/cleave-react');
+var CleavePhone = require('cleave.js/dist/addons/cleave-phone.{country}');
```
And define the component:
@@ -126,7 +166,7 @@ var MyComponent = React.createClass({
});
```
-### Shim
+## Shim
Alternatively you can shim `Cleave.js` module. In your html:
diff --git a/gulp-tasks/browserify.js b/gulp-tasks/browserify.js
index 404e7ad4..d68d3b29 100644
--- a/gulp-tasks/browserify.js
+++ b/gulp-tasks/browserify.js
@@ -50,9 +50,22 @@ gulp.task('js:react:watch', function () {
return w;
});
-gulp.task('js:react', function () {
- options.entries = [path.join(paths.root, entry)];
- options.plugin = [errorify];
-
- return bundle(browserify(options), entry);
-});
+/**
+ * This task is replaced by webpack
+ *
+ * I like browserify but sadly webpack doesn't
+ * support loading the bundled file
+ * generated by browserify in bundling :(
+ *
+ * https://github.com/webpack/webpack/issues/1617
+ *
+ * The other way around, browserify supports webpack bundled file,
+ * hence we will use the webpack bundled script
+ *
+ */
+//gulp.task('js:react', function () {
+// options.entries = [path.join(paths.root, entry)];
+// options.plugin = [errorify];
+//
+// return bundle(browserify(options), entry);
+//});
diff --git a/gulp-tasks/build.js b/gulp-tasks/build.js
index 833297fe..8da10d4d 100644
--- a/gulp-tasks/build.js
+++ b/gulp-tasks/build.js
@@ -50,4 +50,4 @@ gulp.task('js', function () {
.pipe(gulp.dest(paths.dist));
});
-gulp.task('build', gulpsync.sync(['js', 'js:react', 'js:react:webpack', 'min']));
+gulp.task('build', gulpsync.sync(['js', 'js:react', 'min']));
diff --git a/gulp-tasks/webpack.js b/gulp-tasks/webpack.js
index 38423d7a..13e81a47 100644
--- a/gulp-tasks/webpack.js
+++ b/gulp-tasks/webpack.js
@@ -10,14 +10,14 @@ var paths = {
var entry = 'react.js';
-gulp.task('js:react:webpack', function () {
+gulp.task('js:react', function () {
return gulp.src(path.join(paths.root, entry))
.pipe(webpack({
entry: './src/Cleave.react.js',
output: {
library: 'Cleave',
libraryTarget: 'umd',
- filename: 'cleave-react.webpack.js'
+ filename: 'cleave-react.js'
},
module: {
loaders: [
diff --git a/package.json b/package.json
index 93fc160c..cd420563 100644
--- a/package.json
+++ b/package.json
@@ -10,7 +10,7 @@
"form",
"input"
],
- "version": "0.5.1",
+ "version": "0.5.2",
"author": {
"name": "Max Huang",
"url": "http://github.com/nosir",