You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 

117 lines
2.7 KiB

import { createSelector } from 'reselect'
import { callApi } from '../api'
import { btc } from '../utils'
// ------------------------------------
// Constants
// ------------------------------------
export const SET_PAYMENT = 'SET_PAYMENT'
export const GET_PAYMENTS = 'GET_PAYMENTS'
export const RECEIVE_PAYMENTS = 'RECEIVE_PAYMENTS'
export const SEND_PAYMENT = 'SEND_PAYMENT'
export const PAYMENT_SUCCESSFULL = 'PAYMENT_SUCCESSFULL'
export const PAYMENT_FAILED = 'PAYMENT_FAILED'
// ------------------------------------
// Actions
// ------------------------------------
export function setPayment(payment) {
return {
type: SET_PAYMENT,
payment
}
}
export function getPayments() {
return {
type: GET_PAYMENTS
}
}
export function receivePayments(data) {
return {
type: RECEIVE_PAYMENTS,
payments: data.payments.reverse()
}
}
export function sendPayment() {
return {
type: SEND_PAYMENT
}
}
export function paymentSuccessfull(payment) {
return {
type: PAYMENT_SUCCESSFULL,
payment
}
}
export function paymentFailed() {
return {
type: PAYMENT_FAILED
}
}
export const fetchPayments = () => async (dispatch) => {
dispatch(getPayments())
const payments = await callApi('payments')
payments ?
dispatch(receivePayments(payments.data))
:
dispatch(paymentFailed())
return payments
}
export const payInvoice = (payment_request) => async (dispatch) => {
console.log('payment_request: ', payment_request)
dispatch(sendPayment())
const payment = await callApi('sendpayment', 'post', { payment_request })
console.log('payment: ', payment)
payment ?
dispatch(fetchPayments())
:
dispatch(paymentFailed())
return payment
}
// ------------------------------------
// Action Handlers
// ------------------------------------
const ACTION_HANDLERS = {
[SET_PAYMENT]: (state, { payment }) => ({ ...state, payment }),
[GET_PAYMENTS]: (state) => ({ ...state, paymentLoading: true }),
[RECEIVE_PAYMENTS]: (state, { payments }) => ({ ...state, paymentLoading: false, payments }),
[PAYMENT_SUCCESSFULL]: (state, { payment }) => ({ ...state, paymentLoading: false, payments: [payment, ...state.payments] })
}
const paymentSelectors = {}
const modalPaymentSelector = state => state.payment.payment
paymentSelectors.paymentModalOpen = createSelector(
modalPaymentSelector,
payment => payment ? true : false
)
export { paymentSelectors }
// ------------------------------------
// Reducer
// ------------------------------------
const initialState = {
paymentLoading: false,
payments: [],
payment: null
}
export default function paymentReducer(state = initialState, action) {
const handler = ACTION_HANDLERS[action.type]
return handler ? handler(state, action) : state
}