|
|
|
import { createSelector } from 'reselect'
|
|
|
|
import bitcoin from 'bitcoinjs-lib'
|
|
|
|
|
|
|
|
// Initial State
|
|
|
|
const initialState = {
|
|
|
|
formType: null,
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
modalOpen: false,
|
|
|
|
amount: '0',
|
|
|
|
onchainAmount: '0',
|
|
|
|
message: '',
|
|
|
|
pubkey: '',
|
|
|
|
payment_request: ''
|
|
|
|
}
|
|
|
|
|
|
|
|
// Constants
|
|
|
|
// ------------------------------------
|
|
|
|
export const SET_FORM_TYPE = 'SET_FORM_TYPE'
|
|
|
|
|
|
|
|
|
|
|
|
export const SET_FORM = 'SET_FORM'
|
|
|
|
export const SET_AMOUNT = 'SET_AMOUNT'
|
|
|
|
export const SET_ONCHAIN_AMOUNT = 'SET_ONCHAIN_AMOUNT'
|
|
|
|
export const SET_MESSAGE = 'SET_MESSAGE'
|
|
|
|
export const SET_PUBKEY = 'SET_PUBKEY'
|
|
|
|
export const SET_PAYMENT_REQUEST = 'SET_PAYMENT_REQUEST'
|
|
|
|
export const RESET_FORM = 'RESET_FORM'
|
|
|
|
|
|
|
|
// ------------------------------------
|
|
|
|
// Actions
|
|
|
|
// ------------------------------------
|
|
|
|
export function setFormType(formType) {
|
|
|
|
return {
|
|
|
|
type: SET_FORM_TYPE,
|
|
|
|
formType
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export function setForm({ modalOpen, formType }) {
|
|
|
|
return {
|
|
|
|
type: SET_FORM,
|
|
|
|
modalOpen,
|
|
|
|
formType
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export function setAmount(amount) {
|
|
|
|
return {
|
|
|
|
type: SET_AMOUNT,
|
|
|
|
amount
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export function setOnchainAmount(onchainAmount) {
|
|
|
|
return {
|
|
|
|
type: SET_ONCHAIN_AMOUNT,
|
|
|
|
onchainAmount
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export function setMessage(message) {
|
|
|
|
return {
|
|
|
|
type: SET_MESSAGE,
|
|
|
|
message
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export function setPubkey(pubkey) {
|
|
|
|
return {
|
|
|
|
type: SET_PUBKEY,
|
|
|
|
pubkey
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export function setPaymentRequest(payment_request) {
|
|
|
|
return {
|
|
|
|
type: SET_PAYMENT_REQUEST,
|
|
|
|
payment_request
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export function resetForm() {
|
|
|
|
return {
|
|
|
|
type: RESET_FORM
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// ------------------------------------
|
|
|
|
// Action Handlers
|
|
|
|
// ------------------------------------
|
|
|
|
const ACTION_HANDLERS = {
|
|
|
|
[SET_FORM_TYPE]: (state, { formType }) => ({ ...state, formType }),
|
|
|
|
|
|
|
|
|
|
|
|
[SET_FORM]: (state, { modalOpen, formType }) => ({ ...state, modalOpen, formType }),
|
|
|
|
[SET_AMOUNT]: (state, { amount }) => ({ ...state, amount }),
|
|
|
|
[SET_ONCHAIN_AMOUNT]: (state, { onchainAmount }) => ({ ...state, onchainAmount }),
|
|
|
|
[SET_MESSAGE]: (state, { message }) => ({ ...state, message }),
|
|
|
|
[SET_PUBKEY]: (state, { pubkey }) => ({ ...state, pubkey }),
|
|
|
|
[SET_PAYMENT_REQUEST]: (state, { payment_request }) => ({ ...state, payment_request }),
|
|
|
|
[RESET_FORM]: () => (initialState)
|
|
|
|
}
|
|
|
|
|
|
|
|
// ------------------------------------
|
|
|
|
// Selector
|
|
|
|
// ------------------------------------
|
|
|
|
const formSelectors = {}
|
|
|
|
const paymentRequestSelector = state => state.form.payment_request
|
|
|
|
|
|
|
|
formSelectors.isOnchain = createSelector(
|
|
|
|
paymentRequestSelector,
|
|
|
|
(paymentRequest) => {
|
|
|
|
// TODO: work with bitcoin-js to fix p2wkh error and make testnet/mainnet dynamic
|
|
|
|
try {
|
|
|
|
bitcoin.address.toOutputScript(paymentRequest, bitcoin.networks.testnet)
|
|
|
|
return true
|
|
|
|
} catch (e) {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
)
|
|
|
|
|
|
|
|
// TODO: Add more robust logic to detect a LN payment request
|
|
|
|
formSelectors.isLn = createSelector(
|
|
|
|
paymentRequestSelector,
|
|
|
|
paymentRequest => paymentRequest.length === 124
|
|
|
|
)
|
|
|
|
|
|
|
|
export { formSelectors }
|
|
|
|
|
|
|
|
// ------------------------------------
|
|
|
|
// Reducer
|
|
|
|
// ------------------------------------
|
|
|
|
export default function formReducer(state = initialState, action) {
|
|
|
|
const handler = ACTION_HANDLERS[action.type]
|
|
|
|
|
|
|
|
return handler ? handler(state, action) : state
|
|
|
|
}
|