// @flow import * as ICONS from 'constants/icons'; import React, { useEffect } from 'react'; import { withRouter } from 'react-router'; import { TXO_LIST as TXO } from 'lbry-redux'; import TransactionListTable from 'component/transactionListTable'; import Paginate from 'component/common/paginate'; import { FormField } from 'component/common/form-components/form-field'; import Button from 'component/button'; import Card from 'component/common/card'; import { toCapitalCase } from 'util/string'; import classnames from 'classnames'; import HelpLink from 'component/common/help-link'; import FileExporter from 'component/common/file-exporter'; import WalletFiatPaymentHistory from 'component/walletFiatPaymentHistory'; import WalletFiatAccountHistory from 'component/walletFiatAccountHistory'; import { Lbryio } from 'lbryinc'; import { getStripeEnvironment } from 'util/stripe'; let stripeEnvironment = getStripeEnvironment(); // constants to be used in query params const QUERY_NAME_CURRENCY = 'currency'; const QUERY_NAME_TAB = 'tab'; const QUERY_NAME_FIAT_TYPE = 'fiatType'; // TODO: this tab will be renamed const DEFAULT_CURRENCY_PARAM = 'credits'; const DEFAULT_TAB_PARAM = 'fiat-payment-history'; const DEFAULT_FIAT_TYPE_PARAM = 'incoming'; type Props = { search: string, history: { action: string, push: (string) => void, replace: (string) => void }, txoPage: Array, txoPageNumber: string, txoItemCount: number, fetchTxoPage: () => void, fetchTransactions: () => void, isFetchingTransactions: boolean, transactionsFile: string, updateTxoPageParams: (any) => void, toast: (string, boolean) => void, }; type Delta = { changedParameterKey: string, value: string, }; function TxoList(props: Props) { const { search, txoPage, txoItemCount, fetchTxoPage, fetchTransactions, updateTxoPageParams, history, isFetchingTransactions, transactionsFile, } = props; const [accountTransactionResponse, setAccountTransactionResponse] = React.useState([]); const [customerTransactions, setCustomerTransactions] = React.useState([]); function getPaymentHistory() { return Lbryio.call( 'customer', 'list', { environment: stripeEnvironment, }, 'post' ); } function getAccountTransactions() { return Lbryio.call( 'account', 'list', { environment: stripeEnvironment, }, 'post' ); } // calculate account transactions section React.useEffect(() => { (async function () { try { const accountTransactionResponse = await getAccountTransactions(); // reverse so order is from most recent to latest if (accountTransactionResponse && accountTransactionResponse.length) { accountTransactionResponse.reverse(); } // TODO: remove this once pagination is implemented if (accountTransactionResponse && accountTransactionResponse.length && accountTransactionResponse.length > 25) { accountTransactionResponse.length = 25; } setAccountTransactionResponse(accountTransactionResponse); } catch (err) { console.log(err); } })(); }, []); // populate customer payment data React.useEffect(() => { (async function () { try { // get card payments customer has made let customerTransactionResponse = await getPaymentHistory(); // console.log('amount of transactions'); // console.log(customerTransactionResponse.length); // reverse so order is from most recent to latest if (customerTransactionResponse && customerTransactionResponse.length) { customerTransactionResponse.reverse(); } // TODO: remove this once pagination is implemented if ( customerTransactionResponse && customerTransactionResponse.length && customerTransactionResponse.length > 25 ) { customerTransactionResponse.length = 25; } setCustomerTransactions(customerTransactionResponse); } catch (err) { console.log(err); } })(); }, []); const urlParams = new URLSearchParams(search); const page = urlParams.get(TXO.PAGE) || String(1); const pageSize = urlParams.get(TXO.PAGE_SIZE) || String(TXO.PAGE_SIZE_DEFAULT); const type = urlParams.get(TXO.TYPE) || TXO.ALL; const subtype = urlParams.get(TXO.SUB_TYPE); const active = urlParams.get(TXO.ACTIVE) || TXO.ALL; const currency = urlParams.get(QUERY_NAME_CURRENCY) || DEFAULT_CURRENCY_PARAM; const fiatType = urlParams.get(QUERY_NAME_FIAT_TYPE) || DEFAULT_FIAT_TYPE_PARAM; // tab used in the wallet section // TODO: need to change this eventually const tab = urlParams.get(QUERY_NAME_TAB) || DEFAULT_TAB_PARAM; const currentUrlParams = { page, pageSize, active, type, subtype, currency, fiatType, tab, }; const hideStatus = type === TXO.SENT || (currentUrlParams.type === TXO.RECEIVED && currentUrlParams.subtype !== TXO.TIP); // this is for sdk params const params = {}; if (currentUrlParams.type) { if (currentUrlParams.type === TXO.ALL) { params[TXO.EXCLUDE_INTERNAL_TRANSFERS] = true; params[TXO.IS_MY_INPUT_OR_OUTPUT] = true; } else if (currentUrlParams.type === TXO.SENT) { params[TXO.IS_MY_INPUT] = true; params[TXO.IS_NOT_MY_OUTPUT] = true; if (currentUrlParams.subtype === TXO.TIP) { params[TXO.TX_TYPE] = TXO.SUPPORT; } else if (currentUrlParams.subtype === TXO.PURCHASE) { params[TXO.TX_TYPE] = TXO.PURCHASE; } else if (currentUrlParams.subtype === TXO.PAYMENT) { params[TXO.TX_TYPE] = TXO.OTHER; } else { params[TXO.TX_TYPE] = [TXO.OTHER, TXO.PURCHASE, TXO.SUPPORT]; } } else if (currentUrlParams.type === TXO.RECEIVED) { params[TXO.IS_MY_OUTPUT] = true; params[TXO.IS_NOT_MY_INPUT] = true; if (currentUrlParams.subtype === TXO.TIP) { params[TXO.TX_TYPE] = TXO.SUPPORT; } else if (currentUrlParams.subtype === TXO.PURCHASE) { params[TXO.TX_TYPE] = TXO.PURCHASE; } else if (currentUrlParams.subtype === TXO.PAYMENT) { params[TXO.TX_TYPE] = TXO.OTHER; params[TXO.EXCLUDE_INTERNAL_TRANSFERS] = true; } else { params[TXO.TX_TYPE] = [TXO.OTHER, TXO.PURCHASE, TXO.SUPPORT]; } } else if (currentUrlParams.type === TXO.SUPPORT) { params[TXO.TX_TYPE] = TXO.SUPPORT; params[TXO.IS_MY_INPUT] = true; params[TXO.IS_MY_OUTPUT] = true; } else if (currentUrlParams.type === TXO.CHANNEL || currentUrlParams.type === TXO.REPOST) { params[TXO.TX_TYPE] = currentUrlParams.type; } else if (currentUrlParams.type === TXO.PUBLISH) { params[TXO.TX_TYPE] = TXO.STREAM; } } if (currentUrlParams.active) { if (currentUrlParams.active === 'spent') { params[TXO.IS_SPENT] = true; } else if (currentUrlParams.active === 'active') { params[TXO.IS_NOT_SPENT] = true; } } if (currentUrlParams.page) params[TXO.PAGE] = Number(page); if (currentUrlParams.pageSize) params[TXO.PAGE_SIZE] = Number(pageSize); function handleChange(delta: Delta) { const url = updateUrl(delta); history.push(url); } function updateUrl(delta: Delta) { const newUrlParams = new URLSearchParams(); switch (delta.changedParameterKey) { case TXO.PAGE: if (currentUrlParams.type) { newUrlParams.set(TXO.TYPE, currentUrlParams.type); } if (currentUrlParams.subtype) { newUrlParams.set(TXO.SUB_TYPE, currentUrlParams.subtype); } if (currentUrlParams.active) { newUrlParams.set(TXO.ACTIVE, currentUrlParams.active); } newUrlParams.set(TXO.PAGE, delta.value); newUrlParams.set(QUERY_NAME_TAB, currentUrlParams.tab); newUrlParams.set(QUERY_NAME_CURRENCY, currentUrlParams.currency); break; case TXO.TYPE: newUrlParams.set(TXO.TYPE, delta.value); if (delta.value === TXO.SENT || delta.value === TXO.RECEIVED) { newUrlParams.set(TXO.ACTIVE, 'all'); if (currentUrlParams.subtype) { newUrlParams.set(TXO.SUB_TYPE, currentUrlParams.subtype); } else { newUrlParams.set(TXO.SUB_TYPE, 'all'); } } if (currentUrlParams.active && !hideStatus) { newUrlParams.set(TXO.ACTIVE, currentUrlParams.active); } else { newUrlParams.set(TXO.ACTIVE, 'all'); } newUrlParams.set(TXO.PAGE, String(1)); newUrlParams.set(TXO.PAGE_SIZE, currentUrlParams.pageSize); newUrlParams.set(QUERY_NAME_TAB, currentUrlParams.tab); newUrlParams.set(QUERY_NAME_CURRENCY, currentUrlParams.currency); break; case TXO.SUB_TYPE: if (currentUrlParams.type) { newUrlParams.set(TXO.TYPE, currentUrlParams.type); } newUrlParams.set(TXO.ACTIVE, 'all'); newUrlParams.set(TXO.SUB_TYPE, delta.value); newUrlParams.set(TXO.PAGE, String(1)); newUrlParams.set(TXO.PAGE_SIZE, currentUrlParams.pageSize); newUrlParams.set(QUERY_NAME_TAB, currentUrlParams.tab); newUrlParams.set(QUERY_NAME_CURRENCY, currentUrlParams.currency); break; case TXO.ACTIVE: if (currentUrlParams.type) { newUrlParams.set(TXO.TYPE, currentUrlParams.type); } if (currentUrlParams.subtype) { newUrlParams.set(TXO.SUB_TYPE, currentUrlParams.subtype); } newUrlParams.set(TXO.ACTIVE, delta.value); newUrlParams.set(TXO.PAGE, String(1)); newUrlParams.set(TXO.PAGE_SIZE, currentUrlParams.pageSize); newUrlParams.set(QUERY_NAME_TAB, currentUrlParams.tab); newUrlParams.set(QUERY_NAME_CURRENCY, currentUrlParams.currency); break; // toggling the currency type (lbc/fiat) case QUERY_NAME_CURRENCY: newUrlParams.set(QUERY_NAME_CURRENCY, delta.value); newUrlParams.set(QUERY_NAME_TAB, currentUrlParams.tab); // only set fiat type (incoming|outgoing) if fiat is being used if (delta.value === 'credits') { newUrlParams.delete(QUERY_NAME_FIAT_TYPE); } else { newUrlParams.set(QUERY_NAME_FIAT_TYPE, currentUrlParams.fiatType); } break; // toggling the fiat type (incoming/outgoing) case QUERY_NAME_FIAT_TYPE: newUrlParams.set(QUERY_NAME_FIAT_TYPE, delta.value); newUrlParams.set(QUERY_NAME_TAB, currentUrlParams.tab); newUrlParams.set(QUERY_NAME_CURRENCY, currentUrlParams.currency); break; } return `?${newUrlParams.toString()}`; } const paramsString = JSON.stringify(params); useEffect(() => { if (paramsString && updateTxoPageParams) { const params = JSON.parse(paramsString); updateTxoPageParams(params); } }, [paramsString, updateTxoPageParams]); return (
{__(`Transactions`)}
{/* toggle between LBC and fiat buttons */}
{/* toggle to LBC */}
} isBodyList body={ currency === 'credits' ? (
{/* LBC transactions section */}
{/* LBC transaction type dropdown */} {__('Type')} } value={type || 'all'} onChange={(e) => handleChange({ changedParameterKey: TXO.TYPE, value: e.target.value, tab })} > {Object.values(TXO.DROPDOWN_TYPES).map((v) => { const stringV = String(v); return ( ); })}
{(type === TXO.SENT || type === TXO.RECEIVED) && (
handleChange({ changedParameterKey: TXO.SUB_TYPE, value: e.target.value, tab }) } > {Object.values(TXO.DROPDOWN_SUBTYPES).map((v) => { const stringV = String(v); return ( ); })}
)} {!hideStatus && (
{/* active transactions button */}
)}
{/* export and refresh buttons */}
{!isFetchingTransactions && transactionsFile === null && ( )}
fetchTransactions()} progressMsg={isFetchingTransactions ? __('Fetching data') : ''} />
{/* listing of the lbc transactions */}
) : (
{/* FIAT SECTION ( toggle buttons and transactions) */}
{/* incoming transactions button */}
{/* listing of the transactions */} {fiatType === 'incoming' && } {fiatType === 'outgoing' && } {/* TODO: have to finish pagination */} {/* */}
) } /> ); } export default withRouter(TxoList);