Skip to content

Commit

Permalink
Merge pull request #1 from opassion/on-validity-state-change
Browse files Browse the repository at this point in the history
added prop method for validity change (medipass#39/40)
  • Loading branch information
Passion authored Mar 17, 2019
2 parents efdef73 + e86fe8b commit dbdaa77
Show file tree
Hide file tree
Showing 2 changed files with 57 additions and 9 deletions.
65 changes: 56 additions & 9 deletions src/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -119,7 +119,12 @@ type State = {
cardNumberLength: number,
cardNumber: ?string,
errorText: ?string,
showZip: boolean
showZip: boolean,
cardNumberInvalid: boolean,
cardExpiryInvalid: boolean,
cardCVCInvalid: boolean,
cardZipInvalid: boolean,
valid: boolean
};

const inputRenderer = ({ props }: Object) => <input {...props} />;
Expand Down Expand Up @@ -163,7 +168,12 @@ class CreditCardInput extends Component<Props, State> {
cardNumberLength: 0,
cardNumber: null,
errorText: null,
showZip: false
showZip: false,
cardNumberInvalid: false,
cardExpiryInvalid: false,
cardCVCInvalid: false,
cardZipInvalid: false,
valid: true
};
}

Expand Down Expand Up @@ -225,7 +235,7 @@ class CreditCardInput extends Component<Props, State> {
this.setState({ showZip: cardNumberLength >= 6 });
}

this.setFieldValid();
this.setFieldValid('cardNumber');
if (cardTypeLengths) {
const lastCardTypeLength = cardTypeLengths[cardTypeLengths.length - 1];
for (let length of cardTypeLengths) {
Expand Down Expand Up @@ -286,7 +296,7 @@ class CreditCardInput extends Component<Props, State> {

this.cardExpiryField.value = formatExpiry(cardExpiry);

this.setFieldValid();
this.setFieldValid('cardExpiry');

const expiryError = isExpiryInvalid(
cardExpiry,
Expand Down Expand Up @@ -341,7 +351,7 @@ class CreditCardInput extends Component<Props, State> {
const isZipFieldAvailable = this.props.enableZipInput && this.state.showZip;
const cardType = payment.fns.cardType(this.state.cardNumber);

this.setFieldValid();
this.setFieldValid('cardCVC');
if (CVCLength >= 4) {
if (!payment.fns.validateCardCVC(CVC, cardType)) {
this.setFieldInvalid(
Expand Down Expand Up @@ -395,7 +405,7 @@ class CreditCardInput extends Component<Props, State> {
const zip = e.target.value;
const zipLength = zip.length;

this.setFieldValid();
this.setFieldValid('cardZip');

if (zipLength >= 5 && !isZipValid(zip)) {
this.setFieldInvalid(
Expand Down Expand Up @@ -429,11 +439,42 @@ class CreditCardInput extends Component<Props, State> {
};
};

handleValidityStatusChange = () => {
const { onValidityStatusChange, enableZipInput } = this.props;
const {
cardNumberInvalid,
cardExpiryInvalid,
cardCVCInvalid,
cardZipInvalid
} = this.state;

const valid =
!cardNumberInvalid &&
!cardExpiryInvalid &&
!cardCVCInvalid &&
(enableZipInput ? !cardZipInvalid : true);
const statusHasChanged = this.state.valid !== valid;

this.setState({
valid: valid
});

if (onValidityStatusChange && statusHasChanged) {
onValidityStatusChange(valid);
}
};

setFieldInvalid = (errorText: string, inputName?: string) => {
const { invalidClassName, onError } = this.props;
// $FlowFixMe
document.getElementById('field-wrapper').classList.add(invalidClassName);
this.setState({ errorText });
this.setState(
{
errorText,
[`${inputName}Invalid`]: true
},
this.handleValidityStatusChange
);

if (inputName) {
const { onError } = this.props[`${inputName}InputProps`];
Expand All @@ -445,11 +486,17 @@ class CreditCardInput extends Component<Props, State> {
}
};

setFieldValid = () => {
setFieldValid = (inputName?: string) => {
const { invalidClassName } = this.props;
// $FlowFixMe
document.getElementById('field-wrapper').classList.remove(invalidClassName);
this.setState({ errorText: null });
this.setState(
{
errorText: null,
[`${inputName}Invalid`]: false
},
this.handleValidityStatusChange
);
};

render = () => {
Expand Down
1 change: 1 addition & 0 deletions src/index.stories.js
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,7 @@ storiesOf('CreditCardInput', module)
onChange: e => console.log('number change', e),
onError: err => console.log(`number error: ${err}`)
}}
onValidityStatusChange={valid => console.log(`Is valid: ${valid}`)}
/>
</Container>
))
Expand Down

0 comments on commit dbdaa77

Please sign in to comment.