-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Andela Developer
authored and
Andela Developer
committed
Feb 2, 2018
1 parent
a41be51
commit c3dc0f4
Showing
18 changed files
with
322 additions
and
303 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
SYNCANO_INSTANCE= | ||
TESTDELETE= |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,2 +1,23 @@ | ||
# syncano-react-demo-stripe-payments | ||
A simple app to demonstrate the integration of stripe-payments socket | ||
## syncano-react-demo-stripe-payments | ||
|
||
This demo features a sample payment interface that uses [Syncano Stripe socket](https://syncano.io/#/sockets/stripe-payments) to illustrate payment and card services on the web. | ||
|
||
data:image/s3,"s3://crabby-images/db8f9/db8f938d2cb9964641c9e5c3ba6cad3d770a6584" alt="Demo" | ||
|
||
### Description/ Usage | ||
This simple demo allows you to make payment, create cards and delete cards as a customer. | ||
On mounting of the application, a `customerID` is generated to identify user, When the <payment> page loads, it displays a form with bunch of inputs ready to receive credit card data. Remember to use any of [Stripe testing credit card](https://stripe.com/docs/testing#cards), any three or four digit CVC code (depending on the of type card) and a valid month and year; to make payments on this demo application. On successful submission of credit card, a user can decide to create a card and a token would be generated to ensure card is being created. Created cards can also be deleted. | ||
data:image/s3,"s3://crabby-images/9307d/9307d2c337fdbd8e7b7ce5e2482345ade65c91f2" alt="stripe test cards" | ||
|
||
|
||
### Local Setup | ||
- Clone this repo | ||
- Move to project repo | ||
- Install dependencies `npm install` | ||
- Create a .env file on the root directory. Assign the instance name where two-factor-auth socket attached to the `SYNCANO_INSTANCE` | ||
e.g `SYNCANO_INSTANCE=abcd` | ||
- Run `npm start` to start project | ||
|
||
|
||
|
||
|
Empty file.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,111 +1,80 @@ | ||
import axios from 'axios'; | ||
import SyncanoClient from 'syncano-client'; | ||
import actionTypes from '../actions/actionTypes'; | ||
import { API, createAsyncAction } from './util'; | ||
|
||
|
||
const s = new SyncanoClient(process.env.SYNCANO_INSTANCE); | ||
|
||
const { | ||
CREATE_CARD_SUCCESSFUL, | ||
CREATE_CARD_FAILED, | ||
DELETE_CARD_SUCCESSFUL, | ||
DELETE_CARD_FAILED | ||
} = actionTypes; | ||
|
||
/** | ||
* | ||
* @param {*} cardResponse | ||
* @returns {object} - action | ||
*/ | ||
const createCardSuccessful = (cardResponse) => { | ||
return { | ||
type: CREATE_CARD_SUCCESSFUL, | ||
payload: { data: cardResponse } | ||
}; | ||
}; | ||
|
||
/** | ||
* | ||
* @param {*} error | ||
* @returns {object} - action | ||
*/ | ||
const createCardFailed = (error) => { | ||
return { | ||
error, | ||
type: CREATE_CARD_FAILED | ||
}; | ||
}; | ||
|
||
/** | ||
* | ||
* @param {*} cardResponse | ||
* @returns {object} - action | ||
*/ | ||
const deleteCardSuccessful = (cardResponse) => { | ||
return { | ||
type: DELETE_CARD_SUCCESSFUL, | ||
payload: { data: cardResponse } | ||
}; | ||
}; | ||
/** | ||
* | ||
* @param {*} error | ||
* @returns {object} - action | ||
*/ | ||
const deleteCardFailed = (error) => { | ||
return { | ||
error, | ||
type: DELETE_CARD_FAILED | ||
}; | ||
}; | ||
|
||
/** | ||
* | ||
* @param {*} customerID - for creating card | ||
* @param {*} source - for creating card | ||
* @returns {function} - dispatch | ||
*/ | ||
export const createCard = (customerID, source) => { | ||
return (dispatch) => { | ||
const args = { | ||
customerID, | ||
cardParams: { source } | ||
}; | ||
return s | ||
.post('stripe-payments/cards/card', args) | ||
.then((response) => { | ||
if (response.statusCode === 200) { | ||
dispatch(createCardSuccessful({ | ||
cardID: response.data.id, | ||
brand: response.data.brand, | ||
last4: response.data.last4, | ||
exp_month: response.data.exp_month, | ||
exp_year: response.data.exp_year })); | ||
} | ||
}) | ||
.catch((error) => { | ||
dispatch(createCardFailed(error)); | ||
}); | ||
}; | ||
return createAsyncAction( | ||
CREATE_CARD_SUCCESSFUL, | ||
CREATE_CARD_FAILED, | ||
() => API.post( | ||
'stripe-payments/cards/card', | ||
{ | ||
customerID, | ||
cardParams: { source } | ||
}, | ||
(response) => { | ||
return { | ||
cardID: response.data.id, | ||
brand: response.data.brand, | ||
last4: response.data.last4, | ||
exp_month: response.data.exp_month, | ||
exp_year: response.data.exp_year | ||
}; | ||
} | ||
) | ||
); | ||
}; | ||
|
||
|
||
// export const deleteCard = (customerID, cardID) => { | ||
// return createAsyncAction( | ||
// DELETE_CARD_SUCCESSFUL, | ||
// DELETE_CARD_FAILED, | ||
// () => API.delete( | ||
// 'stripe-payments/cards/card', | ||
// { customerID, cardID }, | ||
// (response) => { | ||
// return { data: { cardID: response.data.id } }; | ||
// } | ||
// ) | ||
// ); | ||
// }; | ||
export const deleteCard = (customerID, cardID) => { | ||
return (dispatch) => { | ||
const args = { customerID, cardID }; | ||
return axios({ | ||
data: args, | ||
method: 'DELETE', | ||
url: 'https://api.syncano.io/v2/instances/dry-dream-7999/endpoints/sockets/stripe-payments/cards/card/', | ||
url: `${process.env.TESTDELETE}/stripe-payments/cards/card/`, | ||
}) | ||
.then((response) => { | ||
if (response.data.message === 'Card Deleted') { | ||
dispatch(deleteCardSuccessful({ | ||
cardID: response.data.id, | ||
})); | ||
dispatch({ | ||
type: DELETE_CARD_SUCCESSFUL, | ||
payload: { | ||
data: { cardID: response.data.id } } | ||
}); | ||
} | ||
}) | ||
.catch((error) => { | ||
dispatch(deleteCardFailed(error)); | ||
dispatch({ | ||
type: DELETE_CARD_FAILED, | ||
error, | ||
}); | ||
}); | ||
}; | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,58 +1,33 @@ | ||
import SyncanoClient from 'syncano-client'; | ||
import actionTypes from '../actions/actionTypes'; | ||
|
||
|
||
const s = new SyncanoClient(process.env.SYNCANO_INSTANCE); | ||
import { createAsyncAction, API } from './util'; | ||
|
||
const { CREATE_CUSTOMER_SUCCESSFUL, CREATE_CUSTOMER_FAILED } = actionTypes; | ||
|
||
/** | ||
* | ||
* @param {*} customerParameterId | ||
* @returns {object} - action | ||
*/ | ||
const createCustomerSuccessful = (customerParameterId) => { | ||
return { | ||
type: CREATE_CUSTOMER_SUCCESSFUL, | ||
payload: { customerId: customerParameterId } | ||
}; | ||
}; | ||
|
||
/** | ||
* | ||
* @param {*} error | ||
* @returns {object} - action | ||
*/ | ||
const createCustomerFailed = (error) => { | ||
return { | ||
type: CREATE_CUSTOMER_FAILED, | ||
error | ||
}; | ||
}; | ||
|
||
/** | ||
* | ||
* @param {*} accountBalance | ||
* @returns {function} - dispatch | ||
*/ | ||
const createCustomer = (accountBalance) => { | ||
return (dispatch) => { | ||
const args = { customerParameter: accountBalance }; | ||
if (localStorage.getItem('customerId') === null) { | ||
return s | ||
.post('stripe-payments/customers/customer', args) | ||
.then((response) => { | ||
if (response.statusCode === 200) { | ||
localStorage.setItem('customerId', response.data.id); | ||
dispatch(createCustomerSuccessful(localStorage.customerId)); | ||
} | ||
}) | ||
.catch((error) => { | ||
dispatch(createCustomerFailed(error)); | ||
}); | ||
} | ||
dispatch(createCustomerSuccessful(localStorage.customerId)); | ||
}; | ||
return createAsyncAction( | ||
CREATE_CUSTOMER_SUCCESSFUL, | ||
CREATE_CUSTOMER_FAILED, | ||
() => API.post( | ||
'stripe-payments/customers/customer', | ||
{ | ||
customerParameter: accountBalance | ||
}, | ||
(response) => { | ||
if (localStorage.getItem('customerId') === null) { | ||
localStorage.setItem('customerId', response.data.id); | ||
return { | ||
customerId: localStorage.customerId | ||
}; | ||
} return { | ||
customerId: localStorage.customerId | ||
}; | ||
} | ||
) | ||
); | ||
}; | ||
|
||
export default createCustomer; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.