@paybutton/react 4.0.1 → 4.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1 +1 @@
1
- {"version":3,"file":"index.modern.js","sources":["../lib/themes/themes/orange.ts","../lib/themes/themes/paybutton.ts","../lib/themes/themes/xec.ts","../lib/themes/index.tsx","../lib/components/Button/Button.tsx","../lib/util/address.ts","../lib/util/constants.ts","../lib/util/currency.ts","../lib/util/api-client.ts","../node_modules/accounting/accounting.js","../node_modules/object-assign/index.js","../node_modules/locale-currency/map.js","../node_modules/locale-currency/index.js","../node_modules/currency-formatter/index.js","../lib/util/format.ts","../lib/util/opReturn.ts","../lib/util/randomizeSats.ts","../lib/util/number.ts","../lib/util/satoshis.ts","../lib/altpayment/sideshift.ts","../lib/components/BarChart/BarChart.tsx","../lib/components/Widget/SideShiftLogo.tsx","../lib/components/Widget/AltpaymentWidget.tsx","../lib/components/Widget/Widget.tsx","../lib/util/socket.ts","../lib/altpayment/index.ts","../lib/components/Widget/WidgetContainer.tsx","../lib/util/validate.ts","../lib/components/PaymentDialog/PaymentDialog.tsx","../lib/components/PayButton/PayButton.tsx","../index.tsx"],"sourcesContent":["import Theme from '../Theme';\r\n\r\nconst primary = '#ee8b2b';\r\n\r\nconst theme: Theme = {\r\n palette: {\r\n primary,\r\n secondary: '#fefbf8',\r\n tertiary: '#504030',\r\n logo: primary,\r\n },\r\n};\r\n\r\nexport default theme;\r\n","import Theme from '../Theme';\r\n\r\nconst primary = '#4bc846';\r\n\r\nconst theme: Theme = {\r\n palette: {\r\n primary,\r\n secondary: '#f8fdf8',\r\n tertiary: '#374936',\r\n logo: primary,\r\n },\r\n};\r\n\r\nexport default theme;\r\n","import Theme from '../Theme';\r\n\r\nconst primary = '#0074C2';\r\n\r\nconst theme: Theme = {\r\n palette: {\r\n primary,\r\n secondary: '#f8fdf8',\r\n tertiary: '#231F20',\r\n logo: primary,\r\n },\r\n};\r\n\r\nexport default theme;\r\n","import React, { useContext } from 'react';\r\n\r\nimport { Theme } from './Theme';\r\nimport orange from './themes/orange';\r\nimport paybutton from './themes/paybutton';\r\nimport xec from './themes/xec';\r\n\r\nexport const themes: Record<ThemeName, Theme> = { orange, paybutton, xec };\r\n\r\nexport * from './Theme';\r\nexport default themes;\r\n\r\nexport enum ThemeName {\r\n ORANGE = 'orange',\r\n PAYBUTTON = 'paybutton',\r\n XEC = 'xec',\r\n}\r\n\r\nconst DEFAULT_THEME = ThemeName.PAYBUTTON;\r\n\r\nexport const getTheme = (name: ThemeName = DEFAULT_THEME): Theme =>\r\n themes[name];\r\n\r\nconst ThemeContext = React.createContext<Theme | undefined>(undefined);\r\n\r\nexport const ThemeProvider = ThemeContext.Provider;\r\n\r\nconst checkHash = (name: string): string => {\r\n // const textColor = new RegExp(/^[A-Za-z]+$/, 'i');\r\n if (name.startsWith('#')) {\r\n return name;\r\n } else {\r\n return `#${name}`;\r\n }\r\n};\r\n\r\nconst validateColors = (obj: any, isXec?: boolean): Theme => {\r\n const regexp = new RegExp(\r\n /(#(?:[0-9a-f]{2}){2,4}$|(#[0-9a-f]{3}$)|(rgb|hsl)a?\\((-?\\d+%?[,\\s]+){2,3}\\s*[\\d\\.]+%?\\)$|black$|silver$|gray$|whitesmoke$|maroon$|red$|purple$|fuchsia$|green$|lime$|olivedrab$|yellow$|navy$|blue$|teal$|aquamarine$|orange$|aliceblue$|antiquewhite$|aqua$|azure$|beige$|bisque$|blanchedalmond$|blueviolet$|brown$|burlywood$|cadetblue$|chartreuse$|chocolate$|coral$|cornflowerblue$|cornsilk$|crimson$|currentcolor$|darkblue$|darkcyan$|darkgoldenrod$|darkgray$|darkgreen$|darkgrey$|darkkhaki$|darkmagenta$|darkolivegreen$|darkorange$|darkorchid$|darkred$|darksalmon$|darkseagreen$|darkslateblue$|darkslategray$|darkslategrey$|darkturquoise$|darkviolet$|deeppink$|deepskyblue$|dimgray$|dimgrey$|dodgerblue$|firebrick$|floralwhite$|forestgreen$|gainsboro$|ghostwhite$|goldenrod$|gold$|greenyellow$|grey$|honeydew$|hotpink$|indianred$|indigo$|ivory$|khaki$|lavenderblush$|lavender$|lawngreen$|lemonchiffon$|lightblue$|lightcoral$|lightcyan$|lightgoldenrodyellow$|lightgray$|lightgreen$|lightgrey$|lightpink$|lightsalmon$|lightseagreen$|lightskyblue$|lightslategray$|lightslategrey$|lightsteelblue$|lightyellow$|limegreen$|linen$|mediumaquamarine$|mediumblue$|mediumorchid$|mediumpurple$|mediumseagreen$|mediumslateblue$|mediumspringgreen$|mediumturquoise$|mediumvioletred$|midnightblue$|mintcream$|mistyrose$|moccasin$|navajowhite$|oldlace$|olive$|orangered$|orchid$|palegoldenrod$|palegreen$|paleturquoise$|palevioletred$|papayawhip$|peachpuff$|peru$|pink$|plum$|powderblue$|rosybrown$|royalblue$|saddlebrown$|salmon$|sandybrown$|seagreen$|seashell$|sienna$|skyblue$|slateblue$|slategray$|slategrey$|snow$|springgreen$|steelblue$|tan$|thistle$|tomato$|transparent$|turquoise$|violet$|wheat$|white$|yellowgreen$|rebeccapurple$)/,\r\n 'i',\r\n );\r\n if (obj === undefined || obj.palette === undefined) {\r\n return themes[DEFAULT_THEME];\r\n } else {\r\n let { primary, secondary, tertiary, logo } = obj.palette;\r\n\r\n if (primary === undefined || !regexp.test(primary)) {\r\n primary = isXec ? xec.palette.primary : paybutton.palette.primary\r\n } else {\r\n primary = checkHash(primary);\r\n }\r\n\r\n if (secondary === undefined || !regexp.test(secondary)) {\r\n secondary = isXec ? xec.palette.secondary : paybutton.palette.secondary\r\n } else {\r\n secondary = checkHash(secondary);\r\n }\r\n\r\n if (tertiary === undefined || !regexp.test(tertiary)) {\r\n tertiary = isXec ? xec.palette.tertiary : paybutton.palette.tertiary\r\n } else {\r\n tertiary = checkHash(tertiary);\r\n }\r\n\r\n if (logo === undefined || !regexp.test(logo)) {\r\n logo = isXec ? xec.palette.logo : paybutton.palette.logo\r\n } else {\r\n logo = checkHash(logo);\r\n }\r\n\r\n return { palette: { primary, secondary, tertiary, logo } };\r\n }\r\n};\r\n\r\nexport const useTheme = (\r\n defaultTheme?: ThemeName | Theme,\r\n isXec?: boolean,\r\n): Theme => {\r\n const validated =\r\n defaultTheme === undefined && isXec === true\r\n ? ThemeName.XEC\r\n : defaultTheme === 'orange' || defaultTheme === 'xec'\r\n ? defaultTheme\r\n : validateColors(defaultTheme, isXec);\r\n\r\n const theme =\r\n useContext(ThemeContext) ??\r\n (typeof validated === 'object' ? validated : getTheme(validated));\r\n return theme;\r\n};\r\n","import { Button as MuiButton, makeStyles } from '@material-ui/core';\r\nimport { CreateCSSProperties } from '@material-ui/styles';\r\nimport React, { useRef, useState, useLayoutEffect } from 'react';\r\n\r\nimport { Theme, ThemeName, useTheme } from '../../themes';\r\n\r\nexport type animation = 'slide' | 'invert' | 'none' | undefined;\r\n\r\nexport interface ButtonProps {\r\n animation?: animation;\r\n text?: string;\r\n hoverText?: string;\r\n theme?: ThemeName | Theme;\r\n disabled?: boolean;\r\n onClick?: () => void;\r\n}\r\n\r\ninterface StyleProps {\r\n animation: animation;\r\n theme: Theme;\r\n}\r\n\r\nconst useStyles = makeStyles({\r\n container: {\r\n fontSize: '0.8rem !important',\r\n },\r\n button: ({ theme, ...props }: StyleProps): CreateCSSProperties => ({\r\n background: `${theme.palette.secondary} !important`,\r\n transition: '0.6s !important',\r\n ...(props.animation === 'slide'\r\n ? {\r\n background: `linear-gradient(45deg, ${theme.palette.primary} 50%, ${theme.palette.secondary} 50%) 100% center / 300% !important`,\r\n backgroundSize: '300% !important',\r\n backgroundPosition: '100% !important',\r\n transition: 'background-position 0.8s, color 0.15s !important',\r\n }\r\n : {}),\r\n color: `${theme.palette.primary} !important`,\r\n minWidth: '14em !important',\r\n padding: '0.618em 1.618em !important',\r\n margin: 'auto !important',\r\n boxShadow: '3px 3px 3px rgba(0, 0, 0, 0.08) !important',\r\n border: `2px solid ${theme.palette.primary} !important`,\r\n borderRadius: '10px !important',\r\n fontSize: '1em !important',\r\n textTransform: 'none',\r\n '&:hover': {\r\n ...(props.animation === 'slide'\r\n ? {\r\n backgroundPosition: '0 !important',\r\n color: `${theme.palette.secondary} !important`,\r\n }\r\n : {}),\r\n ...(props.animation === 'invert'\r\n ? {\r\n background: `${theme.palette.primary} !important`,\r\n color: `${theme.palette.secondary} !important`,\r\n }\r\n : {}),\r\n ...(props.animation === 'none'\r\n ? {\r\n background: `${theme.palette.secondary} !important`,\r\n color: `${theme.palette.primary} !important`,\r\n }\r\n : {}),\r\n },\r\n '& .MuiTouchRipple-root': {\r\n margin: -2,\r\n color: '#00000044 !important',\r\n },\r\n '&:disabled span': {\r\n filter: 'blur(2px)',\r\n color: 'rgba(0, 0, 0, 0.5)',\r\n },\r\n }),\r\n});\r\n\r\nexport const Button = (props: ButtonProps): React.ReactElement => {\r\n const { animation, text, hoverText, disabled } = Object.assign(\r\n {},\r\n Button.defaultProps,\r\n props,\r\n );\r\n\r\n const [hovering, setHovering] = useState(false);\r\n const [transitioning, setTransitioning] = useState(false);\r\n const timer = useRef<number>();\r\n const buttonRef = useRef<HTMLButtonElement>(null);\r\n\r\n const theme = useTheme(props.theme);\r\n const styleProps: StyleProps = { animation, theme };\r\n const classes = useStyles(styleProps);\r\n\r\n useLayoutEffect(() => {\r\n if (buttonRef !== null && text) {\r\n const { current } = buttonRef;\r\n if (current !== null) {\r\n const { style } = current;\r\n style.width = `${current.clientWidth}px`;\r\n // +4 is a seemingly magic number but it works.\r\n style.height = `${current.clientHeight + 4}px`;\r\n }\r\n }\r\n }, [text, buttonRef]);\r\n\r\n const handleMouseEnter = (): void => {\r\n setHovering(true);\r\n if (animation === 'none') return;\r\n setTransitioning(true);\r\n clearTimeout(timer.current);\r\n timer.current = window.setTimeout(() => setTransitioning(false), 150);\r\n };\r\n\r\n const handleMouseLeave = (): void => {\r\n setHovering(false);\r\n if (animation === 'none') return;\r\n setTransitioning(true);\r\n clearTimeout(timer.current);\r\n timer.current = window.setTimeout(() => setTransitioning(false), 150);\r\n };\r\n\r\n return (\r\n <div className={classes.container}>\r\n <MuiButton\r\n disabled={disabled}\r\n className={classes.button}\r\n onClick={props.onClick}\r\n onMouseEnter={handleMouseEnter}\r\n onMouseLeave={handleMouseLeave}\r\n ref={buttonRef}\r\n >\r\n <span> {transitioning !== hovering ? hoverText : (text && text.trim() !== \"\" ? text : <div>&nbsp;</div>)}\r\n </span>\r\n </MuiButton>\r\n </div>\r\n );\r\n};\r\n\r\nconst buttonDefaultProps: ButtonProps = {\r\n animation: 'slide',\r\n text: 'Donate',\r\n hoverText: 'Send Payment',\r\n disabled: false,\r\n};\r\n\r\nButton.defaultProps = buttonDefaultProps;\r\n\r\nexport default Button;\r\n","import * as xecaddr from 'xecaddrjs';\r\nimport { CryptoCurrency } from './types';\r\n\r\nexport const isValidCashAddress = (address: string): boolean => {\r\n if (!address) return false;\r\n try {\r\n // This should always work, but the xecaddrjs docs warn that some libraries\r\n // it depends on can return InvalidAddressError\r\n return xecaddr.isCashAddress(address);\r\n } catch (err) {\r\n return false;\r\n }\r\n};\r\n\r\nexport const isValidXecAddress = (address: string): boolean => {\r\n if (!address) return false;\r\n try {\r\n // This should always work, but the xecaddrjs docs warn that some libraries\r\n // it depends on can return InvalidAddressError\r\n return xecaddr.isXecAddress(address);\r\n } catch (err) {\r\n return false;\r\n }\r\n};\r\n\r\nexport const getCurrencyTypeFromAddress = (address: string): CryptoCurrency => {\r\n if (isValidCashAddress(address)) {\r\n return 'BCH';\r\n } else if (isValidXecAddress(address)) {\r\n return 'XEC';\r\n } else {\r\n throw new Error('Invalid currency');\r\n }\r\n};\r\n\r\nexport default {\r\n isValidCashAddress,\r\n isValidXecAddress,\r\n getCurrencyTypeFromAddress,\r\n};\r\n","export const FIAT_CURRENCIES = ['USD', 'CAD'];\r\n\r\nexport const CRYPTO_CURRENCIES = ['BCH', 'XEC'];\r\n\r\nexport const DECIMALS: { [key: string]: number } = {\r\n BCH: 8,\r\n XEC: 2,\r\n FIAT: 2,\r\n};\r\n\r\nexport const CURRENCY_PREFIXES_MAP: Record<typeof CRYPTO_CURRENCIES[number], string> = {\r\n bch: 'bitcoincash',\r\n xec: 'ecash',\r\n};","import { CRYPTO_CURRENCIES, FIAT_CURRENCIES } from \"./constants\";\r\nimport { CryptoCurrency, FiatCurrency } from \"./types\";\r\n\r\nexport function isFiat(unknownString: string): unknownString is FiatCurrency {\r\n return FIAT_CURRENCIES.includes(unknownString);\r\n }\r\n \r\n export function isCrypto(\r\n unknownString: string,\r\n ): unknownString is CryptoCurrency {\r\n return CRYPTO_CURRENCIES.includes(unknownString);\r\n }\r\n \r\n export function isValidCurrency(\r\n unknownString: string,\r\n ): unknownString is CryptoCurrency {\r\n return isFiat(unknownString) || isCrypto(unknownString);\r\n }","import axios from 'axios';\r\nimport _ from 'lodash';\r\nimport config from '../../../paybutton-config.json'\r\nimport { isValidCashAddress, isValidXecAddress } from './address';\r\nimport {\r\n Transaction,\r\n UtxoDetails,\r\n PriceData,\r\n TransactionDetails,\r\n Currency,\r\n} from './types';\r\nimport { isFiat } from './currency';\r\n\r\nexport const getAddressDetails = async (\r\n address: string,\r\n rootUrl = config.apiBaseUrl,\r\n): Promise<Transaction[]> => {\r\n const res = await fetch(`${rootUrl}/address/transactions/${address}`);\r\n return res.json();\r\n};\r\n\r\nexport const getAddressBalance = async (\r\n address: string,\r\n rootUrl = config.apiBaseUrl,\r\n): Promise<number | undefined> => {\r\n try {\r\n const res = await axios.get(`${rootUrl}/address/balance/${address}`);\r\n\r\n return isNaN(res.data) ? null : res.data;\r\n } catch (error) {\r\n return;\r\n }\r\n\r\n};\r\n\r\nexport const getUTXOs = async (\r\n address: string,\r\n rootUrl = config.apiBaseUrl,\r\n): Promise<UtxoDetails> => {\r\n const res = await fetch(`${rootUrl}/address/utxo/${address}`);\r\n return res.json();\r\n};\r\n\r\nexport const getBchFiatPrice = async (\r\n currency: Currency,\r\n rootUrl = config.apiBaseUrl,\r\n): Promise<PriceData> => {\r\n const { data } = await axios.get(\r\n `${rootUrl}/price/bitcoincash/${_.lowerCase(currency)}`,\r\n );\r\n\r\n const price: number = data;\r\n return { price };\r\n};\r\n\r\nexport const getXecFiatPrice = async (\r\n currency: Currency,\r\n rootUrl = config.apiBaseUrl,\r\n): Promise<PriceData> => {\r\n const { data } = await axios.get(\r\n `${rootUrl}/price/ecash/${_.lowerCase(currency)}`,\r\n );\r\n\r\n const price: number = data;\r\n return { price };\r\n};\r\n\r\nexport const getFiatPrice = async (currency: string, to: string, apiBaseUrl?: string): Promise<number | null> => {\r\n try {\r\n if (isFiat(currency) && isValidCashAddress(to)) {\r\n const data = await getBchFiatPrice(currency, apiBaseUrl);\r\n return data.price;\r\n } else if (isFiat(currency) && isValidXecAddress(to)) {\r\n const data = await getXecFiatPrice(currency, apiBaseUrl);\r\n return data.price;\r\n }\r\n return null\r\n } catch (error) {\r\n console.log('err', error);\r\n }\r\n return null\r\n}\r\n\r\nexport const getTransactionDetails = async (\r\n txid: string,\r\n rootUrl = config.apiBaseUrl,\r\n): Promise<TransactionDetails> => {\r\n const res = await fetch(`${rootUrl}/transactions/details/${txid}`);\r\n return res.json();\r\n};\r\n\r\nexport default {\r\n getAddressDetails,\r\n getTransactionDetails,\r\n getBchFiatPrice,\r\n getXecFiatPrice,\r\n getAddressBalance,\r\n};\r\n\r\nexport const getCashtabProviderStatus = () => {\r\n const windowAny = window as any\r\n if (window && windowAny.bitcoinAbc && windowAny.bitcoinAbc === 'cashtab') {\r\n return true;\r\n }\r\n return false;\r\n};\r\n\r\n","/*!\n * accounting.js v0.4.1\n * Copyright 2014 Open Exchange Rates\n *\n * Freely distributable under the MIT license.\n * Portions of accounting.js are inspired or borrowed from underscore.js\n *\n * Full details and documentation:\n * http://openexchangerates.github.io/accounting.js/\n */\n\n(function(root, undefined) {\n\n\t/* --- Setup --- */\n\n\t// Create the local library object, to be exported or referenced globally later\n\tvar lib = {};\n\n\t// Current version\n\tlib.version = '0.4.1';\n\n\n\t/* --- Exposed settings --- */\n\n\t// The library's settings configuration object. Contains default parameters for\n\t// currency and number formatting\n\tlib.settings = {\n\t\tcurrency: {\n\t\t\tsymbol : \"$\",\t\t// default currency symbol is '$'\n\t\t\tformat : \"%s%v\",\t// controls output: %s = symbol, %v = value (can be object, see docs)\n\t\t\tdecimal : \".\",\t\t// decimal point separator\n\t\t\tthousand : \",\",\t\t// thousands separator\n\t\t\tprecision : 2,\t\t// decimal places\n\t\t\tgrouping : 3\t\t// digit grouping (not implemented yet)\n\t\t},\n\t\tnumber: {\n\t\t\tprecision : 0,\t\t// default precision on numbers is 0\n\t\t\tgrouping : 3,\t\t// digit grouping (not implemented yet)\n\t\t\tthousand : \",\",\n\t\t\tdecimal : \".\"\n\t\t}\n\t};\n\n\n\t/* --- Internal Helper Methods --- */\n\n\t// Store reference to possibly-available ECMAScript 5 methods for later\n\tvar nativeMap = Array.prototype.map,\n\t\tnativeIsArray = Array.isArray,\n\t\ttoString = Object.prototype.toString;\n\n\t/**\n\t * Tests whether supplied parameter is a string\n\t * from underscore.js\n\t */\n\tfunction isString(obj) {\n\t\treturn !!(obj === '' || (obj && obj.charCodeAt && obj.substr));\n\t}\n\n\t/**\n\t * Tests whether supplied parameter is a string\n\t * from underscore.js, delegates to ECMA5's native Array.isArray\n\t */\n\tfunction isArray(obj) {\n\t\treturn nativeIsArray ? nativeIsArray(obj) : toString.call(obj) === '[object Array]';\n\t}\n\n\t/**\n\t * Tests whether supplied parameter is a true object\n\t */\n\tfunction isObject(obj) {\n\t\treturn obj && toString.call(obj) === '[object Object]';\n\t}\n\n\t/**\n\t * Extends an object with a defaults object, similar to underscore's _.defaults\n\t *\n\t * Used for abstracting parameter handling from API methods\n\t */\n\tfunction defaults(object, defs) {\n\t\tvar key;\n\t\tobject = object || {};\n\t\tdefs = defs || {};\n\t\t// Iterate over object non-prototype properties:\n\t\tfor (key in defs) {\n\t\t\tif (defs.hasOwnProperty(key)) {\n\t\t\t\t// Replace values with defaults only if undefined (allow empty/zero values):\n\t\t\t\tif (object[key] == null) object[key] = defs[key];\n\t\t\t}\n\t\t}\n\t\treturn object;\n\t}\n\n\t/**\n\t * Implementation of `Array.map()` for iteration loops\n\t *\n\t * Returns a new Array as a result of calling `iterator` on each array value.\n\t * Defers to native Array.map if available\n\t */\n\tfunction map(obj, iterator, context) {\n\t\tvar results = [], i, j;\n\n\t\tif (!obj) return results;\n\n\t\t// Use native .map method if it exists:\n\t\tif (nativeMap && obj.map === nativeMap) return obj.map(iterator, context);\n\n\t\t// Fallback for native .map:\n\t\tfor (i = 0, j = obj.length; i < j; i++ ) {\n\t\t\tresults[i] = iterator.call(context, obj[i], i, obj);\n\t\t}\n\t\treturn results;\n\t}\n\n\t/**\n\t * Check and normalise the value of precision (must be positive integer)\n\t */\n\tfunction checkPrecision(val, base) {\n\t\tval = Math.round(Math.abs(val));\n\t\treturn isNaN(val)? base : val;\n\t}\n\n\n\t/**\n\t * Parses a format string or object and returns format obj for use in rendering\n\t *\n\t * `format` is either a string with the default (positive) format, or object\n\t * containing `pos` (required), `neg` and `zero` values (or a function returning\n\t * either a string or object)\n\t *\n\t * Either string or format.pos must contain \"%v\" (value) to be valid\n\t */\n\tfunction checkCurrencyFormat(format) {\n\t\tvar defaults = lib.settings.currency.format;\n\n\t\t// Allow function as format parameter (should return string or object):\n\t\tif ( typeof format === \"function\" ) format = format();\n\n\t\t// Format can be a string, in which case `value` (\"%v\") must be present:\n\t\tif ( isString( format ) && format.match(\"%v\") ) {\n\n\t\t\t// Create and return positive, negative and zero formats:\n\t\t\treturn {\n\t\t\t\tpos : format,\n\t\t\t\tneg : format.replace(\"-\", \"\").replace(\"%v\", \"-%v\"),\n\t\t\t\tzero : format\n\t\t\t};\n\n\t\t// If no format, or object is missing valid positive value, use defaults:\n\t\t} else if ( !format || !format.pos || !format.pos.match(\"%v\") ) {\n\n\t\t\t// If defaults is a string, casts it to an object for faster checking next time:\n\t\t\treturn ( !isString( defaults ) ) ? defaults : lib.settings.currency.format = {\n\t\t\t\tpos : defaults,\n\t\t\t\tneg : defaults.replace(\"%v\", \"-%v\"),\n\t\t\t\tzero : defaults\n\t\t\t};\n\n\t\t}\n\t\t// Otherwise, assume format was fine:\n\t\treturn format;\n\t}\n\n\n\t/* --- API Methods --- */\n\n\t/**\n\t * Takes a string/array of strings, removes all formatting/cruft and returns the raw float value\n\t * Alias: `accounting.parse(string)`\n\t *\n\t * Decimal must be included in the regular expression to match floats (defaults to\n\t * accounting.settings.number.decimal), so if the number uses a non-standard decimal \n\t * separator, provide it as the second argument.\n\t *\n\t * Also matches bracketed negatives (eg. \"$ (1.99)\" => -1.99)\n\t *\n\t * Doesn't throw any errors (`NaN`s become 0) but this may change in future\n\t */\n\tvar unformat = lib.unformat = lib.parse = function(value, decimal) {\n\t\t// Recursively unformat arrays:\n\t\tif (isArray(value)) {\n\t\t\treturn map(value, function(val) {\n\t\t\t\treturn unformat(val, decimal);\n\t\t\t});\n\t\t}\n\n\t\t// Fails silently (need decent errors):\n\t\tvalue = value || 0;\n\n\t\t// Return the value as-is if it's already a number:\n\t\tif (typeof value === \"number\") return value;\n\n\t\t// Default decimal point comes from settings, but could be set to eg. \",\" in opts:\n\t\tdecimal = decimal || lib.settings.number.decimal;\n\n\t\t // Build regex to strip out everything except digits, decimal point and minus sign:\n\t\tvar regex = new RegExp(\"[^0-9-\" + decimal + \"]\", [\"g\"]),\n\t\t\tunformatted = parseFloat(\n\t\t\t\t(\"\" + value)\n\t\t\t\t.replace(/\\((.*)\\)/, \"-$1\") // replace bracketed values with negatives\n\t\t\t\t.replace(regex, '') // strip out any cruft\n\t\t\t\t.replace(decimal, '.') // make sure decimal point is standard\n\t\t\t);\n\n\t\t// This will fail silently which may cause trouble, let's wait and see:\n\t\treturn !isNaN(unformatted) ? unformatted : 0;\n\t};\n\n\n\t/**\n\t * Implementation of toFixed() that treats floats more like decimals\n\t *\n\t * Fixes binary rounding issues (eg. (0.615).toFixed(2) === \"0.61\") that present\n\t * problems for accounting- and finance-related software.\n\t */\n\tvar toFixed = lib.toFixed = function(value, precision) {\n\t\tprecision = checkPrecision(precision, lib.settings.number.precision);\n\t\tvar power = Math.pow(10, precision);\n\n\t\t// Multiply up by precision, round accurately, then divide and use native toFixed():\n\t\treturn (Math.round(lib.unformat(value) * power) / power).toFixed(precision);\n\t};\n\n\n\t/**\n\t * Format a number, with comma-separated thousands and custom precision/decimal places\n\t * Alias: `accounting.format()`\n\t *\n\t * Localise by overriding the precision and thousand / decimal separators\n\t * 2nd parameter `precision` can be an object matching `settings.number`\n\t */\n\tvar formatNumber = lib.formatNumber = lib.format = function(number, precision, thousand, decimal) {\n\t\t// Resursively format arrays:\n\t\tif (isArray(number)) {\n\t\t\treturn map(number, function(val) {\n\t\t\t\treturn formatNumber(val, precision, thousand, decimal);\n\t\t\t});\n\t\t}\n\n\t\t// Clean up number:\n\t\tnumber = unformat(number);\n\n\t\t// Build options object from second param (if object) or all params, extending defaults:\n\t\tvar opts = defaults(\n\t\t\t\t(isObject(precision) ? precision : {\n\t\t\t\t\tprecision : precision,\n\t\t\t\t\tthousand : thousand,\n\t\t\t\t\tdecimal : decimal\n\t\t\t\t}),\n\t\t\t\tlib.settings.number\n\t\t\t),\n\n\t\t\t// Clean up precision\n\t\t\tusePrecision = checkPrecision(opts.precision),\n\n\t\t\t// Do some calc:\n\t\t\tnegative = number < 0 ? \"-\" : \"\",\n\t\t\tbase = parseInt(toFixed(Math.abs(number || 0), usePrecision), 10) + \"\",\n\t\t\tmod = base.length > 3 ? base.length % 3 : 0;\n\n\t\t// Format the number:\n\t\treturn negative + (mod ? base.substr(0, mod) + opts.thousand : \"\") + base.substr(mod).replace(/(\\d{3})(?=\\d)/g, \"$1\" + opts.thousand) + (usePrecision ? opts.decimal + toFixed(Math.abs(number), usePrecision).split('.')[1] : \"\");\n\t};\n\n\n\t/**\n\t * Format a number into currency\n\t *\n\t * Usage: accounting.formatMoney(number, symbol, precision, thousandsSep, decimalSep, format)\n\t * defaults: (0, \"$\", 2, \",\", \".\", \"%s%v\")\n\t *\n\t * Localise by overriding the symbol, precision, thousand / decimal separators and format\n\t * Second param can be an object matching `settings.currency` which is the easiest way.\n\t *\n\t * To do: tidy up the parameters\n\t */\n\tvar formatMoney = lib.formatMoney = function(number, symbol, precision, thousand, decimal, format) {\n\t\t// Resursively format arrays:\n\t\tif (isArray(number)) {\n\t\t\treturn map(number, function(val){\n\t\t\t\treturn formatMoney(val, symbol, precision, thousand, decimal, format);\n\t\t\t});\n\t\t}\n\n\t\t// Clean up number:\n\t\tnumber = unformat(number);\n\n\t\t// Build options object from second param (if object) or all params, extending defaults:\n\t\tvar opts = defaults(\n\t\t\t\t(isObject(symbol) ? symbol : {\n\t\t\t\t\tsymbol : symbol,\n\t\t\t\t\tprecision : precision,\n\t\t\t\t\tthousand : thousand,\n\t\t\t\t\tdecimal : decimal,\n\t\t\t\t\tformat : format\n\t\t\t\t}),\n\t\t\t\tlib.settings.currency\n\t\t\t),\n\n\t\t\t// Check format (returns object with pos, neg and zero):\n\t\t\tformats = checkCurrencyFormat(opts.format),\n\n\t\t\t// Choose which format to use for this value:\n\t\t\tuseFormat = number > 0 ? formats.pos : number < 0 ? formats.neg : formats.zero;\n\n\t\t// Return with currency symbol added:\n\t\treturn useFormat.replace('%s', opts.symbol).replace('%v', formatNumber(Math.abs(number), checkPrecision(opts.precision), opts.thousand, opts.decimal));\n\t};\n\n\n\t/**\n\t * Format a list of numbers into an accounting column, padding with whitespace\n\t * to line up currency symbols, thousand separators and decimals places\n\t *\n\t * List should be an array of numbers\n\t * Second parameter can be an object containing keys that match the params\n\t *\n\t * Returns array of accouting-formatted number strings of same length\n\t *\n\t * NB: `white-space:pre` CSS rule is required on the list container to prevent\n\t * browsers from collapsing the whitespace in the output strings.\n\t */\n\tlib.formatColumn = function(list, symbol, precision, thousand, decimal, format) {\n\t\tif (!list) return [];\n\n\t\t// Build options object from second param (if object) or all params, extending defaults:\n\t\tvar opts = defaults(\n\t\t\t\t(isObject(symbol) ? symbol : {\n\t\t\t\t\tsymbol : symbol,\n\t\t\t\t\tprecision : precision,\n\t\t\t\t\tthousand : thousand,\n\t\t\t\t\tdecimal : decimal,\n\t\t\t\t\tformat : format\n\t\t\t\t}),\n\t\t\t\tlib.settings.currency\n\t\t\t),\n\n\t\t\t// Check format (returns object with pos, neg and zero), only need pos for now:\n\t\t\tformats = checkCurrencyFormat(opts.format),\n\n\t\t\t// Whether to pad at start of string or after currency symbol:\n\t\t\tpadAfterSymbol = formats.pos.indexOf(\"%s\") < formats.pos.indexOf(\"%v\") ? true : false,\n\n\t\t\t// Store value for the length of the longest string in the column:\n\t\t\tmaxLength = 0,\n\n\t\t\t// Format the list according to options, store the length of the longest string:\n\t\t\tformatted = map(list, function(val, i) {\n\t\t\t\tif (isArray(val)) {\n\t\t\t\t\t// Recursively format columns if list is a multi-dimensional array:\n\t\t\t\t\treturn lib.formatColumn(val, opts);\n\t\t\t\t} else {\n\t\t\t\t\t// Clean up the value\n\t\t\t\t\tval = unformat(val);\n\n\t\t\t\t\t// Choose which format to use for this value (pos, neg or zero):\n\t\t\t\t\tvar useFormat = val > 0 ? formats.pos : val < 0 ? formats.neg : formats.zero,\n\n\t\t\t\t\t\t// Format this value, push into formatted list and save the length:\n\t\t\t\t\t\tfVal = useFormat.replace('%s', opts.symbol).replace('%v', formatNumber(Math.abs(val), checkPrecision(opts.precision), opts.thousand, opts.decimal));\n\n\t\t\t\t\tif (fVal.length > maxLength) maxLength = fVal.length;\n\t\t\t\t\treturn fVal;\n\t\t\t\t}\n\t\t\t});\n\n\t\t// Pad each number in the list and send back the column of numbers:\n\t\treturn map(formatted, function(val, i) {\n\t\t\t// Only if this is a string (not a nested array, which would have already been padded):\n\t\t\tif (isString(val) && val.length < maxLength) {\n\t\t\t\t// Depending on symbol position, pad after symbol or at index 0:\n\t\t\t\treturn padAfterSymbol ? val.replace(opts.symbol, opts.symbol+(new Array(maxLength - val.length + 1).join(\" \"))) : (new Array(maxLength - val.length + 1).join(\" \")) + val;\n\t\t\t}\n\t\t\treturn val;\n\t\t});\n\t};\n\n\n\t/* --- Module Definition --- */\n\n\t// Export accounting for CommonJS. If being loaded as an AMD module, define it as such.\n\t// Otherwise, just add `accounting` to the global object\n\tif (typeof exports !== 'undefined') {\n\t\tif (typeof module !== 'undefined' && module.exports) {\n\t\t\texports = module.exports = lib;\n\t\t}\n\t\texports.accounting = lib;\n\t} else if (typeof define === 'function' && define.amd) {\n\t\t// Return the library as an AMD module:\n\t\tdefine([], function() {\n\t\t\treturn lib;\n\t\t});\n\t} else {\n\t\t// Use accounting.noConflict to restore `accounting` back to its original value.\n\t\t// Returns a reference to the library's `accounting` object;\n\t\t// e.g. `var numbers = accounting.noConflict();`\n\t\tlib.noConflict = (function(oldAccounting) {\n\t\t\treturn function() {\n\t\t\t\t// Reset the value of the root's `accounting` variable:\n\t\t\t\troot.accounting = oldAccounting;\n\t\t\t\t// Delete the noConflict method:\n\t\t\t\tlib.noConflict = undefined;\n\t\t\t\t// Return reference to the library to re-assign it:\n\t\t\t\treturn lib;\n\t\t\t};\n\t\t})(root.accounting);\n\n\t\t// Declare `fx` on the root (global/window) object:\n\t\troot['accounting'] = lib;\n\t}\n\n\t// Root will be `window` in browser or `global` on the server:\n}(this));\n","/*\nobject-assign\n(c) Sindre Sorhus\n@license MIT\n*/\n\n'use strict';\n/* eslint-disable no-unused-vars */\nvar getOwnPropertySymbols = Object.getOwnPropertySymbols;\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\nvar propIsEnumerable = Object.prototype.propertyIsEnumerable;\n\nfunction toObject(val) {\n\tif (val === null || val === undefined) {\n\t\tthrow new TypeError('Object.assign cannot be called with null or undefined');\n\t}\n\n\treturn Object(val);\n}\n\nfunction shouldUseNative() {\n\ttry {\n\t\tif (!Object.assign) {\n\t\t\treturn false;\n\t\t}\n\n\t\t// Detect buggy property enumeration order in older V8 versions.\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=4118\n\t\tvar test1 = new String('abc'); // eslint-disable-line no-new-wrappers\n\t\ttest1[5] = 'de';\n\t\tif (Object.getOwnPropertyNames(test1)[0] === '5') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test2 = {};\n\t\tfor (var i = 0; i < 10; i++) {\n\t\t\ttest2['_' + String.fromCharCode(i)] = i;\n\t\t}\n\t\tvar order2 = Object.getOwnPropertyNames(test2).map(function (n) {\n\t\t\treturn test2[n];\n\t\t});\n\t\tif (order2.join('') !== '0123456789') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test3 = {};\n\t\t'abcdefghijklmnopqrst'.split('').forEach(function (letter) {\n\t\t\ttest3[letter] = letter;\n\t\t});\n\t\tif (Object.keys(Object.assign({}, test3)).join('') !==\n\t\t\t\t'abcdefghijklmnopqrst') {\n\t\t\treturn false;\n\t\t}\n\n\t\treturn true;\n\t} catch (err) {\n\t\t// We don't expect any of the above to throw, but better to be safe.\n\t\treturn false;\n\t}\n}\n\nmodule.exports = shouldUseNative() ? Object.assign : function (target, source) {\n\tvar from;\n\tvar to = toObject(target);\n\tvar symbols;\n\n\tfor (var s = 1; s < arguments.length; s++) {\n\t\tfrom = Object(arguments[s]);\n\n\t\tfor (var key in from) {\n\t\t\tif (hasOwnProperty.call(from, key)) {\n\t\t\t\tto[key] = from[key];\n\t\t\t}\n\t\t}\n\n\t\tif (getOwnPropertySymbols) {\n\t\t\tsymbols = getOwnPropertySymbols(from);\n\t\t\tfor (var i = 0; i < symbols.length; i++) {\n\t\t\t\tif (propIsEnumerable.call(from, symbols[i])) {\n\t\t\t\t\tto[symbols[i]] = from[symbols[i]];\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn to;\n};\n","// Generated using ShowCurrencies.java\nvar map = {\nAD: 'EUR',\nAE: 'AED',\nAF: 'AFN',\nAG: 'XCD',\nAI: 'XCD',\nAL: 'ALL',\nAM: 'AMD',\nAN: 'ANG',\nAO: 'AOA',\nAR: 'ARS',\nAS: 'USD',\nAT: 'EUR',\nAU: 'AUD',\nAW: 'AWG',\nAX: 'EUR',\nAZ: 'AZN',\nBA: 'BAM',\nBB: 'BBD',\nBD: 'BDT',\nBE: 'EUR',\nBF: 'XOF',\nBG: 'BGN',\nBH: 'BHD',\nBI: 'BIF',\nBJ: 'XOF',\nBL: 'EUR',\nBM: 'BMD',\nBN: 'BND',\nBO: 'BOB',\nBQ: 'USD',\nBR: 'BRL',\nBS: 'BSD',\nBT: 'BTN',\nBV: 'NOK',\nBW: 'BWP',\nBY: 'BYR',\nBZ: 'BZD',\nCA: 'CAD',\nCC: 'AUD',\nCD: 'CDF',\nCF: 'XAF',\nCG: 'XAF',\nCH: 'CHF',\nCI: 'XOF',\nCK: 'NZD',\nCL: 'CLP',\nCM: 'XAF',\nCN: 'CNY',\nCO: 'COP',\nCR: 'CRC',\nCU: 'CUP',\nCV: 'CVE',\nCW: 'ANG',\nCX: 'AUD',\nCY: 'EUR',\nCZ: 'CZK',\nDE: 'EUR',\nDJ: 'DJF',\nDK: 'DKK',\nDM: 'XCD',\nDO: 'DOP',\nDZ: 'DZD',\nEC: 'USD',\nEE: 'EUR',\nEG: 'EGP',\nEH: 'MAD',\nER: 'ERN',\nES: 'EUR',\nET: 'ETB',\nFI: 'EUR',\nFJ: 'FJD',\nFK: 'FKP',\nFM: 'USD',\nFO: 'DKK',\nFR: 'EUR',\nGA: 'XAF',\nGB: 'GBP',\nGD: 'XCD',\nGE: 'GEL',\nGF: 'EUR',\nGG: 'GBP',\nGH: 'GHS',\nGI: 'GIP',\nGL: 'DKK',\nGM: 'GMD',\nGN: 'GNF',\nGP: 'EUR',\nGQ: 'XAF',\nGR: 'EUR',\nGS: 'GBP',\nGT: 'GTQ',\nGU: 'USD',\nGW: 'XOF',\nGY: 'GYD',\nHK: 'HKD',\nHM: 'AUD',\nHN: 'HNL',\nHR: 'HRK',\nHT: 'HTG',\nHU: 'HUF',\nID: 'IDR',\nIE: 'EUR',\nIL: 'ILS',\nIM: 'GBP',\nIN: 'INR',\nIO: 'USD',\nIQ: 'IQD',\nIR: 'IRR',\nIS: 'ISK',\nIT: 'EUR',\nJE: 'GBP',\nJM: 'JMD',\nJO: 'JOD',\nJP: 'JPY',\nKE: 'KES',\nKG: 'KGS',\nKH: 'KHR',\nKI: 'AUD',\nKM: 'KMF',\nKN: 'XCD',\nKP: 'KPW',\nKR: 'KRW',\nKW: 'KWD',\nKY: 'KYD',\nKZ: 'KZT',\nLA: 'LAK',\nLB: 'LBP',\nLC: 'XCD',\nLI: 'CHF',\nLK: 'LKR',\nLR: 'LRD',\nLS: 'LSL',\nLT: 'LTL',\nLU: 'EUR',\nLV: 'LVL',\nLY: 'LYD',\nMA: 'MAD',\nMC: 'EUR',\nMD: 'MDL',\nME: 'EUR',\nMF: 'EUR',\nMG: 'MGA',\nMH: 'USD',\nMK: 'MKD',\nML: 'XOF',\nMM: 'MMK',\nMN: 'MNT',\nMO: 'MOP',\nMP: 'USD',\nMQ: 'EUR',\nMR: 'MRO',\nMS: 'XCD',\nMT: 'EUR',\nMU: 'MUR',\nMV: 'MVR',\nMW: 'MWK',\nMX: 'MXN',\nMY: 'MYR',\nMZ: 'MZN',\nNA: 'NAD',\nNC: 'XPF',\nNE: 'XOF',\nNF: 'AUD',\nNG: 'NGN',\nNI: 'NIO',\nNL: 'EUR',\nNO: 'NOK',\nNP: 'NPR',\nNR: 'AUD',\nNU: 'NZD',\nNZ: 'NZD',\nOM: 'OMR',\nPA: 'PAB',\nPE: 'PEN',\nPF: 'XPF',\nPG: 'PGK',\nPH: 'PHP',\nPK: 'PKR',\nPL: 'PLN',\nPM: 'EUR',\nPN: 'NZD',\nPR: 'USD',\nPS: 'ILS',\nPT: 'EUR',\nPW: 'USD',\nPY: 'PYG',\nQA: 'QAR',\nRE: 'EUR',\nRO: 'RON',\nRS: 'RSD',\nRU: 'RUB',\nRW: 'RWF',\nSA: 'SAR',\nSB: 'SBD',\nSC: 'SCR',\nSD: 'SDG',\nSE: 'SEK',\nSG: 'SGD',\nSH: 'SHP',\nSI: 'EUR',\nSJ: 'NOK',\nSK: 'EUR',\nSL: 'SLL',\nSM: 'EUR',\nSN: 'XOF',\nSO: 'SOS',\nSR: 'SRD',\nST: 'STD',\nSV: 'SVC',\nSX: 'ANG',\nSY: 'SYP',\nSZ: 'SZL',\nTC: 'USD',\nTD: 'XAF',\nTF: 'EUR',\nTG: 'XOF',\nTH: 'THB',\nTJ: 'TJS',\nTK: 'NZD',\nTL: 'USD',\nTM: 'TMT',\nTN: 'TND',\nTO: 'TOP',\nTR: 'TRY',\nTT: 'TTD',\nTV: 'AUD',\nTW: 'TWD',\nTZ: 'TZS',\nUA: 'UAH',\nUG: 'UGX',\nUM: 'USD',\nUS: 'USD',\nUY: 'UYU',\nUZ: 'UZS',\nVA: 'EUR',\nVC: 'XCD',\nVE: 'VEF',\nVG: 'USD',\nVI: 'USD',\nVN: 'VND',\nVU: 'VUV',\nWF: 'XPF',\nWS: 'WST',\nYE: 'YER',\nYT: 'EUR',\nZA: 'ZAR',\nZM: 'ZMK',\nZW: 'ZWL'\n};\n\nmodule.exports = map;","var map = require(\"./map\");\n\nvar getCountryCode = function(localeString) {\n var components = localeString.split(\"_\");\n if (components.length == 2) {\n return components.pop();\n }\n components = localeString.split(\"-\");\n if (components.length == 2) {\n return components.pop();\n }\n return localeString;\n}\n\nexports.getCurrency = function(locale) {\n var countryCode = getCountryCode(locale).toUpperCase();\n if (countryCode in map) {\n return map[countryCode];\n }\n return null;\n}\n\nexports.getLocales = function(currencyCode) {\n currencyCode = currencyCode.toUpperCase();\n var locales = [];\n for (countryCode in map) {\n if (map[countryCode] === currencyCode) {\n locales.push(countryCode);\n }\n }\n return locales;\n}","var accounting = require('accounting')\nvar assign = require('object-assign')\nvar localeCurrency = require('locale-currency')\nvar currencies = require('./currencies.json')\nvar localeFormats = require('./localeFormats.json')\n\nvar defaultCurrency = {\n symbol: '',\n thousandsSeparator: ',',\n decimalSeparator: '.',\n symbolOnLeft: true,\n spaceBetweenAmountAndSymbol: false,\n decimalDigits: 2\n}\n\nvar defaultLocaleFormat = {}\n\nvar formatMapping = [\n {\n symbolOnLeft: true,\n spaceBetweenAmountAndSymbol: false,\n format: {\n pos: '%s%v',\n neg: '-%s%v',\n zero: '%s%v'\n }\n },\n {\n symbolOnLeft: true,\n spaceBetweenAmountAndSymbol: true,\n format: {\n pos: '%s %v',\n neg: '-%s %v',\n zero: '%s %v'\n }\n },\n {\n symbolOnLeft: false,\n spaceBetweenAmountAndSymbol: false,\n format: {\n pos: '%v%s',\n neg: '-%v%s',\n zero: '%v%s'\n }\n },\n {\n symbolOnLeft: false,\n spaceBetweenAmountAndSymbol: true,\n format: {\n pos: '%v %s',\n neg: '-%v %s',\n zero: '%v %s'\n }\n }\n]\n\nfunction format(value, options) {\n var code = options.code || (options.locale && localeCurrency.getCurrency(options.locale))\n var localeMatch = /^([a-z]+)([_-]([a-z]+))?$/i.exec(options.locale) || []\n var language = localeMatch[1]\n var region = localeMatch[3]\n var localeFormat = assign({}, defaultLocaleFormat,\n localeFormats[language] || {},\n localeFormats[language + '-' + region] || {})\n var currency = assign({}, defaultCurrency, findCurrency(code), localeFormat)\n \n var symbolOnLeft = currency.symbolOnLeft\n var spaceBetweenAmountAndSymbol = currency.spaceBetweenAmountAndSymbol\n\n var format = formatMapping.filter(function(f) {\n return f.symbolOnLeft == symbolOnLeft && f.spaceBetweenAmountAndSymbol == spaceBetweenAmountAndSymbol\n })[0].format\n\n return accounting.formatMoney(value, {\n symbol: isUndefined(options.symbol)\n ? currency.symbol\n : options.symbol,\n\n decimal: isUndefined(options.decimal)\n ? currency.decimalSeparator\n : options.decimal,\n\n thousand: isUndefined(options.thousand)\n ? currency.thousandsSeparator\n : options.thousand,\n\n precision: typeof options.precision === 'number'\n ? options.precision\n : currency.decimalDigits,\n\n format: ['string', 'object'].indexOf(typeof options.format) > -1\n ? options.format\n : format\n })\n}\n\nfunction findCurrency (currencyCode) {\n return currencies[currencyCode]\n}\n\nfunction isUndefined (val) {\n return typeof val === 'undefined'\n}\n\nfunction unformat(value, options) {\n var code = options.code || (options.locale && localeCurrency.getCurrency(options.locale))\n var localeFormat = localeFormats[options.locale] || defaultLocaleFormat\n var currency = assign({}, defaultCurrency, findCurrency(code), localeFormat)\n var decimal = isUndefined(options.decimal) ? currency.decimalSeparator : options.decimal\n return accounting.unformat(value, decimal)\n}\n\nmodule.exports = {\n defaultCurrency: defaultCurrency,\n get currencies() {\n // In favor of backwards compatibility, the currencies map is converted to an array here\n return Object.keys(currencies).map(function(key) {\n return currencies[key]\n })\n },\n findCurrency: findCurrency,\n format: format,\n unformat: unformat\n}","import currencyFormat from 'currency-formatter';\r\nimport { Currency } from './types';\r\nimport { DECIMALS } from './constants'\r\n\r\nexport const amount = (x?: number | null): string | undefined => {\r\n const clean = +x!;\r\n if (clean === 0) return;\r\n return clean\r\n ?.toFixed(8)\r\n .replace(/\\.0*$/, '')\r\n .replace(/(\\.\\d*?)0*$/, '$1');\r\n};\r\n\r\nexport const formatPrice = (\r\n price: number,\r\n currencyType: Currency,\r\n precision = DECIMALS.FIAT,\r\n) => {\r\n return Intl.NumberFormat(undefined, {\r\n style: 'currency',\r\n currency: currencyType,\r\n currencyDisplay: 'narrowSymbol',\r\n minimumFractionDigits: precision,\r\n maximumFractionDigits: precision,\r\n }).format(price);\r\n};\r\n\r\nexport const formatComma = (number: number) => {\r\n const formattedString = currencyFormat.format(number, {\r\n symbol: '',\r\n decimal: '',\r\n thousand: ',',\r\n precision: 0,\r\n format: '%v',\r\n });\r\n\r\n return formattedString;\r\n};\r\n\r\nexport const formatBCH = (bch: string) => {\r\n const val = +bch;\r\n const formattedString = currencyFormat.format(val, {\r\n symbol: '',\r\n decimal: '.',\r\n thousand: ',',\r\n precision: 8,\r\n format: '%v',\r\n });\r\n\r\n return formattedString;\r\n};\r\n\r\nexport const formatXEC = (xec: string) => {\r\n const val = +xec;\r\n const formattedString = currencyFormat.format(val, {\r\n symbol: '',\r\n decimal: '.',\r\n thousand: ',',\r\n precision: 2,\r\n format: '%v',\r\n });\r\n\r\n return formattedString;\r\n};\r\n\r\nexport const isPropsTrue = (value?: string | boolean) => {\r\n switch (typeof value) {\r\n case \"string\":\r\n return value === \"true\"\r\n case \"boolean\":\r\n return value\r\n case \"undefined\":\r\n return false\r\n }\r\n}\r\n\r\nexport default {\r\n amount,\r\n formatPrice,\r\n formatComma,\r\n formatBCH,\r\n formatXEC,\r\n};\r\n","import { lib, enc } from 'crypto-js';\r\n\r\n// All the below variables are already encoded to HEX\r\nexport const OP_RETURN_PREFIX_PUSHDATA = '04'; // \\x04\r\nexport const OP_RETURN_PREFIX = '50415900'; // PAY\\x00\r\nexport const VERSION = '00'; // \\x00\r\n\r\n// 223 total bytes\r\n// - 1 from the OP_RETURN op code: '\\x6a'\r\n// - 1 from the protocol pushdata: '\\x04'\r\n// - 4 from the 4-byte procol prefix: 'PAY\\x00'\r\n// - 1 for the version byte: '\\x00'\r\n// - 2 from the maximum size for the data pushdata\r\n// - 1 from the paymentId pushdata\r\n// = 213 available bytes\r\nexport const USER_DATA_BYTES_LIMIT = 213;\r\n\r\n// Pushdata is self-describing up to 75 bytes, since 0x4c (76 in hex) is\r\n// a special OP code.\r\nconst SINGLE_PUSHDATA_BYTE_LIMIT = 75;\r\n\r\nfunction prependPaymentIdWithPushdata(hexString: string): string {\r\n // 2 hex chars == 1 byte\r\n if (hexString.length % 2 !== 0) {\r\n throw new Error(\r\n `Malformed input; paymentId hex should never be of odd length`,\r\n );\r\n }\r\n const bytesQuantity = hexString.length / 2;\r\n // We limit the paymentId size to 75 bytes,\r\n // since this is way more than necessary for security.\r\n if (bytesQuantity > SINGLE_PUSHDATA_BYTE_LIMIT) {\r\n throw new Error(\r\n `Maximum ${SINGLE_PUSHDATA_BYTE_LIMIT} byte size exceeded for paymentId: ${bytesQuantity}`,\r\n );\r\n }\r\n const pushdata = bytesQuantity.toString(16).padStart(2, '0');\r\n return `${pushdata}${hexString}`;\r\n}\r\n\r\n// UTF8 encoding\r\nfunction stringToHex(str: string): string {\r\n const encoder = new TextEncoder();\r\n const encoded = encoder.encode(str);\r\n const encodedBytes = Array.from(encoded);\r\n return encodedBytes.map(byte => byte.toString(16).padStart(2, '0')).join('');\r\n}\r\n\r\nexport function generatePaymentId(bytesAmount: number): string {\r\n // Generate random bytes\r\n const wordArray = lib.WordArray.random(bytesAmount);\r\n\r\n // Convert the word array to a hex string\r\n return enc.Hex.stringify(wordArray);\r\n}\r\n\r\nfunction generatePushdataPrefixedPaymentId(\r\n bytesAmount: number,\r\n disabled = false,\r\n): string {\r\n if (disabled) {\r\n return '00';\r\n }\r\n const hexString = generatePaymentId(bytesAmount);\r\n\r\n // The result is 18 char long:\r\n // ---\r\n // a hex character encodes 4 bits of information (2⁴ = 16);\r\n // ... therefore; 8 bytes = 64 bits => 64/4 = 16 hex chars\r\n // + 1 byte of pushdata at the beggining = 2 hex chars\r\n // = 18 chars\r\n return prependPaymentIdWithPushdata(hexString);\r\n}\r\n\r\nfunction getDataPushdata(data: string, disablePaymentId = false): string {\r\n const bytesQuantity = new Blob([data]).size;\r\n // If paymentId is expected, limit is 8 bytes smaller\r\n const bytesLimit = USER_DATA_BYTES_LIMIT - (disablePaymentId ? 0 : 8);\r\n if (bytesQuantity > bytesLimit) {\r\n throw new Error(\r\n `Maximum ${bytesLimit} byte size exceeded for user data: ${bytesQuantity}`,\r\n );\r\n }\r\n const rawPushdata = bytesQuantity.toString(16).padStart(2, '0');\r\n if (bytesQuantity > SINGLE_PUSHDATA_BYTE_LIMIT) {\r\n return '4c' + rawPushdata;\r\n }\r\n return rawPushdata;\r\n}\r\n\r\n// Example:\r\n// If the user wants to send \"hello world\" in the OP_RETURN, the\r\n// function below constructs it in the following way:\r\n//\r\n// `04` - Pushdata of the Protocol Identifier, `50415900`\r\n// `50415900` - PayButton protocol identifier, ascii \"PAY\"\r\n// `00` - Version 0, pushed as `OP_0`\r\n// `16` - pushdata for the data payload, signifying this tx has 22 bytes of data\r\n// `68656c6c6f20776f726c64` - data payload, 'hello world' as ASCII encoded to hex\r\n// `08` - pushdata for the optional paymentId (paymentId), signifying this tx has 8 bytes of paymentId data\r\n// `0102030405060708` - The 8-byte paymentId (paymentId)\r\n//\r\n// Result: 0450415900001668656c6c6f20776f726c64080102030405060708\r\n\r\nexport interface EncodeOpReturnParams {\r\n opReturn?: string;\r\n disablePaymentId: boolean;\r\n paymentId?: string;\r\n}\r\n\r\n// specs defined at:\r\n// https://github.com/Bitcoin-ABC/bitcoin-abc/blob/master/doc/standards/paybutton.md\r\nexport function encodeOpReturnProps({\r\n opReturn,\r\n disablePaymentId,\r\n paymentId\r\n}: EncodeOpReturnParams): string {\r\n if (opReturn === undefined) {\r\n opReturn = '';\r\n }\r\n\r\n const dataPushdata = getDataPushdata(opReturn, disablePaymentId);\r\n if (paymentId === undefined || disablePaymentId) {\r\n paymentId = ''\r\n }\r\n const pushDataPrefixedPaymentId = prependPaymentIdWithPushdata(paymentId ?? '');\r\n return (\r\n OP_RETURN_PREFIX_PUSHDATA +\r\n OP_RETURN_PREFIX +\r\n VERSION +\r\n dataPushdata +\r\n stringToHex(opReturn) +\r\n pushDataPrefixedPaymentId\r\n );\r\n}\r\n\r\nexport const exportedForTesting = {\r\n prependPaymentIdWithPushdata,\r\n generatePaymentId,\r\n generatePushdataPrefixedPaymentId,\r\n stringToHex,\r\n getDataPushdata,\r\n};\r\n","import { CryptoCurrency } from \"./types\";\r\n\r\nconst DEFAULT = 3\r\nconst MAX = 4\r\n\r\n\r\nexport const getNSatoshis = (amount: number, randomSatoshis: boolean | number, satsPrecision: number): number => {\r\n const amountDigits = amount.toFixed(satsPrecision).toString().replace('.', '').length;\r\n if (randomSatoshis === true) {\r\n return Math.min(DEFAULT, amountDigits)\r\n } else if (randomSatoshis === false) {\r\n throw new Error(\"Trying to randomize satoshis when not allowed.\")\r\n }\r\n if (randomSatoshis > MAX) {\r\n randomSatoshis = MAX\r\n }\r\n return Math.min(randomSatoshis, amountDigits)\r\n}\r\n\r\nexport const randomizeSatoshis = (amount: number, addressType: CryptoCurrency, randomSatoshis: boolean | number): number => {\r\n if (amount === 0) {\r\n return 0;\r\n }\r\n let nSatoshis: number\r\n let random: number\r\n let randomizedAmount: number\r\n let ret: number\r\n switch (addressType) {\r\n case 'BCH':\r\n nSatoshis = getNSatoshis(amount, randomSatoshis, 8)\r\n random = Math.floor(Math.random() * 10 ** nSatoshis) * 1e-8\r\n\r\n randomizedAmount =\r\n Math.max(0, +amount.toFixed(nSatoshis)) + // zero out the least-significant digits\r\n random\r\n ret = +randomizedAmount.toFixed(8);\r\n break\r\n case 'XEC':\r\n nSatoshis = getNSatoshis(amount, randomSatoshis, 2)\r\n random = Math.floor(Math.random() * 10 ** nSatoshis) * 1e-2\r\n\r\n const multiplier = 10 ** (nSatoshis - 2)\r\n randomizedAmount = Math.max(0, +(Math.floor(amount / multiplier) * multiplier)) + // zero out the least-significant digits\r\n random\r\n ret = +randomizedAmount.toFixed(2);\r\n break\r\n default:\r\n throw new Error(`Invalid currency: ${addressType}`)\r\n }\r\n return ret\r\n};\r\n\r\nexport default randomizeSatoshis;\r\n","import BigNumber from 'bignumber.js';\r\n\r\nexport const zero = new BigNumber(0);\r\n\r\nexport const resolveNumber = (value: BigNumber.Value) => {\r\n return new BigNumber(value);\r\n};\r\n\r\nexport const isGreaterThanZero = (value: BigNumber.Value) => {\r\n return zero.isLessThan(value)\r\n}\r\n","import { DECIMALS } from './constants';\r\nimport { isCrypto } from './currency';\r\nimport { formatBCH, formatPrice, formatXEC } from './format';\r\nimport { resolveNumber } from './number';\r\nimport randomizeSatoshis from './randomizeSats';\r\nimport { Currency, CurrencyObject } from './types';\r\n\r\nexport const getCurrencyObject = (\r\n amount: number,\r\n currencyType: Currency,\r\n randomSatoshis: boolean | number | undefined,\r\n): CurrencyObject => {\r\n let string = '';\r\n let float = 0;\r\n\r\n if (isCrypto(currencyType)) {\r\n let newAmount = randomSatoshis ? randomizeSatoshis(amount, currencyType, randomSatoshis) : amount;\r\n const decimals = DECIMALS[currencyType]\r\n const primaryUnit = resolveNumber(`${newAmount}`);\r\n\r\n if (primaryUnit?.c !== null) {\r\n float = parseFloat(resolveNumber(primaryUnit).toFixed(decimals));\r\n string = resolveNumber(`${primaryUnit}`).toFixed(decimals);\r\n\r\n if (currencyType === 'BCH') {\r\n string = formatBCH(string);\r\n } else if (currencyType === 'XEC') {\r\n string = formatXEC(string);\r\n }\r\n }\r\n } else {\r\n float = amount;\r\n string = formatPrice(amount, currencyType, DECIMALS.FIAT)\r\n }\r\n\r\n return {\r\n float,\r\n string,\r\n currency: currencyType,\r\n };\r\n};\r\n\r\nexport default {\r\n getCurrencyObject,\r\n};\r\n","import { AltpaymentClient } from \".\";\r\n\r\nexport const SIDESHIFT_BASE_URL = 'https://sideshift.ai/api/v2/'\r\n\r\ninterface SideshiftTokenDetails {\r\n [network: string]: {\r\n contractAddress: string;\r\n decimals: number;\r\n }\r\n}\r\n\r\nexport interface SideshiftCoin {\r\n networks: string[];\r\n coin: string;\r\n name: string;\r\n hasMemo: boolean;\r\n fixedOnly: string[] | boolean;\r\n variableOnly: string[] | boolean;\r\n tokenDetails: SideshiftTokenDetails;\r\n depositOffline?: string[] | boolean;\r\n settleOffline?: string[] | boolean;\r\n}\r\n\r\n\r\nexport interface SideshiftQuote {\r\n id: string;\r\n createdAt: string;\r\n depositCoin: string;\r\n settleCoin: string;\r\n depositNetwork: string;\r\n settleNetwork: string;\r\n expiresAt: string;\r\n depositAmount: string;\r\n settleAmount: string;\r\n rate: string;\r\n affiliateId: string;\r\n}\r\n\r\n\r\nexport interface SideshiftPair {\r\n min: string;\r\n max: string;\r\n rate: string;\r\n depositCoin: string;\r\n settleCoin: string;\r\n depositNetwork: string;\r\n settleNetwork: string;\r\n}\r\n\r\nexport interface SideshiftShift {\r\n id: string;\r\n createdAt: string;\r\n depositCoin: string;\r\n settleCoin: string;\r\n depositNetwork: string;\r\n settleNetwork: string;\r\n depositAddress: string;\r\n settleAddress: string;\r\n depositMin: string;\r\n depositMax: string;\r\n averageShiftSeconds: string;\r\n depositAmount: string;\r\n expiresAt: string;\r\n quoteId: string;\r\n rate: string;\r\n settleAmount: string;\r\n status: string;\r\n type: string;\r\n}\r\n\r\ntype ErrorType = 'quote-error' | 'shift-error'\r\nexport interface SideshiftError {\r\n errorType: ErrorType\r\n errorMessage: string\r\n}\r\n\r\nexport class SideshiftClient implements AltpaymentClient {\r\n public async getPaymentStatus (shiftId: string): Promise<SideshiftShift> {\r\n const res = await fetch(`${SIDESHIFT_BASE_URL}/shifts/${shiftId}?t=${(new Date()).getTime()}`);\r\n return (await res.json()) as SideshiftShift;\r\n }\r\n}\r\n","import React, { useEffect, useState, CSSProperties } from 'react';\r\nimport { isPropsTrue } from '../../util';\r\n\r\nexport interface BarChartProps {\r\n value: number;\r\n color: string;\r\n disabled: boolean;\r\n}\r\n\r\nexport const BarChart = (props: BarChartProps): React.ReactElement => {\r\n const { value, color, disabled } = props;\r\n const [barWidth, setBarWidth] = useState(0);\r\n\r\n\r\n const blurCSS = isPropsTrue(disabled) ? { filter: 'blur(5px)' } : {};\r\n\r\n const containerStyle: CSSProperties = {\r\n width: '100%',\r\n marginBottom: '20px',\r\n };\r\n\r\n const barHolder: CSSProperties = {\r\n height: '8px',\r\n borderRadius: '20px',\r\n backgroundColor: '#dddddd',\r\n position: 'relative',\r\n } as React.CSSProperties;\r\n\r\n const bar: CSSProperties = {\r\n left: '0',\r\n top: '0',\r\n bottom: '0',\r\n height: '8px',\r\n borderRadius: '20px',\r\n backgroundColor: `${color}`,\r\n transition: 'width 0.8s ease-out',\r\n position: 'absolute',\r\n };\r\n\r\n useEffect(() => {\r\n setTimeout(() => {\r\n setBarWidth(value > 100 ? 100 : Math.round(value));\r\n }, 800);\r\n }, [value]);\r\n\r\n return (\r\n <div style={containerStyle}>\r\n <div style={barHolder}>\r\n <div style={{ ...bar, width: `${barWidth}%`, ...blurCSS}} />\r\n </div>\r\n </div>\r\n );\r\n};\r\n\r\nBarChart.defaultProps = {\r\n value: 34,\r\n color: '#4bc846',\r\n};\r\n\r\nexport default BarChart;\r\n","export const sideShiftLogo = 'data:image/png;base64,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'\r\nexport const copyIcon = 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAGQAAABuCAMAAADmp0YAAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAyRpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMy1jMDExIDY2LjE0NTY2MSwgMjAxMi8wMi8wNi0xNDo1NjoyNyAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvIiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RSZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENTNiAoTWFjaW50b3NoKSIgeG1wTU06SW5zdGFuY2VJRD0ieG1wLmlpZDpDQTk0NEI3OThFMzIxMUVGQkNERDhEQjQ1RTlGOTk2OCIgeG1wTU06RG9jdW1lbnRJRD0ieG1wLmRpZDpDQTk0NEI3QThFMzIxMUVGQkNERDhEQjQ1RTlGOTk2OCI+IDx4bXBNTTpEZXJpdmVkRnJvbSBzdFJlZjppbnN0YW5jZUlEPSJ4bXAuaWlkOkNBOTQ0Qjc3OEUzMjExRUZCQ0REOERCNDVFOUY5OTY4IiBzdFJlZjpkb2N1bWVudElEPSJ4bXAuZGlkOkNBOTQ0Qjc4OEUzMjExRUZCQ0REOERCNDVFOUY5OTY4Ii8+IDwvcmRmOkRlc2NyaXB0aW9uPiA8L3JkZjpSREY+IDwveDp4bXBtZXRhPiA8P3hwYWNrZXQgZW5kPSJyIj8+PQtV5wAAAYBQTFRFOTk5Tk5OTExMGhoaLCwsPz8/IiIiJycnBAQEICAgKioqFRUVHBwcCAgICwsLHx8fAQEB4ODgDQ0N8vLyMTExqKiovLy8FhYWMDAwzs7O5OTkHh4e+Pj4MzMz8fHx2dnZLy8v2NjY5+fn4uLiNDQ09/f3qqqqWlpaDg4Ozc3Nl5eXt7e3FxcX3t7ea2tr6urq6+vrZmZm9fX129vblpaWvb29DAwMw8PD7Ozsra2twsLC6enpPT09goKC+vr67u7uv7+/Nzc3WVlZmJiYioqKiYmJaGhosrKy0NDQ1dXVpKSkj4+PSEhI4eHhz8/PExMTo6Ojr6+vdnZ2QkJCnJyccXFxOjo65eXltbW1fn5+RkZGn5+fi4uLjIyM5ubmsLCw8/Pz9PT0NTU16Ojo2traKSkp/f39kJCQ/Pz8xsbGXl5ebm5uxcXFbGxsgYGBoKCgoaGhnZ2dmZmZjY2NJCQkiIiIQEBAW1tbaWlpYGBgYWFhXFxcXV1dV1dXAAAA////NCYxYAAAAIB0Uk5T/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////wA4BUtnAAACdElEQVR42uzaZ1PbQBAGYDkY48SWhS2FCFeMTQgtgdA7CYH03hPSe+896P56GMB3irwnsG7lT/t+9Gn2mbM0exrdaQxO+UXENnJG0OSMfefev6oV00CiM+JgRJvxQcYcrByWIT2vHbxUZ2Gky8FMG4h8dnDzA0AexZERZ6Ye+YttOMk65IiDnwde5FoISK8X+SXGRm51KGRe54VsL3KDD40xtdzllb56EZsPLSoi4u4aciSriGR5pZwXsfhQWhFJy2dCSENIgQ/NhodU+dBUCMiTM6vfC1YhxYeij63dxbZae++Vd4GUfuqKDSoysBPyBqMPHjvqi1zF6baxbh9kBKunt+SlyCe8lUNbkCAVzPXpmwQ5jv0CBCBF3KX2FIj0uy/ZfB1qb7Duf9e/AxHxb8XPlrPpjZx/ejrdSCpDlzK8iAUic56X40AZF0/xcwgRvf2gQjccrBXJPIQQsahPKyCxWpGJov9M9isgBp+JSQghhBBCCCGEEEIIIYQQQgghhBBCCCFNRirNQIbDQw7xnybFN3xsZOKmuZWONrETg420Z7bj+la8BxuB0o+E7PUx4mYTZrLMcJB8Qm5EGRLSI0fi97EQlpMZ+hJDQ2Q3vjrK8BD4xusrW6PhIRfvfKmdG8BGUpMXOjfS11dybW26tjZU9k9i9Q3SFU0cTzqJMpMihGgcmQ9uDPEDSIkFCFkXz8KHKTNYBlqAjTM3csL9yGWCxVXiN4iUcDczL4MIm8M0Bl/CyCgmcpvBCLuOZ6RMGcKiaMhbJkWGkc4LJsaZHGHsD/4RiXqETSdVCf1Knu2AsPzHdds4EDDJZ61r3T5d558AAwDxw6DYwVV5JQAAAABJRU5ErkJggg=='","import React, { useEffect, useState } from 'react';\r\nimport {\r\n TextField,\r\n Grid,\r\n Select,\r\n MenuItem,\r\n makeStyles,\r\n InputLabel,\r\n FormControl,\r\n Typography\r\n} from '@material-ui/core';\r\nimport {\r\n resolveNumber,\r\n CryptoCurrency,\r\n DECIMALS\r\n} from '../../util';\r\nimport { Button, animation } from '../Button/Button';\r\nimport { Socket } from 'socket.io-client';\r\nimport { AltpaymentCoin, AltpaymentError, AltpaymentPair, AltpaymentShift } from '../../altpayment';\r\nimport { sideShiftLogo, copyIcon } from './SideShiftLogo'\r\n\r\ninterface AltpaymentProps {\r\n altpaymentSocket?: Socket;\r\n setUseAltpayment: Function;\r\n altpaymentShift?: AltpaymentShift;\r\n setAltpaymentShift: Function;\r\n shiftCompleted: boolean;\r\n setShiftCompleted: Function;\r\n altpaymentError?: AltpaymentError;\r\n setAltpaymentError: Function;\r\n coins: AltpaymentCoin[];\r\n loadingPair: boolean;\r\n setLoadingPair: Function;\r\n loadingShift: boolean;\r\n setLoadingShift: Function;\r\n coinPair?: AltpaymentPair;\r\n setCoinPair: Function;\r\n altpaymentEditable: boolean;\r\n animation?: animation;\r\n addressType: CryptoCurrency;\r\n to: string;\r\n thisAmount?: string | number | null\r\n updateAmount: Function;\r\n}\r\n\r\nexport const AltpaymentWidget: React.FunctionComponent<AltpaymentProps> = props => {\r\n\r\n const {\r\n altpaymentSocket,\r\n setUseAltpayment,\r\n altpaymentShift,\r\n setAltpaymentShift,\r\n shiftCompleted,\r\n setShiftCompleted,\r\n altpaymentError,\r\n setAltpaymentError,\r\n coins,\r\n loadingPair,\r\n loadingShift,\r\n coinPair,\r\n setCoinPair,\r\n altpaymentEditable,\r\n animation,\r\n addressType,\r\n thisAmount,\r\n updateAmount,\r\n setLoadingPair,\r\n setLoadingShift,\r\n to\r\n } = Object.assign({}, props);\r\n\r\n const [pairAmountMaxLength, setPairAmountMaxLength] = useState<number | undefined>(undefined);\r\n const [isAboveMinimumAltpaymentAmount, setIsAboveMinimumAltpaymentAmount] = useState<boolean | null>(null);\r\n const [isBelowMaximumAltpaymentAmount, setIsBelowMaximumAltpaymentAmount] = useState<boolean | null>(null);\r\n const [selectedCoin, setSelectedCoin] = useState<AltpaymentCoin|undefined>();\r\n const [selectedCoinNetwork, setSelectedCoinNetwork] = useState<string | undefined>(undefined);\r\n const [pairAmountFixedDecimals, setPairAmountFixedDecimals] = useState<string | undefined>(undefined);\r\n const [pairAmount, setPairAmount] = useState<string | undefined>(undefined);\r\n\r\n useEffect(() => {\r\n if (pairAmount && coinPair) {\r\n setIsBelowMaximumAltpaymentAmount(+pairAmount <= +coinPair.max)\r\n setIsAboveMinimumAltpaymentAmount(+pairAmount >= +coinPair.min)\r\n } else {\r\n setIsBelowMaximumAltpaymentAmount(true)\r\n setIsAboveMinimumAltpaymentAmount(true)\r\n }\r\n }, [pairAmount, coinPair])\r\n\r\n useEffect(() => {\r\n if (selectedCoin?.networks.length === 1) {\r\n setSelectedCoinNetwork(selectedCoin.networks[0])\r\n }\r\n }, [selectedCoin])\r\n\r\n useEffect(() => {\r\n if (coinPair && thisAmount && selectedCoin && selectedCoinNetwork) {\r\n const bigNumber = resolveNumber(+thisAmount / +coinPair.rate)\r\n const tokenDetails = selectedCoin.tokenDetails\r\n let decimals: number\r\n if (tokenDetails !== undefined) {\r\n decimals = tokenDetails[selectedCoinNetwork].decimals\r\n } else {\r\n decimals = coinPair.min.split('.')[1].length\r\n }\r\n\r\n const amountString = bigNumber.toFixed(decimals)\r\n setPairAmountFixedDecimals(amountString)\r\n\r\n // Besides decimals, account for the non-decimal part of the bigNumber\r\n // plus the '.' character.\r\n const floorAmount = pairAmount ? Math.floor(+pairAmount) : 1\r\n const nonDecimalCharCount = 1 + Math.ceil(Math.log10(floorAmount + 1))\r\n setPairAmountMaxLength(nonDecimalCharCount + decimals)\r\n }\r\n }, [coinPair, selectedCoin, thisAmount, pairAmount, selectedCoinNetwork])\r\n\r\n const requestPairRate = (): void => {\r\n if (selectedCoin !== undefined) {\r\n const from = `${selectedCoin.coin}-${selectedCoin?.networks[0]}`\r\n const to = addressType === 'XEC' ? `ecash-mainnet` : `bitcoincash-mainnet`\r\n if (altpaymentSocket !== undefined) {\r\n altpaymentSocket.emit('get-altpayment-rate', {from, to})\r\n }\r\n }\r\n }\r\n\r\n const handleCoinChange = async (e: React.ChangeEvent<{ name?: string; value: unknown }>) => {\r\n const coinName = e.target.value as string\r\n const selectedCoin = coins.find(c => c.coin === coinName)\r\n setSelectedCoinNetwork(selectedCoin?.networks[0])\r\n setSelectedCoin(selectedCoin)\r\n }\r\n\r\n const handleGetRateButtonClick = () => {\r\n setLoadingPair(true)\r\n requestPairRate()\r\n }\r\n\r\n const handleNetworkChange = async (e: React.ChangeEvent<{ name?: string; value: unknown }>) => {\r\n const networkName = e.target.value as string\r\n setSelectedCoinNetwork(networkName)\r\n }\r\n\r\n const handlePairAmountChange = (e: React.ChangeEvent<HTMLInputElement>) => {\r\n let pairAmount = e.target.value;\r\n if (pairAmount === '') {\r\n pairAmount = '0';\r\n }\r\n setPairAmount(pairAmount)\r\n\r\n if (coinPair !== undefined) {\r\n const settleCoinAmount = +coinPair.rate * +pairAmount\r\n\r\n if(Object.keys(DECIMALS).includes(coinPair.settleCoin)){\r\n updateAmount(settleCoinAmount.toFixed(DECIMALS[coinPair.settleCoin]))\r\n }\r\n }\r\n };\r\n\r\n const handleCreateQuoteButtonClick = () => {\r\n if (altpaymentSocket !== undefined && selectedCoin !== undefined) {\r\n setLoadingShift(true)\r\n altpaymentSocket.emit('create-altpayment-quote', {\r\n depositAmount: pairAmountFixedDecimals,\r\n settleCoin: addressType,\r\n depositCoin: selectedCoin?.coin,\r\n depositNetwork: selectedCoinNetwork,\r\n settleAddress: to\r\n });\r\n }\r\n }\r\n\r\n const resetTrade = () => {\r\n setCoinPair(undefined)\r\n setAltpaymentError(undefined)\r\n setAltpaymentShift(undefined)\r\n setPairAmount(undefined)\r\n setShiftCompleted(false)\r\n }\r\n\r\n const copyToClipboard = (elementId: string) => {\r\n const contentElement = document.getElementById(elementId);\r\n const copiedMessage = document.createElement(\"div\");\r\n copiedMessage.textContent = \"Copied!\";\r\n copiedMessage.style.position = \"absolute\";\r\n copiedMessage.style.width = \"calc(100% - 10px)\";\r\n copiedMessage.style.height = \"calc(100% - 20px)\";\r\n copiedMessage.style.alignItems = \"center\";\r\n copiedMessage.style.top = \"0\";\r\n copiedMessage.style.left = \"0\";\r\n copiedMessage.style.backgroundColor = \"#fff\";\r\n copiedMessage.style.borderRadius = \"5px\";\r\n copiedMessage.style.padding = \"10px 0 10px 10px\";\r\n copiedMessage.style.zIndex = \"10\";\r\n copiedMessage.style.display = \"none\";\r\n\r\n if (contentElement) {\r\n const content = contentElement.textContent || \"\";\r\n navigator.clipboard.writeText(content);\r\n contentElement.appendChild(copiedMessage);\r\n copiedMessage.style.display = \"flex\";\r\n\r\n setTimeout(() => {\r\n copiedMessage.style.display = \"none\";\r\n if (copiedMessage.parentElement === contentElement) {\r\n contentElement.removeChild(copiedMessage);\r\n }\r\n }, 2000);\r\n }\r\n };\r\n\r\n const useStyles = makeStyles({\r\n select_box: {\r\n minWidth: '220px'\r\n },\r\n option_outer_ctn: {\r\n display: 'flex',\r\n alignItems: 'center'\r\n },\r\n option_ctn: {\r\n display: 'flex',\r\n flexDirection: 'column',\r\n margin: '5px 0'\r\n },\r\n list_icon: {\r\n width: '28px',\r\n height: '28px',\r\n marginRight: '10px'\r\n },\r\n coin: {\r\n fontWeight: 'bold',\r\n lineHeight: '1em'\r\n },\r\n coin_name: {\r\n fontSize: '14px'\r\n },\r\n spacer: {\r\n height: '20px'\r\n },\r\n sideshift_ctn: {\r\n alignItems: 'center',\r\n display: 'flex',\r\n flexDirection: 'column',\r\n height: 'calc(100% - 20px)',\r\n width: '100%',\r\n position: 'absolute',\r\n zIndex: 9,\r\n top: '0',\r\n left: '0',\r\n background: '#f5f5f7',\r\n paddingTop: '20px'\r\n },\r\n header: {\r\n marginBottom:'30px',\r\n display: 'flex',\r\n alignItems: 'center',\r\n flexDirection: 'column',\r\n color: 'rgb(35, 31, 32)',\r\n fontSize: '0.9rem',\r\n\r\n '& img': {\r\n width: '150px',\r\n marginTop: '10px'\r\n },\r\n },\r\n back_link: {\r\n fontSize: '14px',\r\n marginTop: '20px',\r\n cursor: 'pointer',\r\n border: '1px solid #000',\r\n opacity: '0.7',\r\n padding: '2px 20px',\r\n borderRadius: '3px',\r\n '&:hover': {\r\n opacity: '1'\r\n },\r\n },\r\n shift_ready: {\r\n width: '100%',\r\n display: 'flex',\r\n flexDirection: 'column',\r\n '& h4': {\r\n margin: '0',\r\n fontSize: '20px',\r\n borderBottom: '1px solid #000',\r\n paddingBottom: '10px',\r\n textAlign: 'center',\r\n },\r\n },\r\n copy_ctn: {\r\n display: 'flex',\r\n alignItems: 'center',\r\n '& > div': {\r\n position: 'relative'\r\n },\r\n },\r\n editAmount: {\r\n width: '100%',\r\n margin: '12px auto 10px',\r\n display: 'flex',\r\n alignItems: 'flex-end',\r\n '& > div': {\r\n width: '100%',\r\n },\r\n '& span': {\r\n marginLeft: '4px',\r\n fontSize: '16px',\r\n }\r\n },\r\n amount_error: {\r\n position: 'absolute',\r\n bottom: '10px',\r\n textAlign: 'center',\r\n background: '#00000014',\r\n padding: '10px',\r\n borderRadius: '5px'\r\n },\r\n error_msg: {\r\n textAlign: 'center',\r\n background: '#ee010119',\r\n padding: '10px',\r\n borderRadius: '5px',\r\n color: 'red'\r\n },\r\n shift_label: {\r\n fontSize: '14px',\r\n marginLeft: '5px',\r\n marginTop: '20px',\r\n marginBottom: '2px',\r\n fontWeight: 600\r\n },\r\n shift_input: {\r\n background: '#ffffff',\r\n padding: '10px',\r\n borderRadius: '5px',\r\n fontSize: '14px',\r\n border: '1px solid #b3b3b3',\r\n wordBreak: 'break-all',\r\n flexGrow: 1,\r\n position: 'relative',\r\n },\r\n copy_btn: {\r\n background: '#ffffff',\r\n padding: '10px',\r\n borderRadius: '5px',\r\n border: '1px solid #b3b3b3',\r\n marginLeft: '5px',\r\n display: 'flex',\r\n alignItems: 'center',\r\n cursor: 'pointer',\r\n alignSelf: 'stretch',\r\n transition: 'all ease-in-out 200ms',\r\n '&:hover': {\r\n background: '#f1f1f1'\r\n },\r\n '& img': {\r\n width: '15px',\r\n },\r\n },\r\n shift_complete: {\r\n display: 'flex',\r\n alignItems: 'center',\r\n height: '100%',\r\n flex: '1',\r\n width: '100%',\r\n fontSize: '18px'\r\n }\r\n });\r\n\r\n const classes = useStyles();\r\n\r\n const checkCoin = (coin:string) => {\r\n let coinString = coin.toLowerCase();\r\n if (coinString.includes('.')) {\r\n return 'btc';\r\n }\r\n if (coinString === 'bitcoin') {\r\n return 'harrypotterobamasonic10inu';\r\n }\r\n return coinString;\r\n }\r\n\r\n return (\r\n <Typography component=\"div\" className={classes.sideshift_ctn}>\r\n {altpaymentError ? (\r\n <>\r\n <p className={classes.error_msg}>Error: {altpaymentError.errorMessage}</p>\r\n <div className={classes.back_link} onClick={resetTrade}>Back</div>\r\n </>\r\n ) : (\r\n <>\r\n {\r\n altpaymentShift ? (\r\n shiftCompleted ? (\r\n <div className={classes.shift_complete}>Shift Completed!</div>\r\n ) : (\r\n <div className={classes.shift_ready}>\r\n <h4>Shift Ready!</h4>\r\n <span className={classes.shift_label}>Send</span>\r\n <div className={classes.copy_ctn}>\r\n <div className={classes.shift_input}>\r\n <span id=\"shift_amount\">{altpaymentShift.depositAmount}</span>{' '}{altpaymentShift.depositCoin}\r\n </div>\r\n <div className={classes.copy_btn} onClick={() => copyToClipboard('shift_amount')}>\r\n <img\r\n src={copyIcon}\r\n alt=\"Copy\"\r\n />\r\n </div>\r\n </div>\r\n <span className={classes.shift_label}>To</span>\r\n <div className={classes.copy_ctn}>\r\n <div id=\"to_address\" className={classes.shift_input}>\r\n {altpaymentShift.depositAddress}\r\n </div>\r\n <div className={classes.copy_btn} onClick={() => copyToClipboard('to_address')}>\r\n <img\r\n src={copyIcon}\r\n alt=\"Copy\"\r\n />\r\n </div>\r\n </div>\r\n <span className={classes.shift_label}>Network</span>\r\n <div className={classes.shift_input}>{selectedCoinNetwork}</div>\r\n <span className={classes.shift_label}>SideShift ID</span>\r\n <div className={classes.copy_ctn}>\r\n <div id=\"sideshift_id\" className={classes.shift_input}>\r\n {altpaymentShift.id}\r\n </div>\r\n <div className={classes.copy_btn} onClick={() => copyToClipboard('sideshift_id')}>\r\n <img\r\n src={copyIcon}\r\n alt=\"Copy\"\r\n />\r\n </div>\r\n </div>\r\n </div>\r\n )\r\n ) : loadingShift ? (\r\n <p>Loading Shift...</p>\r\n ) : coinPair ? (\r\n <>\r\n <p>\r\n {' '}\r\n 1 {selectedCoin?.name} ~={' '}\r\n {resolveNumber(coinPair.rate).toFixed(DECIMALS[coinPair.settleCoin])} {coinPair.settleCoin}{' '}\r\n </p>\r\n {altpaymentEditable ? (\r\n <Grid\r\n container\r\n spacing={2}\r\n alignItems=\"center\"\r\n justifyContent=\"center\"\r\n style={{ margin: '6px auto', width: '100%' }}\r\n >\r\n <Grid item>\r\n <TextField\r\n label=\"Amount\"\r\n value={pairAmount ?? 0}\r\n onChange={handlePairAmountChange}\r\n inputProps={{\r\n maxLength: pairAmountMaxLength,\r\n type: 'number',\r\n pattern: '[0-9]*',\r\n inputMode: 'numeric'\r\n }}\r\n />\r\n </Grid>\r\n </Grid>\r\n ) : (\r\n null\r\n )}\r\n <div></div>\r\n <div style={loadingPair ||\r\n selectedCoinNetwork === undefined ||\r\n (altpaymentEditable && !pairAmount) ||\r\n !isAboveMinimumAltpaymentAmount ||\r\n !isBelowMaximumAltpaymentAmount ? {opacity: '0.5', cursor: 'not-allowed'} : {}}>\r\n <Button\r\n text={`Send ${selectedCoin?.name}`}\r\n hoverText={`Send ${selectedCoin?.name}`}\r\n onClick={handleCreateQuoteButtonClick}\r\n disabled={\r\n loadingPair ||\r\n selectedCoinNetwork === undefined ||\r\n (altpaymentEditable && !pairAmount) ||\r\n !isAboveMinimumAltpaymentAmount ||\r\n !isBelowMaximumAltpaymentAmount\r\n }\r\n animation={animation}\r\n />\r\n </div>\r\n {!isAboveMinimumAltpaymentAmount && (\r\n <p className={classes.amount_error}>Amount is below minimum.</p>\r\n )}\r\n {!isBelowMaximumAltpaymentAmount && (\r\n <p className={classes.amount_error}>Amount is above maximum.</p>\r\n )}\r\n </>\r\n ) : (\r\n <>\r\n {coins.length === 0 && <div>Loading...</div>}\r\n {coins.length > 0 && (\r\n <>\r\n <div className={classes.header}>\r\n Swap coins with\r\n <a href=\"https://sideshift.ai\" target=\"_blank\">\r\n <img src={sideShiftLogo} alt='SideShift' />\r\n </a>\r\n </div>\r\n <FormControl>\r\n <InputLabel id=\"select-coin-label\">\r\n Select a coin\r\n </InputLabel>\r\n <Select\r\n labelId=\"select-coin-label\"\r\n className={classes.select_box}\r\n value={selectedCoin?.coin ?? null}\r\n onChange={e => {\r\n handleCoinChange(e);\r\n }}\r\n >\r\n {coins.map(coin => (\r\n <MenuItem key={coin.coin} value={coin.coin}>\r\n <div className={classes.option_outer_ctn}>\r\n <img\r\n className={classes.list_icon}\r\n src={`https://sideshift.ai/coin-icons/${checkCoin(\r\n coin.coin,\r\n )}.svg`}\r\n />\r\n <div className={classes.option_ctn}>\r\n <span className={classes.coin}>\r\n {coin.coin}\r\n </span>\r\n <span className={classes.coin_name}>\r\n {coin.name}\r\n </span>\r\n </div>\r\n </div>\r\n </MenuItem>\r\n ))}\r\n </Select>\r\n </FormControl>\r\n <div className={classes.spacer} />\r\n {selectedCoin && selectedCoin.networks.length > 1 && (\r\n <>\r\n {\r\n <FormControl>\r\n <InputLabel id=\"select-network-label\">\r\n Select a network\r\n </InputLabel>\r\n\r\n <Select\r\n labelId=\"select-network-label\"\r\n className={classes.select_box}\r\n value={selectedCoinNetwork ?? null}\r\n onChange={e => {\r\n handleNetworkChange(e);\r\n }}\r\n >\r\n {selectedCoin.networks.map(network => (\r\n <MenuItem key={network} value={network}>\r\n <div className={classes.option_outer_ctn}>\r\n <div className={classes.option_ctn}>\r\n <span className={classes.coin}>\r\n {network.charAt(0).toUpperCase() +\r\n network.slice(1)}\r\n </span>\r\n </div>\r\n </div>\r\n </MenuItem>\r\n ))}\r\n </Select>\r\n </FormControl>\r\n }\r\n </>\r\n )}\r\n </>\r\n )}\r\n <div className={classes.spacer} />\r\n {loadingPair ||\r\n selectedCoin === undefined ||\r\n selectedCoinNetwork === undefined ? null : (\r\n <Button\r\n text={'Send with SideShift'}\r\n hoverText={'Send with SideShift'}\r\n onClick={handleGetRateButtonClick}\r\n disabled={\r\n loadingPair ||\r\n selectedCoin === undefined ||\r\n selectedCoinNetwork === undefined\r\n }\r\n animation={animation}\r\n />\r\n )}\r\n <div className={classes.back_link} onClick={() => {setUseAltpayment(false)}}>Back</div>\r\n </>\r\n )\r\n // END: Altpayment region\r\n }\r\n {coinPair && !loadingShift && (\r\n <div className={classes.back_link} onClick={resetTrade}>Back</div>\r\n )}\r\n </>\r\n )}\r\n </Typography>\r\n );\r\n};\r\n\r\nexport default AltpaymentWidget;\r\n","import {\r\n Box,\r\n CircularProgress,\r\n Fade,\r\n Typography,\r\n makeStyles,\r\n TextField,\r\n} from '@material-ui/core';\r\nimport React, { useCallback, useEffect, useMemo, useState } from 'react';\r\nimport copy from 'copy-to-clipboard';\r\nimport QRCode, { BaseQRCodeProps } from 'qrcode.react';\r\nimport io, { Socket } from 'socket.io-client';\r\nimport config from '../../../../paybutton-config.json';\r\nimport { Theme, ThemeName, ThemeProvider, useTheme } from '../../themes';\r\nimport { Button, animation } from '../Button/Button';\r\nimport BarChart from '../BarChart/BarChart';\r\nimport {\r\n Currency,\r\n getAddressBalance,\r\n getAddressDetails,\r\n isFiat,\r\n Transaction,\r\n getCashtabProviderStatus,\r\n CryptoCurrency,\r\n DECIMALS,\r\n CurrencyObject,\r\n getCurrencyObject,\r\n formatPrice,\r\n txsListener,\r\n encodeOpReturnProps,\r\n isValidCashAddress,\r\n isValidXecAddress,\r\n getCurrencyTypeFromAddress,\r\n altpaymentListener,\r\n CURRENCY_PREFIXES_MAP,\r\n CRYPTO_CURRENCIES,\r\n isPropsTrue\r\n} from '../../util';\r\nimport AltpaymentWidget from './AltpaymentWidget';\r\nimport { AltpaymentPair, AltpaymentShift, AltpaymentError, AltpaymentCoin, MINIMUM_ALTPAYMENT_DOLLAR_AMOUNT } from '../../altpayment';\r\n\r\ntype QRCodeProps = BaseQRCodeProps & { renderAs: 'svg' };\r\n\r\nexport interface WidgetProps {\r\n to: string;\r\n amount?: number | null | string;\r\n setAmount?: Function;\r\n opReturn?: string;\r\n paymentId?: string;\r\n disablePaymentId?: boolean;\r\n text?: string;\r\n ButtonComponent?: React.ComponentType;\r\n success: boolean;\r\n successText?: string;\r\n theme?: ThemeName | Theme;\r\n foot?: React.ReactNode;\r\n disabled: boolean;\r\n goalAmount?: number | string | null;\r\n currency?: Currency;\r\n animation?: animation;\r\n currencyObject?: CurrencyObject | undefined;\r\n setCurrencyObject?: Function;\r\n randomSatoshis?: boolean | number;\r\n price?: number | undefined;\r\n usdPrice?: number | undefined;\r\n editable?: boolean;\r\n setNewTxs: Function;\r\n newTxs?: Transaction[];\r\n wsBaseUrl?: string;\r\n apiBaseUrl?: string;\r\n loading?: boolean;\r\n hoverText?: string;\r\n setAltpaymentShift: Function;\r\n altpaymentShift?: AltpaymentShift | undefined,\r\n useAltpayment: boolean\r\n setUseAltpayment: Function;\r\n shiftCompleted: boolean\r\n setShiftCompleted: Function;\r\n disableAltpayment?: boolean;\r\n contributionOffset?: number\r\n}\r\n\r\ninterface StyleProps {\r\n success: boolean;\r\n loading: boolean;\r\n theme: Theme;\r\n}\r\n\r\nconst useStyles = makeStyles({\r\n root: {\r\n minWidth: '240px !important',\r\n background: '#f5f5f7 !important',\r\n position: 'relative',\r\n },\r\n qrCode: ({ success, loading, theme }: StyleProps) => ({\r\n background: '#fff !important',\r\n border: '1px solid #eee !important',\r\n borderRadius: '4px !important',\r\n outline: 'none !important',\r\n lineHeight: '0 !important',\r\n maxWidth: '28vh !important',\r\n maxHeight: '28vh !important',\r\n position: 'relative',\r\n padding: '1rem !important',\r\n cursor: 'pointer !important',\r\n userSelect: 'none',\r\n '&:active': {\r\n borderWidth: '2px !important',\r\n margin: '-1px !important',\r\n },\r\n '& path': {\r\n opacity: loading ? 0 : success ? 0.35 : 1,\r\n color: theme.palette.secondary,\r\n },\r\n '& image': {\r\n opacity: loading ? 0 : 1,\r\n },\r\n }),\r\n copyTextContainer: ({ loading }: StyleProps) => ({\r\n display: loading ? 'none' : 'block',\r\n background: '#ffffffcc !important',\r\n padding: '0 0.15rem 0.15rem 0 !important',\r\n }),\r\n copyText: ({ theme }: StyleProps) => ({\r\n lineHeight: '1.2em !important',\r\n fontSize: '0.7em !important',\r\n color: `${theme.palette.tertiary} !important`,\r\n textShadow:\r\n '#fff -2px 0 1px, #fff 0 -2px 1px, #fff 0 2px 1px, #fff 2px 0 1px !important',\r\n '&:disabled span': {\r\n filter: 'blur(2px)',\r\n color: 'rgba(0, 0, 0, 0.5)',\r\n },\r\n }),\r\n text: ({ theme }: StyleProps) => ({\r\n fontSize: '0.9rem !important',\r\n color: `${theme.palette.tertiary} !important`,\r\n }),\r\n spinner: ({ theme }: StyleProps) => ({\r\n color: `${theme.palette.primary} !important`,\r\n }),\r\n footer: () => ({\r\n fontSize: '0.6rem !important',\r\n color: '#a8a8a8 !important',\r\n fontWeight: 'normal',\r\n userSelect: 'none',\r\n }),\r\n sideShiftLink: ({ theme }: StyleProps) => ({\r\n fontSize: '14px',\r\n cursor: 'pointer',\r\n padding: '6px 12px',\r\n marginTop: '20px',\r\n background: '#e9e9e9',\r\n borderRadius: '5px',\r\n transition: 'all ease-in-out 200ms',\r\n '&:hover': {\r\n background: `${theme.palette.primary}`,\r\n color: `${theme.palette.secondary}`,\r\n },\r\n }),\r\n editAmount: {\r\n width: '100%',\r\n margin: '12px auto 10px',\r\n display: 'flex',\r\n alignItems: 'flex-end',\r\n '& > div': {\r\n width: '100%',\r\n },\r\n '& span': {\r\n marginLeft: '4px',\r\n fontSize: '16px',\r\n }\r\n },\r\n error: () => ({\r\n fontSize: '0.9rem !important',\r\n color: '#EB3B3B !important',\r\n }),\r\n});\r\n\r\n\r\nexport const Widget: React.FunctionComponent<WidgetProps> = props => {\r\n const {\r\n to,\r\n foot,\r\n success,\r\n paymentId,\r\n successText,\r\n disablePaymentId,\r\n goalAmount,\r\n ButtonComponent = Button,\r\n currency = getCurrencyTypeFromAddress(to),\r\n animation,\r\n randomSatoshis = false,\r\n editable,\r\n setNewTxs,\r\n newTxs,\r\n apiBaseUrl,\r\n usdPrice,\r\n wsBaseUrl,\r\n hoverText = Button.defaultProps.hoverText,\r\n setAltpaymentShift,\r\n altpaymentShift,\r\n useAltpayment,\r\n setUseAltpayment,\r\n shiftCompleted,\r\n setShiftCompleted,\r\n disableAltpayment,\r\n contributionOffset\r\n } = Object.assign({}, Widget.defaultProps, props);\r\n\r\n const [loading, setLoading] = useState(true);\r\n const [copied, setCopied] = useState(false);\r\n const [recentlyCopied, setRecentlyCopied] = useState(false);\r\n const [totalReceived, setTotalReceived] = useState<number | undefined>(\r\n undefined,\r\n );\r\n const [disabled, setDisabled] = useState(false);\r\n const [errorMsg, setErrorMsg] = useState('');\r\n const [goalText, setGoalText] = useState('');\r\n const [goalPercent, setGoalPercent] = useState(0);\r\n const [socket, setSocket] = useState<Socket | undefined>(undefined);\r\n const [addressType, setAddressType] = useState<CryptoCurrency>(\r\n getCurrencyTypeFromAddress(to),\r\n );\r\n\r\n const price = props.price ?? 0;\r\n const [url, setUrl] = useState('');\r\n const [userEditedAmount, setUserEditedAmount] = useState<CurrencyObject>();\r\n const [text, setText] = useState(`Send any amount of ${addressType}`);\r\n const [widgetButtonText, setWidgetButtonText] = useState('Send Payment');\r\n const [opReturn, setOpReturn] = useState<string | undefined>();\r\n\r\n const [altpaymentSocket, setAltpaymentSocket] = useState<Socket | undefined>(undefined);\r\n const [coins, setCoins] = useState<AltpaymentCoin[]>([]);\r\n const [loadingPair, setLoadingPair] = useState<boolean>(false);\r\n const [coinPair, setCoinPair] = useState<AltpaymentPair | undefined>();\r\n const [loadingShift, setLoadingShift] = useState(false);\r\n const [altpaymentError, setAltpaymentError] = useState<AltpaymentError | undefined>(undefined);\r\n const [altpaymentEditable, setAltpaymentEditable] = useState<boolean>(false);\r\n const [isAboveMinimumAltpaymentUSDAmount, setIsAboveMinimumAltpaymentUSDAmount] = useState<boolean | null>(null);\r\n\r\n const theme = useTheme(props.theme, isValidXecAddress(to));\r\n const classes = useStyles({ success, loading, theme });\r\n\r\n const [thisAmount, setThisAmount] = useState(props.amount);\r\n const [hasPrice, setHasPrice] = useState(props.price !== undefined && props.price > 0);\r\n const [thisCurrencyObject, setThisCurrencyObject] = useState(\r\n props.currencyObject,\r\n );\r\n\r\n const blurCSS = isPropsTrue(disabled) ? { filter: 'blur(5px)' } : {};\r\n\r\n const bchSvg = useMemo((): string => {\r\n const color = theme.palette.logo ?? theme.palette.primary;\r\n return `data:image/svg+xml,%3C%3Fxml version='1.0' encoding='UTF-8'%3F%3E%3Csvg version='1.1' viewBox='0 0 34 34' xmlns='http://www.w3.org/2000/svg'%3E%3Cg transform='translate(1,1)'%3E%3Ccircle cx='16' cy='16' r='17' fill='%23fff' stroke-width='1.0625'/%3E%3C/g%3E%3Cg transform='translate(1,1)' fill-rule='evenodd'%3E%3Ccircle cx='16' cy='16' r='16' fill='${window.encodeURIComponent(\r\n color,\r\n )}'/%3E%3Cpath d='m21.207 10.534c-0.776-1.972-2.722-2.15-4.988-1.71l-0.807-2.813-1.712 0.491 0.786 2.74c-0.45 0.128-0.908 0.27-1.363 0.41l-0.79-2.758-1.711 0.49 0.805 2.813c-0.368 0.114-0.73 0.226-1.085 0.328l-3e-3 -0.01-2.362 0.677 0.525 1.83s1.258-0.388 1.243-0.358c0.694-0.199 1.035 0.139 1.2 0.468l0.92 3.204c0.047-0.013 0.11-0.029 0.184-0.04l-0.181 0.052 1.287 4.49c0.032 0.227 4e-3 0.612-0.48 0.752 0.027 0.013-1.246 0.356-1.246 0.356l0.247 2.143 2.228-0.64c0.415-0.117 0.825-0.227 1.226-0.34l0.817 2.845 1.71-0.49-0.807-2.815a65.74 65.74 0 0 0 1.372-0.38l0.802 2.803 1.713-0.491-0.814-2.84c2.831-0.991 4.638-2.294 4.113-5.07-0.422-2.234-1.724-2.912-3.471-2.836 0.848-0.79 1.213-1.858 0.642-3.3zm-0.65 6.77c0.61 2.127-3.1 2.929-4.26 3.263l-1.081-3.77c1.16-0.333 4.704-1.71 5.34 0.508zm-2.322-5.09c0.554 1.935-2.547 2.58-3.514 2.857l-0.98-3.419c0.966-0.277 3.915-1.455 4.494 0.563z' fill='%23fff' fill-rule='nonzero'/%3E%3C/g%3E%3C/svg%3E%0A`;\r\n }, [theme]);\r\n\r\n const xecSvg =\r\n \"data:image/svg+xml;charset=UTF-8,%3csvg version='1.1' id='Layer_1' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' x='0px' y='0px' width='576px' height='576px' viewBox='0 0 576 576' enable-background='new 0 0 576 576' xml:space='preserve'%3e%3cg transform='translate(1,1)'%3e%3ccircle fill='%23FFFFFF' cx='287' cy='287' r='288'/%3e%3c/g%3e%3cpath fill='%23FFFFFF' d='M325.089,228.325l-67.15,38.668c-1.734,0.995-2.794,2.85-2.773,4.849v32.443 c-0.019,1.954,1.05,3.757,2.773,4.681l28.122,16.22c1.635,1.039,3.723,1.039,5.359,0l116.046-66.833 c19.694-11.393,19.694-44.216,0-55.609l-104.294-60.057c-8.867-5.357-19.975-5.357-28.842,0l-104.294,60.078 c-9.056,5.074-14.637,14.671-14.569,25.052c0,40.235,0.17,80.28,0,120.325c-0.085,10.362,5.461,19.954,14.485,25.052l104.294,60.247 c8.914,5.188,19.928,5.188,28.843,0l104.378-60.247c9.017-5.085,14.521-14.702,14.337-25.052v-52.306l-124.136,71.83 c-5.537,3.283-12.423,3.283-17.959,0l-55.439-32.124c-5.612-3.147-9.056-9.11-8.979-15.545V255.96 c-0.028-6.327,3.322-12.188,8.788-15.374c18.487-10.716,37.122-21.409,55.609-32.125c5.542-3.262,12.416-3.262,17.958,0 l27.53,15.713c1.13,0.727,1.459,2.233,0.732,3.365C325.7,227.862,325.42,228.131,325.089,228.325z'/%3e%3cpath fill='%230074C2' d='M288.878,16.941C139.176,16.941,17.819,138.298,17.819,288c0,149.701,121.357,271.059,271.059,271.059 c149.701,0,271.059-121.357,271.059-271.059C559.937,138.298,438.579,16.941,288.878,16.941z M325.089,224.174l-27.529-15.713 c-5.541-3.262-12.415-3.262-17.957,0c-18.487,10.715-37.122,21.409-55.609,32.125c-5.466,3.186-8.816,9.047-8.788,15.374v64.037 c-0.078,6.435,3.366,12.397,8.979,15.545l55.418,32.124c5.536,3.283,12.422,3.283,17.957,0l124.138-71.83v52.306 c0.204,10.327-5.257,19.938-14.231,25.052L303.193,433.44c-8.915,5.188-19.928,5.188-28.843,0l-104.315-60.247 c-9.056-5.075-14.637-14.671-14.569-25.052c0.17-40.045,0-80.111,0-120.325c-0.085-10.363,5.461-19.956,14.485-25.052 l104.294-60.078c8.868-5.357,19.975-5.357,28.843,0l104.378,60.078c19.694,11.393,19.694,44.217,0,55.609L291.42,325.186 c-1.636,1.039-3.724,1.039-5.359,0l-28.122-16.22c-1.724-0.924-2.792-2.727-2.773-4.681v-32.443 c-0.021-1.999,1.04-3.854,2.773-4.849l67.15-38.668c1.146-0.705,1.506-2.204,0.802-3.35 C325.689,224.649,325.416,224.375,325.089,224.174z'/%3e%3c/svg%3e\";\r\n\r\n const checkSvg = useMemo((): string => {\r\n const color = theme.palette.logo ?? theme.palette.primary;\r\n return `data:image/svg+xml,%3Csvg version='1.1' viewBox='1.65 1.65 20.65 20.65' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm-2 15l-5-5 1.41-1.41L10 14.17l7.59-7.59L19 8l-9 9z' fill='${window.encodeURIComponent(\r\n color,\r\n )}' stroke='%23fff' stroke-width='.6'/%3E%3Cpath d='m7.2979 14.697-2.6964-2.6966 0.89292-0.8934c0.49111-0.49137 0.90364-0.88958 0.91675-0.88491 0.013104 0.0047 0.71923 0.69866 1.5692 1.5422 0.84994 0.84354 1.6548 1.6397 1.7886 1.7692l0.24322 0.23547 7.5834-7.5832 1.8033 1.8033-9.4045 9.4045z' fill='%23fff' stroke-width='.033708'/%3E%3C/svg%3E%0A`;\r\n }, [theme]);\r\n\r\n useEffect((): (() => void) | undefined => {\r\n if (!recentlyCopied) return;\r\n\r\n const timer = setTimeout((): void => {\r\n setRecentlyCopied(false);\r\n }, 1000);\r\n\r\n return (): void => clearTimeout(timer);\r\n }, [recentlyCopied]);\r\n\r\n useEffect(() => {\r\n setHasPrice(price !== undefined && price > 0)\r\n }, [price])\r\n\r\n useEffect(() => {\r\n const setupAltpaymentSocket = async (): Promise<void> => {\r\n if (altpaymentSocket !== undefined) {\r\n altpaymentSocket.disconnect();\r\n }\r\n const newSocket = io(`${wsBaseUrl ?? config.wsBaseUrl}/altpayment`, {\r\n forceNew: true,\r\n });\r\n setAltpaymentSocket(newSocket);\r\n altpaymentListener({\r\n addressType,\r\n socket: newSocket,\r\n setCoins,\r\n setCoinPair,\r\n setLoadingPair,\r\n setAltpaymentShift,\r\n setLoadingShift,\r\n setAltpaymentError,\r\n })\r\n }\r\n\r\n const setupTxsSocket = async (): Promise<void> => {\r\n void getAddressDetails(to, apiBaseUrl);\r\n if (socket !== undefined) {\r\n socket.disconnect();\r\n }\r\n const newSocket = io(`${wsBaseUrl ?? config.wsBaseUrl}/addresses`, {\r\n forceNew: true,\r\n query: { addresses: [to], dummy: 'hehe' },\r\n });\r\n setSocket(newSocket);\r\n txsListener(newSocket, setNewTxs);\r\n }\r\n\r\n (async () => {\r\n await setupTxsSocket()\r\n if (useAltpayment) {\r\n await setupAltpaymentSocket()\r\n } else if (altpaymentSocket) {\r\n altpaymentSocket.disconnect()\r\n }\r\n })()\r\n\r\n return () => {\r\n if (socket !== undefined) {\r\n socket.disconnect();\r\n }\r\n if (altpaymentSocket !== undefined) {\r\n altpaymentSocket.disconnect();\r\n }\r\n }\r\n }, [to, useAltpayment]);\r\n\r\n const tradeWithAltpayment = () => {\r\n if (setUseAltpayment) {\r\n setUseAltpayment(true)\r\n }\r\n }\r\n\r\n useEffect(() => {\r\n if (thisAmount === undefined || thisAmount === null || thisAmount === 0) {\r\n setAltpaymentEditable(true)\r\n }\r\n if (isPropsTrue(editable)) {\r\n setAltpaymentEditable(true)\r\n }\r\n }, [])\r\n\r\n useEffect(() => {\r\n (async (): Promise<void> => {\r\n const balance = await getAddressBalance(to, apiBaseUrl);\r\n setTotalReceived(balance);\r\n setLoading(false);\r\n })();\r\n }, [newTxs]);\r\n\r\n useEffect(() => {\r\n const invalidAmount =\r\n thisAmount !== undefined && thisAmount && isNaN(+thisAmount);\r\n\r\n if (isValidCashAddress(to) || isValidXecAddress(to)) {\r\n setDisabled(isPropsTrue(props.disabled));\r\n setErrorMsg('');\r\n } else if (invalidAmount) {\r\n setDisabled(true);\r\n setErrorMsg('Amount should be a number');\r\n } else {\r\n setDisabled(true);\r\n setErrorMsg('Invalid Recipient');\r\n }\r\n if (usdPrice && thisAmount) {\r\n const usdAmount = usdPrice * +thisAmount\r\n setIsAboveMinimumAltpaymentUSDAmount(usdAmount >= MINIMUM_ALTPAYMENT_DOLLAR_AMOUNT)\r\n }\r\n }, [to, thisAmount, usdPrice]);\r\n\r\n useEffect(() => {\r\n const invalidAmount =\r\n thisAmount !== undefined && thisAmount && isNaN(+thisAmount);\r\n const isNegativeNumber =\r\n typeof thisAmount === 'string' && thisAmount.startsWith('-');\r\n let cleanAmount: any;\r\n\r\n if (invalidAmount) {\r\n setDisabled(true);\r\n setErrorMsg('Amount should be a number');\r\n } else if (isNegativeNumber) {\r\n setDisabled(true);\r\n setErrorMsg('Amount should be positive');\r\n } else {\r\n if (isValidCashAddress(to) || isValidXecAddress(to)) {\r\n setErrorMsg('');\r\n } else {\r\n setErrorMsg('Invalid Recipient');\r\n }\r\n }\r\n\r\n if (userEditedAmount !== undefined && thisAmount && addressType) {\r\n const obj = getCurrencyObject(+thisAmount, currency, false);\r\n setThisCurrencyObject(obj);\r\n if (props.setCurrencyObject) {\r\n props.setCurrencyObject(obj);\r\n }\r\n } else if (thisAmount && addressType) {\r\n cleanAmount = +thisAmount;\r\n const obj = getCurrencyObject(cleanAmount, currency, randomSatoshis);\r\n setThisCurrencyObject(obj);\r\n if (props.setCurrencyObject) {\r\n props.setCurrencyObject(obj);\r\n }\r\n }\r\n }, [thisAmount, currency, userEditedAmount]);\r\n\r\n useEffect(() => {\r\n if (to === undefined) {\r\n return;\r\n }\r\n const address = to;\r\n let url;\r\n\r\n const addressType: Currency = getCurrencyTypeFromAddress(address);\r\n setAddressType(addressType);\r\n setWidgetButtonText(`Send with ${addressType} wallet`);\r\n\r\n if (thisCurrencyObject && hasPrice) {\r\n const convertedAmount = thisCurrencyObject.float / price\r\n const convertedObj = price\r\n ? getCurrencyObject(\r\n convertedAmount,\r\n addressType,\r\n randomSatoshis,\r\n )\r\n : null;\r\n if (convertedObj) {\r\n setText(\r\n `Send ${thisCurrencyObject.string} ${thisCurrencyObject.currency} = ${convertedObj.string} ${addressType}`,\r\n );\r\n url = resolveUrl(addressType, convertedObj.float);\r\n setUrl(url ?? \"\");\r\n }\r\n } else {\r\n const notZeroValue: boolean =\r\n thisCurrencyObject?.float !== undefined && thisCurrencyObject.float > 0;\r\n if (!isFiat(currency) && thisCurrencyObject && notZeroValue) {\r\n const currency: string = thisCurrencyObject.currency;\r\n setText(`Send ${thisCurrencyObject.string} ${currency}`);\r\n url = resolveUrl(currency, thisCurrencyObject?.float);\r\n } else {\r\n setText(`Send any amount of ${addressType}`);\r\n url = resolveUrl(addressType);\r\n }\r\n setUrl(url ?? \"\");\r\n }\r\n }, [to, thisCurrencyObject, price, thisAmount, opReturn, hasPrice]);\r\n\r\n useEffect(() => {\r\n try {\r\n setOpReturn(\r\n encodeOpReturnProps({\r\n opReturn: props.opReturn,\r\n paymentId,\r\n disablePaymentId: disablePaymentId ?? false,\r\n }),\r\n );\r\n } catch (err) {\r\n console.error(err);\r\n setErrorMsg((err as Error).message);\r\n setDisabled(true)\r\n }\r\n }, [props.opReturn, paymentId, disablePaymentId]);\r\n\r\n useEffect(() => {\r\n setThisAmount(props.amount);\r\n }, [props.amount]);\r\n\r\n useEffect(() => {\r\n if (totalReceived !== undefined) {\r\n const progress = getCurrencyObject(totalReceived, currency, false);\r\n\r\n const goal = getCurrencyObject(cleanGoalAmount, currency, false);\r\n if (!isFiat(currency)) {\r\n if (goal !== undefined) {\r\n let progressFloat = progress.float;\r\n if(contributionOffset !== undefined){\r\n progressFloat = Number(progressFloat) + Number(contributionOffset)\r\n };\r\n setGoalPercent((100 * progressFloat) / goal.float);\r\n setGoalText(`${progressFloat} / ${cleanGoalAmount}`);\r\n setLoading(false);\r\n }\r\n } else {\r\n if (hasPrice) {\r\n const receivedVal: number = totalReceived * price;\r\n const receivedText: string = formatPrice(\r\n receivedVal,\r\n currency,\r\n DECIMALS.FIAT,\r\n );\r\n const goalText: string = formatPrice(\r\n cleanGoalAmount,\r\n currency,\r\n DECIMALS.FIAT,\r\n );\r\n const receivedRatio = `${receivedText} / ${goalText}`;\r\n const receivedPercentage: number =\r\n 100 * (receivedVal / cleanGoalAmount);\r\n setLoading(false);\r\n setGoalPercent(receivedPercentage);\r\n setGoalText(receivedRatio);\r\n }\r\n }\r\n if (shouldDisplayGoal && goal.float !== undefined && goal.float <= 0) {\r\n setDisabled(true);\r\n setErrorMsg('Goal Value must be a number');\r\n }\r\n }\r\n }, [totalReceived, currency, goalAmount, price, hasPrice, contributionOffset]);\r\n\r\n const handleButtonClick = () => {\r\n if (addressType === 'XEC') {\r\n const hasExtension = getCashtabProviderStatus();\r\n if (!hasExtension) {\r\n const isMobile = window.matchMedia('(pointer:coarse)').matches;\r\n if (isMobile) {\r\n const webUrl = `https://cashtab.com/#/send?bip21=${url}`;\r\n window.open(webUrl, '_blank');\r\n } else {\r\n window.location.href = url;\r\n }\r\n } else {\r\n return window.postMessage(\r\n {\r\n type: 'FROM_PAGE',\r\n text: 'Cashtab',\r\n txInfo: {\r\n bip21: url\r\n },\r\n },\r\n '*',\r\n );\r\n }\r\n } else {\r\n window.location.href = url;\r\n }\r\n };\r\n\r\n const handleQrCodeClick = useCallback((): void => {\r\n if (disabled || to === undefined) return;\r\n if (!url || !copy(url)) return;\r\n setCopied(true);\r\n setRecentlyCopied(true);\r\n }, [disabled, to, url, copy, setCopied, setRecentlyCopied]);\r\n\r\n const resolveUrl = useCallback((currency: string, amount?: number) => {\r\n if (disabled || !to) return;\r\n\r\n const prefix = CURRENCY_PREFIXES_MAP[currency.toLowerCase() as typeof CRYPTO_CURRENCIES[number]];\r\n if (!prefix) return;\r\n\r\n let thisUrl = `${prefix}:${to.replace(/^.*:/, '')}`;\r\n\r\n if (amount) {\r\n thisUrl += `?amount=${amount}`;\r\n }\r\n\r\n if (opReturn) {\r\n const separator = thisUrl.includes('?') ? '&' : '?';\r\n thisUrl += `${separator}op_return_raw=${opReturn}`;\r\n }\r\n\r\n return thisUrl;\r\n }, [disabled, to, currency, opReturn]);\r\n\r\n const qrCodeProps: QRCodeProps = {\r\n renderAs: 'svg',\r\n size: 300,\r\n level: 'H', // High error correction allows for a larger logo\r\n value: url,\r\n fgColor: theme.palette.tertiary,\r\n imageSettings: {\r\n src: success ? checkSvg : isValidCashAddress(to) ? bchSvg : xecSvg,\r\n excavate: false,\r\n height: 112,\r\n width: 112,\r\n },\r\n };\r\n\r\n const qrCode = (\r\n <QRCode\r\n {...qrCodeProps}\r\n style={{ flex: 1, width: '100%', height: 'auto', ...blurCSS }}\r\n />\r\n );\r\n\r\n let cleanGoalAmount: any;\r\n if (goalAmount) {\r\n cleanGoalAmount = +goalAmount;\r\n }\r\n\r\n const shouldDisplayGoal: boolean = goalAmount !== undefined;\r\n const handleAmountChange = (e: React.ChangeEvent<HTMLInputElement>) => {\r\n let amount = e.target.value;\r\n if (amount === '') {\r\n amount = '0';\r\n }\r\n\r\n const userEdited = getCurrencyObject(+amount, currency, false);\r\n\r\n setUserEditedAmount(userEdited);\r\n updateAmount(amount)\r\n };\r\n\r\n const updateAmount = (amount: string) => {\r\n setThisAmount(amount);\r\n if (props.setAmount) {\r\n props.setAmount(amount);\r\n }\r\n }\r\n\r\n return (\r\n <ThemeProvider value={theme}>\r\n <Box\r\n className={classes.root}\r\n pt={0}\r\n display=\"flex\"\r\n flexDirection=\"column\"\r\n alignItems=\"center\"\r\n >\r\n <Box\r\n flex=\"shrink\"\r\n alignSelf=\"stretch\"\r\n style={{ background: '#fff' }}\r\n py={1}\r\n textAlign=\"center\"\r\n >\r\n <Typography className={errorMsg ? classes.error : classes.text}>\r\n {(() => {\r\n if (errorMsg) return errorMsg;\r\n if (disabled) return 'Not yet ready for payment';\r\n if (loading) return 'Loading...';\r\n if (success) return successText;\r\n return text;\r\n })()}\r\n </Typography>\r\n </Box>\r\n <Box\r\n display=\"flex\"\r\n flexDirection=\"column\"\r\n alignItems=\"center\"\r\n px={3}\r\n pt={2}\r\n position=\"relative\"\r\n >\r\n {// Altpayment region\r\n useAltpayment &&\r\n <AltpaymentWidget\r\n altpaymentSocket={altpaymentSocket}\r\n thisAmount={thisAmount}\r\n updateAmount={updateAmount}\r\n setUseAltpayment={setUseAltpayment}\r\n altpaymentShift={altpaymentShift}\r\n setAltpaymentShift={setAltpaymentShift}\r\n shiftCompleted={shiftCompleted}\r\n setShiftCompleted={setShiftCompleted}\r\n altpaymentError={altpaymentError}\r\n setAltpaymentError={setAltpaymentError}\r\n coins={coins}\r\n loadingPair={loadingPair}\r\n setLoadingPair={setLoadingPair}\r\n loadingShift={loadingShift}\r\n setLoadingShift={setLoadingShift}\r\n coinPair={coinPair}\r\n setCoinPair={setCoinPair}\r\n altpaymentEditable={altpaymentEditable}\r\n animation={animation}\r\n addressType={addressType}\r\n to={to}\r\n />\r\n }\r\n <>\r\n {loading && shouldDisplayGoal ? (\r\n <Typography\r\n className={classes.text}\r\n style={{ margin: '10px auto 20px' }}\r\n >\r\n <CircularProgress\r\n size={15}\r\n thickness={4}\r\n className={classes.spinner}\r\n />\r\n </Typography>\r\n ) : (\r\n <>\r\n {shouldDisplayGoal && (\r\n <>\r\n <Typography\r\n className={classes.copyText}\r\n style={{ marginBottom: '0.61rem', ...blurCSS}}\r\n >\r\n {goalText}\r\n <strong>&nbsp;{currency}</strong>\r\n </Typography>\r\n <BarChart\r\n color={theme.palette.primary}\r\n value={Math.round(goalPercent)}\r\n disabled={disabled}\r\n />\r\n </>\r\n )}\r\n </>\r\n )}\r\n\r\n <Box\r\n flex={1}\r\n position=\"relative\"\r\n className={classes.qrCode}\r\n onClick={handleQrCodeClick}\r\n >\r\n <Fade in={!loading && url !== ''}>\r\n <React.Fragment>\r\n {qrCode}\r\n <Box position=\"absolute\" bottom={0} right={0}>\r\n <Fade\r\n appear={false}\r\n in={!copied || recentlyCopied}\r\n timeout={{ enter: 0, exit: 2000 }}\r\n >\r\n <Box className={classes.copyTextContainer}>\r\n {!isPropsTrue(disabled) && (\r\n <Typography className={classes.copyText}>\r\n {copied ? 'Payment copied!' : 'Click to copy'}\r\n </Typography>\r\n )}\r\n </Box>\r\n </Fade>\r\n </Box>\r\n </React.Fragment>\r\n </Fade>\r\n {loading && (\r\n <Box\r\n position=\"absolute\"\r\n top={0}\r\n bottom={0}\r\n left={0}\r\n right={0}\r\n display=\"flex\"\r\n justifyContent=\"center\"\r\n alignItems=\"center\"\r\n >\r\n <CircularProgress\r\n size={70}\r\n thickness={4}\r\n className={classes.spinner}\r\n />\r\n </Box>\r\n )}\r\n </Box>\r\n\r\n {isPropsTrue(editable) && (\r\n <div className={classes.editAmount}>\r\n <TextField\r\n label='Edit amount'\r\n value={thisAmount || 0}\r\n onChange={handleAmountChange}\r\n inputProps={{ maxlength: '12' }}\r\n name=\"Amount\"\r\n placeholder='Enter Amount'\r\n id=\"userEditedAmount\"\r\n />\r\n <Typography component=\"span\">{currency}</Typography>\r\n </div>\r\n )}\r\n\r\n {success || (\r\n <Box pt={2} flex={1}>\r\n <ButtonComponent\r\n text={widgetButtonText}\r\n hoverText={hoverText}\r\n onClick={handleButtonClick}\r\n disabled={isPropsTrue(disabled)}\r\n animation={animation}\r\n />\r\n </Box>\r\n )}\r\n {!isPropsTrue(disableAltpayment) && (\r\n <Typography\r\n component=\"div\"\r\n className={classes.sideShiftLink}\r\n onClick={isAboveMinimumAltpaymentUSDAmount || altpaymentEditable ? tradeWithAltpayment : undefined}\r\n style={{\r\n opacity: isAboveMinimumAltpaymentUSDAmount || altpaymentEditable ? 1 : 0,\r\n cursor: isAboveMinimumAltpaymentUSDAmount || altpaymentEditable ? 'pointer' : 'default'\r\n }}\r\n >\r\n Don't have any {addressType}?\r\n </Typography>\r\n )}\r\n </>\r\n {foot && (\r\n <Box pt={2} flex={1}>\r\n {foot}\r\n </Box>\r\n )}\r\n <Box py={0.8}>\r\n <Typography className={classes.footer}>\r\n Powered by PayButton.org\r\n </Typography>\r\n </Box>\r\n </Box>\r\n </Box>\r\n </ThemeProvider>\r\n );\r\n};\r\n\r\nWidget.defaultProps = {\r\n success: false,\r\n successText: 'Thank you!',\r\n editable: false,\r\n};\r\n\r\nexport default Widget;\r\n","import { Socket } from 'socket.io-client';\r\nimport { AltpaymentCoin, AltpaymentError, AltpaymentPair, AltpaymentShift } from '../altpayment';\r\n\r\nimport { BroadcastTxData } from './types';\r\n\r\nexport const txsListener = (socket: Socket, setNewTxs: Function): void => {\r\n socket.on('incoming-txs', (broadcastedTxData: BroadcastTxData) => {\r\n const unconfirmedTxs = broadcastedTxData.txs.filter(\r\n tx => tx.confirmed === false,\r\n );\r\n if (\r\n broadcastedTxData.messageType === 'NewTx' &&\r\n unconfirmedTxs.length !== 0\r\n ) {\r\n setNewTxs(unconfirmedTxs);\r\n }\r\n });\r\n};\r\n\r\ninterface AltpaymentListenerParams {\r\n addressType: string\r\n socket: Socket\r\n setCoins: Function\r\n setCoinPair: Function\r\n setLoadingPair: Function\r\n setAltpaymentShift: Function\r\n setLoadingShift: Function\r\n setAltpaymentError: Function\r\n}\r\n\r\nexport const altpaymentListener = (params: AltpaymentListenerParams): void => {\r\n params.socket.on('send-altpayment-coins-info', (coins: AltpaymentCoin[]) => {\r\n params.setCoins(coins.filter(c => c.coin !== params.addressType))\r\n })\r\n params.socket.on('shift-creation-error', (error: AltpaymentError) => {\r\n params.setAltpaymentError(error)\r\n params.setLoadingShift(false)\r\n return\r\n });\r\n params.socket.on('quote-creation-error', (error: AltpaymentError) => {\r\n params.setAltpaymentError(error)\r\n params.setLoadingShift(false)\r\n return\r\n });\r\n params.socket.on('shift-created', (shift: AltpaymentShift) => {\r\n params.setAltpaymentShift(shift)\r\n params.setLoadingShift(false)\r\n });\r\n params.socket.on('send-altpayment-rate', (pair: AltpaymentPair) => {\r\n params.setCoinPair(pair)\r\n params.setLoadingPair(false)\r\n })\r\n};\r\n","import { MockedPaymentClient } from \"./mocked\"\r\nimport { SideshiftClient, SideshiftCoin, SideshiftError, SideshiftPair, SideshiftQuote, SideshiftShift } from \"./sideshift\"\r\nimport config from '../../../paybutton-config.json'\r\n\r\nexport const MINIMUM_ALTPAYMENT_DOLLAR_AMOUNT = 10\r\n\r\nexport const SOCKET_MESSAGES = {\r\n GET_ALTPAYMENT_RATE: 'get-altpayment-rate',\r\n SEND_ALTPAYMENT_RATE: 'send-altpayment-rate',\r\n SEND_ALTPAYMENT_COINS_INFO: 'send-altpayment-coins-info',\r\n CREATE_ALTPAYMENT_QUOTE: 'create-altpayment-quote',\r\n SHIFT_CREATED: 'altpayment-shift-created',\r\n ERROR_WHEN_CREATING_QUOTE: 'quote-creation-error',\r\n ERROR_WHEN_CREATING_SHIFT: 'shift-creation-error'\r\n}\r\n\r\nexport type AltpaymentClientOptions = 'sideshift' | 'mocked'\r\n\r\nexport type AltpaymentCoin = SideshiftCoin\r\nexport type AltpaymentQuote = SideshiftQuote\r\nexport type AltpaymentPair = SideshiftPair\r\nexport type AltpaymentShift = SideshiftShift\r\nexport type AltpaymentError = SideshiftError\r\n\r\nexport interface AltpaymentClient {\r\n getPaymentStatus: (id: string) => Promise<AltpaymentShift>\r\n}\r\n\r\nexport function getAltpaymentClient (): AltpaymentClient {\r\n switch (config.altpaymentClient) {\r\n case 'sideshift' as AltpaymentClientOptions:\r\n return new SideshiftClient()\r\n case 'mocked' as AltpaymentClientOptions:\r\n return new MockedPaymentClient()\r\n default:\r\n throw new Error(\"ERROR: Invalid alternative payment client\")\r\n }\r\n}\r\n","import { OptionsObject, SnackbarProvider, useSnackbar } from 'notistack';\r\nimport React, { useCallback, useEffect, useMemo, useState } from 'react';\r\nimport { AltpaymentShift, getAltpaymentClient } from '../../altpayment';\r\n\r\nimport successSound from '../../assets/success.mp3.json';\r\n\r\nimport {\r\n getFiatPrice,\r\n Currency,\r\n CurrencyObject,\r\n Transaction,\r\n generatePaymentId,\r\n getCurrencyTypeFromAddress,\r\n isCrypto,\r\n isGreaterThanZero,\r\n isValidCurrency,\r\n resolveNumber,\r\n shouldTriggerOnSuccess,\r\n getCurrencyObject\r\n} from '../../util';\r\n\r\nimport Widget, { WidgetProps } from './Widget';\r\n\r\nexport interface WidgetContainerProps\r\n extends Omit<WidgetProps, 'success' | 'setNewTxs' | 'setCurrencyObject' | 'setAltpaymentShift' | 'useAltpayment' | 'setUseAltpayment' | 'shiftCompleted' | 'setShiftCompleted' > {\r\n active?: boolean;\r\n amount?: number;\r\n opReturn?: string;\r\n paymentId?: string;\r\n disablePaymentId?: boolean;\r\n currency?: Currency;\r\n currencyObj?: CurrencyObject;\r\n cryptoAmount?: string;\r\n price?: number;\r\n setCurrencyObj: Function;\r\n randomSatoshis?: boolean | number;\r\n hideToasts?: boolean;\r\n onSuccess?: (transaction: Transaction) => void;\r\n onTransaction?: (transaction: Transaction) => void;\r\n sound?: boolean;\r\n goalAmount?: number | string;\r\n disabled: boolean;\r\n editable: boolean;\r\n wsBaseUrl?: string;\r\n apiBaseUrl?: string;\r\n successText?: string;\r\n disableAltpayment?: boolean\r\n contributionOffset?: number\r\n}\r\n\r\nconst snackbarOptions: OptionsObject = {\r\n variant: 'success',\r\n autoHideDuration: 8000,\r\n anchorOrigin: {\r\n vertical: 'bottom',\r\n horizontal: 'center',\r\n },\r\n};\r\n\r\nexport interface Output {\r\n index: number;\r\n value: number;\r\n pubkeyScript: string;\r\n address: string;\r\n scriptClass: string;\r\n disassembledScript: string;\r\n}\r\n\r\nconst withSnackbar =\r\n <T extends object>(\r\n Component: React.ComponentType<T>,\r\n ): React.FunctionComponent<T> =>\r\n (props): React.ReactElement =>\r\n (\r\n <SnackbarProvider>\r\n <Component {...props} />\r\n </SnackbarProvider>\r\n );\r\n\r\nexport const WidgetContainer: React.FunctionComponent<WidgetContainerProps> =\r\n withSnackbar((props): React.ReactElement => {\r\n let {\r\n to,\r\n opReturn,\r\n disablePaymentId,\r\n paymentId,\r\n amount,\r\n setAmount,\r\n setCurrencyObj,\r\n currencyObj,\r\n currency = '' as Currency,\r\n cryptoAmount,\r\n price,\r\n animation,\r\n randomSatoshis = false,\r\n hideToasts = false,\r\n sound = true,\r\n onSuccess,\r\n onTransaction,\r\n goalAmount,\r\n disabled,\r\n editable,\r\n wsBaseUrl,\r\n apiBaseUrl,\r\n successText,\r\n hoverText,\r\n disableAltpayment,\r\n contributionOffset,\r\n ...widgetProps\r\n } = props;\r\n\r\n const [thisPaymentId, setThisPaymentId] = useState<string | undefined>();\r\n const [thisPrice, setThisPrice] = useState(0);\r\n const [usdPrice, setUsdPrice] = useState(0);\r\n useEffect(() => {\r\n if ((paymentId === undefined || paymentId === '') && !disablePaymentId) {\r\n const newPaymentId = generatePaymentId(8);\r\n setThisPaymentId(newPaymentId)\r\n } else {\r\n setThisPaymentId(paymentId)\r\n }\r\n }, [paymentId, disablePaymentId]);\r\n const [success, setSuccess] = useState(false);\r\n const { enqueueSnackbar } = useSnackbar();\r\n\r\n const [newTxs, setNewTxs] = useState<Transaction[] | undefined>();\r\n const [useAltpayment, setUseAltpayment] = useState(false);\r\n const [altpaymentShift, setAltpaymentShift] = useState<AltpaymentShift | undefined>();\r\n const [shiftCompleted, setShiftCompleted] = useState(false);\r\n\r\n const paymentClient = getAltpaymentClient()\r\n\r\n const addrType = getCurrencyTypeFromAddress(to);\r\n if (\r\n !isValidCurrency(currency) ||\r\n (isCrypto(currency) && addrType !== currency)\r\n ) {\r\n currency = addrType;\r\n }\r\n\r\n const txSound = useMemo(\r\n (): HTMLAudioElement => new Audio(successSound.base64),\r\n [],\r\n );\r\n\r\n const handlePayment = useCallback(\r\n async (transaction: Transaction) => {\r\n if (altpaymentShift) {\r\n const shiftStatus = await paymentClient.getPaymentStatus(altpaymentShift.id)\r\n if (shiftStatus.status === 'settled') {\r\n if (sound) txSound.play().catch(() => {});\r\n onSuccess?.(transaction);\r\n setShiftCompleted(true)\r\n }\r\n } else {\r\n const expectedAmount = amount ? resolveNumber(amount) : undefined;\r\n const receivedAmount = resolveNumber(transaction.amount);\r\n\r\n if (await shouldTriggerOnSuccess(\r\n transaction,\r\n currency,\r\n thisPrice,\r\n disablePaymentId,\r\n thisPaymentId,\r\n expectedAmount,\r\n opReturn,\r\n currencyObj ?? getCurrencyObject(\r\n Number(props.amount),\r\n currency,\r\n randomSatoshis,\r\n ),\r\n )) {\r\n if (sound) {\r\n txSound.play().catch(() => {});\r\n }\r\n\r\n const currencyTicker = getCurrencyTypeFromAddress(to);\r\n if (!hideToasts)\r\n enqueueSnackbar(\r\n `${\r\n successText ? successText + ' | ' : ''\r\n }Received ${receivedAmount} ${currencyTicker}`,\r\n snackbarOptions,\r\n );\r\n\r\n setSuccess(true);\r\n onSuccess?.(transaction);\r\n } else {\r\n onTransaction?.(transaction);\r\n }\r\n }\r\n setNewTxs([]);\r\n },\r\n [\r\n onSuccess,\r\n onTransaction,\r\n enqueueSnackbar,\r\n hideToasts,\r\n sound,\r\n txSound,\r\n cryptoAmount,\r\n successText,\r\n to,\r\n thisPaymentId,\r\n altpaymentShift,\r\n thisPrice,\r\n currencyObj,\r\n ],\r\n );\r\n\r\n const getPrice = useCallback(\r\n async () => {\r\n const price = await getFiatPrice(currency, to, apiBaseUrl)\r\n const usdPrice = await getFiatPrice('USD', to, apiBaseUrl)\r\n if (price !== null) setThisPrice(price)\r\n if (usdPrice !== null) setUsdPrice(usdPrice)\r\n }\r\n , [currency, to, apiBaseUrl]\r\n );\r\n\r\n useEffect(() => {\r\n if (price === undefined || price === 0) {\r\n (async () => {\r\n getPrice();\r\n })()\r\n } else {\r\n setThisPrice(price)\r\n }\r\n }, [currency, price, usdPrice]);\r\n\r\n const handleNewTransaction = useCallback(\r\n (tx: Transaction) => {\r\n if (\r\n tx.confirmed === false &&\r\n isGreaterThanZero(resolveNumber(tx.amount))\r\n ) {\r\n handlePayment(tx);\r\n }\r\n },\r\n [handlePayment],\r\n );\r\n\r\n useEffect(() => {\r\n newTxs?.map(tx => {\r\n handleNewTransaction(tx);\r\n });\r\n }, [newTxs, handleNewTransaction]);\r\n\r\n return (\r\n <React.Fragment>\r\n <Widget\r\n to={to}\r\n {...widgetProps}\r\n amount={amount}\r\n setAmount={setAmount}\r\n opReturn={opReturn}\r\n paymentId={thisPaymentId}\r\n disablePaymentId={disablePaymentId}\r\n goalAmount={goalAmount}\r\n currency={currency}\r\n animation={animation}\r\n currencyObject={currencyObj}\r\n setCurrencyObject={setCurrencyObj}\r\n randomSatoshis={randomSatoshis}\r\n price={thisPrice}\r\n usdPrice={usdPrice}\r\n success={success}\r\n disabled={disabled}\r\n editable={editable}\r\n setNewTxs={setNewTxs}\r\n newTxs={newTxs}\r\n wsBaseUrl={wsBaseUrl}\r\n apiBaseUrl={apiBaseUrl}\r\n successText={successText}\r\n hoverText={hoverText}\r\n altpaymentShift={altpaymentShift}\r\n setAltpaymentShift={setAltpaymentShift}\r\n useAltpayment={useAltpayment}\r\n setUseAltpayment={setUseAltpayment}\r\n shiftCompleted={shiftCompleted}\r\n setShiftCompleted={setShiftCompleted}\r\n disableAltpayment={disableAltpayment}\r\n contributionOffset={contributionOffset}\r\n />\r\n </React.Fragment>\r\n );\r\n });\r\n\r\nexport default WidgetContainer;\r\n","import BigNumber from \"bignumber.js\";\r\nimport { getCurrencyTypeFromAddress } from \"./address\";\r\nimport { resolveNumber } from \"./number\";\r\nimport { Currency, CurrencyObject, Transaction } from \"./types\";\r\nimport { DECIMALS } from \"./constants\";\r\n\r\nexport const shouldTriggerOnSuccess = async (\r\n transaction: Transaction,\r\n currency: string,\r\n price: number,\r\n disablePaymentId?: boolean,\r\n expectedPaymentId?: string,\r\n expectedAmount?: BigNumber,\r\n expectedOpReturn?: string,\r\n currencyObject?: CurrencyObject,\r\n ) => {\r\n const {\r\n paymentId,\r\n rawMessage:rawOpReturn,\r\n message,\r\n amount, \r\n address } = transaction; \r\n \r\n let isAmountValid = true;\r\n\r\n if(expectedAmount) {\r\n const transactionCurrency: Currency = getCurrencyTypeFromAddress(address);\r\n if (transactionCurrency !== currency) {\r\n if (currencyObject){\r\n const value = (currencyObject.float / price).toFixed(DECIMALS[transactionCurrency])\r\n isAmountValid = resolveNumber(value).isEqualTo(amount)\r\n }else {\r\n isAmountValid = false\r\n }\r\n } else {\r\n isAmountValid = expectedAmount.isEqualTo(amount)\r\n }\r\n } \r\n \r\n const paymentIdsMatch = expectedPaymentId === paymentId;\r\n const isPaymentIdValid = disablePaymentId ? true : paymentIdsMatch;\r\n\r\n const rawOpReturnIsEmptyOrUndefined = rawOpReturn === '' || rawOpReturn === undefined;\r\n const opReturn = rawOpReturnIsEmptyOrUndefined ? message : rawOpReturn\r\n const opReturnIsEmptyOrUndefined = opReturn === '' || opReturn === undefined;\r\n \r\n const opReturnsMatch = opReturn === expectedOpReturn;\r\n const isOpReturnValid = expectedOpReturn ? opReturnsMatch : opReturnIsEmptyOrUndefined;\r\n \r\n return isAmountValid && isPaymentIdValid && isOpReturnValid;\r\n};","import { Dialog } from '@material-ui/core';\r\nimport React, { useState, useEffect } from 'react';\r\n\r\nimport { Theme, ThemeName, ThemeProvider, useTheme } from '../../themes';\r\nimport Button, { ButtonProps } from '../Button/Button';\r\nimport { WidgetContainer } from '../Widget/WidgetContainer';\r\nimport { Currency, CurrencyObject, Transaction, isPropsTrue, isValidCashAddress, isValidXecAddress } from '../../util';\r\n\r\nexport interface PaymentDialogProps extends ButtonProps {\r\n to: string;\r\n amount?: number | string;\r\n setAmount: Function;\r\n opReturn?: string;\r\n paymentId?: string;\r\n disablePaymentId?: boolean;\r\n currency?: Currency;\r\n currencyObj?: CurrencyObject;\r\n cryptoAmount?: string;\r\n price?: number;\r\n hoverText?: string;\r\n setCurrencyObj: Function;\r\n theme?: ThemeName | Theme;\r\n successText?: string;\r\n randomSatoshis?: boolean | number;\r\n hideToasts?: boolean;\r\n goalAmount?: number | string;\r\n disableEnforceFocus?: boolean;\r\n editable?: boolean;\r\n dialogOpen: boolean;\r\n disableScrollLock?: boolean;\r\n active?: boolean;\r\n container?: HTMLElement;\r\n onClose?: (success?: boolean, paymentId?: string) => void;\r\n onSuccess?: (transaction: Transaction) => void;\r\n onTransaction?: (transaction: Transaction) => void;\r\n wsBaseUrl?: string;\r\n apiBaseUrl?: string;\r\n disableAltpayment?: boolean;\r\n contributionOffset?:number;\r\n}\r\n\r\nexport const PaymentDialog = (\r\n props: PaymentDialogProps,\r\n): React.ReactElement => {\r\n const [success, setSuccess] = useState(false);\r\n const [disabled, setDisabled] = useState(false);\r\n\r\n const {\r\n to,\r\n amount,\r\n setAmount,\r\n opReturn,\r\n paymentId,\r\n disablePaymentId,\r\n currency,\r\n currencyObj,\r\n setCurrencyObj,\r\n cryptoAmount,\r\n price,\r\n successText,\r\n animation,\r\n randomSatoshis,\r\n hideToasts,\r\n onClose,\r\n onSuccess,\r\n onTransaction,\r\n goalAmount,\r\n disableEnforceFocus,\r\n editable,\r\n dialogOpen,\r\n container,\r\n wsBaseUrl,\r\n apiBaseUrl,\r\n hoverText,\r\n disableAltpayment,\r\n contributionOffset\r\n } = Object.assign({}, PaymentDialog.defaultProps, props);\r\n\r\n const handleWidgetClose = (): void => {\r\n if (onClose) onClose(success, paymentId);\r\n setSuccess(false);\r\n };\r\n const handleSuccess = (transaction: Transaction): void => {\r\n setSuccess(true);\r\n onSuccess?.(transaction);\r\n };\r\n useEffect(() => {\r\n const invalidAmount = amount !== undefined && isNaN(+amount);\r\n\r\n if (to !== undefined && (isValidCashAddress(to) || isValidXecAddress(to))) {\r\n setDisabled(isPropsTrue(props.disabled));\r\n } else if (invalidAmount) {\r\n setDisabled(true);\r\n } else {\r\n setDisabled(true);\r\n }\r\n }, [to, amount, props.disabled]);\r\n\r\n const ButtonComponent: React.FunctionComponent<ButtonProps> = (\r\n props: ButtonProps,\r\n ): React.ReactElement => <Button animation={animation} {...props} />;\r\n\r\n const theme = useTheme(props.theme, isValidXecAddress(to));\r\n\r\n let cleanAmount: any;\r\n\r\n if (amount) {\r\n cleanAmount = +amount;\r\n }\r\n\r\n return (\r\n <ThemeProvider value={theme}>\r\n <Dialog\r\n container={container}\r\n open={dialogOpen}\r\n onClose={handleWidgetClose}\r\n disableEnforceFocus={disableEnforceFocus}\r\n disableScrollLock\r\n >\r\n <WidgetContainer\r\n ButtonComponent={ButtonComponent}\r\n active={dialogOpen}\r\n to={to}\r\n amount={cleanAmount}\r\n opReturn={opReturn}\r\n paymentId={paymentId}\r\n disablePaymentId={disablePaymentId}\r\n setAmount={setAmount}\r\n currencyObj={currencyObj}\r\n setCurrencyObj={setCurrencyObj}\r\n cryptoAmount={cryptoAmount}\r\n price={price}\r\n currency={currency}\r\n animation={animation}\r\n randomSatoshis={randomSatoshis}\r\n hideToasts={hideToasts}\r\n onSuccess={handleSuccess}\r\n onTransaction={onTransaction}\r\n successText={successText}\r\n disabled={disabled}\r\n editable={editable}\r\n goalAmount={goalAmount}\r\n wsBaseUrl={wsBaseUrl}\r\n apiBaseUrl={apiBaseUrl}\r\n hoverText={hoverText}\r\n disableAltpayment={disableAltpayment}\r\n contributionOffset={contributionOffset}\r\n foot={success && (\r\n <ButtonComponent\r\n onClick={handleWidgetClose}\r\n text=\"Close\"\r\n hoverText=\"Close\"\r\n disabled={disabled} />\r\n )} />\r\n </Dialog>\r\n </ThemeProvider>\r\n );\r\n};\r\n\r\nPaymentDialog.defaultProps = {\r\n animation: 'slide',\r\n hideToasts: false,\r\n randomSatoshis: false,\r\n successText: 'Thank you!',\r\n disableEnforceFocus: false,\r\n disabled: false,\r\n editable: false,\r\n dialogOpen: true,\r\n};\r\n\r\nexport default PaymentDialog;\r\n","import React, { useState, useEffect, useCallback, useRef } from 'react';\r\n\r\nimport { Theme, ThemeName, ThemeProvider, useTheme } from '../../themes';\r\nimport Button, { ButtonProps } from '../Button/Button';\r\n\r\nimport {\r\n Transaction,\r\n Currency,\r\n isFiat,\r\n getFiatPrice,\r\n getCurrencyTypeFromAddress,\r\n isValidCashAddress,\r\n isValidXecAddress,\r\n CurrencyObject,\r\n generatePaymentId,\r\n getCurrencyObject,\r\n isPropsTrue\r\n} from '../../util';\r\nimport { PaymentDialog } from '../PaymentDialog';\r\nexport interface PayButtonProps extends ButtonProps {\r\n to: string;\r\n amount?: number | string;\r\n opReturn?: string;\r\n disablePaymentId?: boolean;\r\n currency?: Currency;\r\n theme?: ThemeName | Theme;\r\n text?: string;\r\n hoverText?: string;\r\n successText?: string;\r\n randomSatoshis?: boolean | number | undefined;\r\n hideToasts?: boolean;\r\n disabled?: boolean;\r\n goalAmount?: number | string;\r\n disableEnforceFocus?: boolean;\r\n editable?: boolean;\r\n onSuccess?: (transaction: Transaction) => void;\r\n onTransaction?: (transaction: Transaction) => void;\r\n onOpen?: (\r\n amount?: number | string,\r\n to?: string,\r\n paymentId?: string,\r\n ) => void;\r\n onClose?: (success?: boolean, paymentId?:string) => void;\r\n wsBaseUrl?: string;\r\n apiBaseUrl?: string;\r\n disableAltpayment?:boolean\r\n contributionOffset?:number\r\n}\r\n\r\nexport const PayButton = (props: PayButtonProps): React.ReactElement => {\r\n const [dialogOpen, setDialogOpen] = useState(false);\r\n const [disabled, setDisabled] = useState(false);\r\n const [errorMsg, setErrorMsg] = useState('');\r\n const [amount, setAmount] = useState(props.amount);\r\n\r\n const [currencyObj, setCurrencyObj] = useState<CurrencyObject | undefined>();\r\n const [cryptoAmount, setCryptoAmount] = useState<string>();\r\n const [price, setPrice] = useState(0);\r\n const priceRef = useRef<number>(price);\r\n const cryptoAmountRef = useRef<string | undefined>(cryptoAmount);\r\n\r\n\r\n const {\r\n to,\r\n opReturn,\r\n disablePaymentId,\r\n currency = '' as Currency,\r\n text,\r\n hoverText,\r\n successText,\r\n animation,\r\n randomSatoshis,\r\n hideToasts,\r\n onSuccess,\r\n onTransaction,\r\n onOpen,\r\n onClose,\r\n goalAmount,\r\n disableEnforceFocus,\r\n editable,\r\n wsBaseUrl,\r\n apiBaseUrl,\r\n disableAltpayment,\r\n contributionOffset\r\n } = Object.assign({}, PayButton.defaultProps, props);\r\n\r\n const [paymentId] = useState(!disablePaymentId ? generatePaymentId(8) : undefined);\r\n\r\n useEffect(() => {\r\n priceRef.current = price;\r\n }, [price]);\r\n\r\n useEffect(() => {\r\n cryptoAmountRef.current = cryptoAmount;\r\n }, [cryptoAmount]);\r\n\r\n const waitPrice = (callback: Function) => {\r\n const intervalId = setInterval(() => {\r\n if (priceRef.current !== 0) {\r\n clearInterval(intervalId);\r\n callback();\r\n }\r\n }, 300);\r\n };\r\n const handleButtonClick = useCallback(async (): Promise<void> => {\r\n if (onOpen !== undefined) {\r\n if (isFiat(currency)) {\r\n void waitPrice(() => { onOpen(cryptoAmountRef.current, to, paymentId) })\r\n } else {\r\n onOpen(amount, to, paymentId)\r\n }\r\n }\r\n setDialogOpen(true);\r\n }, [cryptoAmount, to, paymentId, price])\r\n\r\n const handleCloseDialog = (success?: boolean, paymentId?: string): void => {\r\n if (onClose !== undefined) onClose(success, paymentId);\r\n setDialogOpen(false);\r\n };\r\n\r\n useEffect(() => {\r\n setAmount(props.amount);\r\n }, [props.amount]);\r\n\r\n useEffect(() => {\r\n const invalidAmount = props.amount !== undefined && isNaN(+props.amount);\r\n\r\n if (to !== undefined) {\r\n setDisabled(isPropsTrue(props.disabled));\r\n setErrorMsg('');\r\n } else if (invalidAmount) {\r\n setDisabled(true);\r\n setErrorMsg('Amount should be a number');\r\n } else {\r\n setDisabled(true);\r\n setErrorMsg('Invalid Recipient');\r\n }\r\n }, [to, props.amount, props.disabled]);\r\n\r\n useEffect(() => {\r\n if (!to) {\r\n setErrorMsg('Enter an address');\r\n } else if (isValidCashAddress(to)) {\r\n setErrorMsg('');\r\n } else if (isValidXecAddress(to)) {\r\n setErrorMsg('');\r\n } else {\r\n setErrorMsg('Invalid Recipient');\r\n }\r\n }, [to]);\r\n\r\n useEffect(() => {\r\n if (dialogOpen === false && props.amount && currency) {\r\n const obj = getCurrencyObject(\r\n Number(props.amount),\r\n currency,\r\n randomSatoshis,\r\n );\r\n setTimeout(() => {\r\n setAmount(obj.float);\r\n setCurrencyObj(obj);\r\n }, 300);\r\n }\r\n }, [dialogOpen, props.amount, currency, randomSatoshis]);\r\n\r\n const getPrice = useCallback(\r\n async () => {\r\n const price = await getFiatPrice(currency, to, apiBaseUrl)\r\n if (price !== null) setPrice(price)\r\n }\r\n , [currency, to, apiBaseUrl]\r\n );\r\n\r\n useEffect(() => {\r\n (async () => {\r\n if (isFiat(currency) && price === 0) {\r\n await getPrice();\r\n }\r\n })()\r\n }, [currency, getPrice, to, price]);\r\n\r\n useEffect(() => {\r\n if (currencyObj && isFiat(currency) && price) {\r\n const addressType: Currency = getCurrencyTypeFromAddress(to);\r\n const convertedObj = getCurrencyObject(\r\n currencyObj.float / price,\r\n addressType,\r\n randomSatoshis,\r\n );\r\n setCryptoAmount(convertedObj.string);\r\n } else if (!isFiat(currency)) {\r\n setCryptoAmount(amount?.toString());\r\n }\r\n }, [price, currencyObj, amount, currency, randomSatoshis, to]);\r\n\r\n const theme = useTheme(props.theme, isValidXecAddress(to ?? ''));\r\n\r\n const ButtonComponent: React.FC<ButtonProps> = (\r\n props: ButtonProps,\r\n ): React.ReactElement => <Button animation={animation} {...props} />;\r\n\r\n return (\r\n <ThemeProvider value={theme}>\r\n <ButtonComponent\r\n onClick={handleButtonClick}\r\n text={text}\r\n hoverText={hoverText}\r\n disabled={disabled}\r\n />\r\n <PaymentDialog\r\n disableEnforceFocus={disableEnforceFocus}\r\n disableScrollLock\r\n to={to ?? ''}\r\n amount={amount}\r\n opReturn={opReturn}\r\n paymentId={paymentId}\r\n disablePaymentId={disablePaymentId}\r\n setAmount={setAmount}\r\n currencyObj={currencyObj}\r\n setCurrencyObj={setCurrencyObj}\r\n cryptoAmount={cryptoAmount}\r\n price={price}\r\n currency={currency}\r\n animation={animation}\r\n randomSatoshis={randomSatoshis}\r\n hideToasts={hideToasts}\r\n onTransaction={onTransaction}\r\n onSuccess={onSuccess}\r\n successText={successText}\r\n disabled={disabled}\r\n editable={editable}\r\n goalAmount={goalAmount}\r\n dialogOpen={dialogOpen}\r\n onClose={handleCloseDialog}\r\n wsBaseUrl={wsBaseUrl}\r\n apiBaseUrl={apiBaseUrl}\r\n hoverText={hoverText}\r\n disableAltpayment={disableAltpayment}\r\n contributionOffset={contributionOffset}\r\n />\r\n {errorMsg && (\r\n <p\r\n style={{\r\n color: '#EB3B3B',\r\n fontSize: '14px',\r\n maxWidth: '190px',\r\n textAlign: 'center',\r\n }}\r\n >\r\n {errorMsg}\r\n </p>\r\n )}\r\n </ThemeProvider>\r\n );\r\n};\r\n\r\nconst payButtonDefaultProps: PayButtonProps = {\r\n to: '',\r\n animation: 'slide',\r\n hideToasts: false,\r\n randomSatoshis: false,\r\n successText: 'Thank you!',\r\n disableEnforceFocus: false,\r\n disabled: false,\r\n editable: false,\r\n};\r\n\r\nPayButton.defaultProps = payButtonDefaultProps;\r\n\r\nexport default PayButton;\r\n","import * as Components from './lib/components'\r\n\r\nexport const PayButton = Components.PayButton;\r\nexport type PayButtonProps = Components.PayButtonProps;\r\n\r\nexport const PaymentDialog = Components.PaymentDialog;\r\nexport type PaymentDialogProps = Components.PaymentDialogProps;\r\n\r\nexport const Widget = Components.Widget;\r\nexport type WidgetProps = Components.WidgetProps;\r\n"],"names":["theme","palette","secondary","tertiary","logo","themes","primary","paybutton","xec","ThemeName","DEFAULT_THEME","PAYBUTTON","ThemeContext","React","createContext","undefined","ThemeProvider","Provider","checkHash","name","startsWith","useTheme","defaultTheme","isXec","validated","XEC","validateColors","obj","regexp","RegExp","test","_useContext","useContext","getTheme","useStyles","makeStyles","container","fontSize","button","_ref","props","_objectWithoutPropertiesLoose","_excluded","_extends","background","transition","animation","backgroundSize","backgroundPosition","color","minWidth","padding","margin","boxShadow","border","borderRadius","textTransform","&:hover","& .MuiTouchRipple-root","&:disabled span","filter","Button","text","hoverText","disabled","Object","assign","defaultProps","hovering","setHovering","useState","transitioning","setTransitioning","timer","useRef","buttonRef","classes","useLayoutEffect","current","style","width","clientWidth","height","clientHeight","className","MuiButton","onClick","onMouseEnter","handleMouseEnter","clearTimeout","window","setTimeout","onMouseLeave","handleMouseLeave","ref","trim","isValidCashAddress","address","xecaddr","err","isValidXecAddress","getCurrencyTypeFromAddress","Error","FIAT_CURRENCIES","CRYPTO_CURRENCIES","DECIMALS","BCH","FIAT","CURRENCY_PREFIXES_MAP","bch","isFiat","unknownString","includes","isCrypto","getFiatPrice","async","currency","to","apiBaseUrl","rootUrl","data","axios","get","_","lowerCase","price","getBchFiatPrice","getXecFiatPrice","error","console","log","root","lib","version","settings","symbol","format","decimal","thousand","precision","grouping","number","nativeMap","Array","prototype","map","nativeIsArray","isArray","toString","isString","charCodeAt","substr","call","isObject","defaults","object","defs","key","hasOwnProperty","iterator","context","i","j","results","length","checkPrecision","val","base","Math","round","abs","isNaN","checkCurrencyFormat","match","pos","neg","replace","zero","unformat","parse","value","regex","unformatted","parseFloat","toFixed","power","pow","formatNumber","opts","usePrecision","negative","parseInt","mod","split","formatMoney","formats","formatColumn","list","padAfterSymbol","indexOf","maxLength","formatted","fVal","join","module","exports","getOwnPropertySymbols","propIsEnumerable","propertyIsEnumerable","toObject","TypeError","test1","String","getOwnPropertyNames","test2","fromCharCode","n","test3","forEach","letter","keys","shouldUseNative","target","source","from","symbols","s","arguments","AD","AE","AF","AG","AI","AL","AM","AN","AO","AR","AS","AT","AU","AW","AX","AZ","BA","BB","BD","BE","BF","BG","BH","BI","BJ","BL","BM","BN","BO","BQ","BR","BS","BT","BV","BW","BY","BZ","CA","CC","CD","CF","CG","CH","CI","CK","CL","CM","CN","CO","CR","CU","CV","CW","CX","CY","CZ","DE","DJ","DK","DM","DO","DZ","EC","EE","EG","EH","ER","ES","ET","FI","FJ","FK","FM","FO","FR","GA","GB","GD","GE","GF","GG","GH","GI","GL","GM","GN","GP","GQ","GR","GS","GT","GU","GW","GY","HK","HM","HN","HR","HT","HU","ID","IE","IL","IM","IN","IO","IQ","IR","IS","IT","JE","JM","JO","JP","KE","KG","KH","KI","KM","KN","KP","KR","KW","KY","KZ","LA","LB","LC","LI","LK","LR","LS","LT","LU","LV","LY","MA","MC","MD","ME","MF","MG","MH","MK","ML","MM","MN","MO","MP","MQ","MR","MS","MT","MU","MV","MW","MX","MY","MZ","NA","NC","NE","NF","NG","NI","NL","NO","NP","NR","NU","NZ","OM","PA","PE","PF","PG","PH","PK","PL","PM","PN","PR","PS","PT","PW","PY","QA","RE","RO","RS","RU","RW","SA","SB","SC","SD","SE","SG","SH","SI","SJ","SK","SL","SM","SN","SO","SR","ST","SV","SX","SY","SZ","TC","TD","TF","TG","TH","TJ","TK","TL","TM","TN","TO","TR","TT","TV","TW","TZ","UA","UG","UM","US","UY","UZ","VA","VC","VE","VG","VI","VN","VU","WF","WS","YE","YT","ZA","ZM","ZW","locale","localeString","components","countryCode","pop","toUpperCase","defaultCurrency","thousandsSeparator","decimalSeparator","symbolOnLeft","spaceBetweenAmountAndSymbol","decimalDigits","defaultLocaleFormat","formatMapping","findCurrency","currencyCode","currencies","isUndefined","options","code","localeCurrency","localeMatch","exec","language","localeFormat","localeFormats","f","accounting","formatPrice","currencyType","Intl","NumberFormat","currencyDisplay","minimumFractionDigits","maximumFractionDigits","isPropsTrue","generatePaymentId","bytesAmount","wordArray","WordArray","random","enc","Hex","stringify","getNSatoshis","amount","randomSatoshis","satsPrecision","amountDigits","min","BigNumber","resolveNumber","getCurrencyObject","string","float","newAmount","randomizeSatoshis","addressType","nSatoshis","randomizedAmount","ret","floor","max","multiplier","decimals","primaryUnit","c","currencyFormat","SideshiftClient","[object Object]","shiftId","res","fetch","Date","getTime","json","BarChart","barWidth","setBarWidth","blurCSS","bar","left","top","bottom","backgroundColor","position","useEffect","marginBottom","copyIcon","AltpaymentWidget","altpaymentSocket","setUseAltpayment","altpaymentShift","setAltpaymentShift","shiftCompleted","setShiftCompleted","altpaymentError","setAltpaymentError","coins","loadingPair","loadingShift","coinPair","setCoinPair","altpaymentEditable","thisAmount","updateAmount","setLoadingPair","setLoadingShift","pairAmountMaxLength","setPairAmountMaxLength","isAboveMinimumAltpaymentAmount","setIsAboveMinimumAltpaymentAmount","isBelowMaximumAltpaymentAmount","setIsBelowMaximumAltpaymentAmount","selectedCoin","setSelectedCoin","selectedCoinNetwork","setSelectedCoinNetwork","pairAmountFixedDecimals","setPairAmountFixedDecimals","pairAmount","setPairAmount","networks","bigNumber","rate","tokenDetails","amountString","floorAmount","nonDecimalCharCount","ceil","log10","resetTrade","copyToClipboard","elementId","contentElement","document","getElementById","copiedMessage","createElement","textContent","alignItems","zIndex","display","navigator","clipboard","writeText","appendChild","parentElement","removeChild","select_box","option_outer_ctn","option_ctn","flexDirection","list_icon","marginRight","coin","fontWeight","lineHeight","coin_name","spacer","sideshift_ctn","paddingTop","header","& img","marginTop","back_link","cursor","opacity","shift_ready","& h4","borderBottom","paddingBottom","textAlign","copy_ctn","& > div","editAmount","& span","marginLeft","amount_error","error_msg","shift_label","shift_input","wordBreak","flexGrow","copy_btn","alignSelf","shift_complete","flex","checkCoin","coinString","toLowerCase","Typography","component","errorMessage","id","depositAmount","depositCoin","src","alt","depositAddress","settleCoin","Grid","spacing","justifyContent","item","TextField","label","onChange","e","settleCoinAmount","inputProps","type","pattern","inputMode","handleCreateQuoteButtonClick","emit","depositNetwork","settleAddress","href","FormControl","InputLabel","Select","labelId","_selectedCoin$coin","coinName","find","handleCoinChange","MenuItem","handleNetworkChange","network","charAt","slice","handleGetRateButtonClick","requestPairRate","qrCode","success","loading","outline","maxWidth","maxHeight","userSelect","&:active","borderWidth","& path","& image","copyTextContainer","copyText","textShadow","spinner","footer","sideShiftLink","Widget","foot","paymentId","successText","disablePaymentId","goalAmount","ButtonComponent","editable","setNewTxs","newTxs","usdPrice","wsBaseUrl","useAltpayment","disableAltpayment","contributionOffset","setLoading","copied","setCopied","recentlyCopied","setRecentlyCopied","totalReceived","setTotalReceived","setDisabled","errorMsg","setErrorMsg","goalText","setGoalText","goalPercent","setGoalPercent","socket","setSocket","setAddressType","_props$price","url","setUrl","userEditedAmount","setUserEditedAmount","setText","widgetButtonText","setWidgetButtonText","opReturn","setOpReturn","setAltpaymentSocket","setCoins","setAltpaymentEditable","isAboveMinimumAltpaymentUSDAmount","setIsAboveMinimumAltpaymentUSDAmount","setThisAmount","hasPrice","setHasPrice","thisCurrencyObject","setThisCurrencyObject","currencyObject","bchSvg","useMemo","_theme$palette$logo","encodeURIComponent","checkSvg","_theme$palette$logo2","getAddressDetails","disconnect","newSocket","io","forceNew","query","addresses","dummy","txsListener","on","broadcastedTxData","unconfirmedTxs","txs","tx","confirmed","messageType","setupTxsSocket","params","shift","pair","setupAltpaymentSocket","balance","getAddressBalance","invalidAmount","isNegativeNumber","cleanAmount","setCurrencyObject","convertedAmount","convertedObj","_url","resolveUrl","_url2","notZeroValue","dataPushdata","bytesQuantity","Blob","size","bytesLimit","rawPushdata","padStart","getDataPushdata","pushDataPrefixedPaymentId","hexString","prependPaymentIdWithPushdata","_paymentId","OP_RETURN_PREFIX_PUSHDATA","str","encoded","TextEncoder","encode","byte","stringToHex","encodeOpReturnProps","message","progress","goal","cleanGoalAmount","receivedVal","receivedRatio","receivedPercentage","progressFloat","Number","shouldDisplayGoal","handleQrCodeClick","useCallback","copy","prefix","thisUrl","separator","qrCodeProps","renderAs","level","fgColor","imageSettings","excavate","QRCode","setAmount","Box","pt","py","px","CircularProgress","thickness","Fade","in","Fragment","right","appear","timeout","enter","exit","userEdited","maxlength","placeholder","handleButtonClick","getCashtabProviderStatus","windowAny","bitcoinAbc","postMessage","txInfo","bip21","matchMedia","matches","open","location","tradeWithAltpayment","snackbarOptions","variant","autoHideDuration","anchorOrigin","vertical","horizontal","WidgetContainer","Component","setCurrencyObj","currencyObj","cryptoAmount","hideToasts","sound","onSuccess","onTransaction","widgetProps","thisPaymentId","setThisPaymentId","thisPrice","setThisPrice","setUsdPrice","newPaymentId","setSuccess","enqueueSnackbar","useSnackbar","paymentClient","addrType","txSound","Audio","handlePayment","getPaymentStatus","status","play","catch","transaction","expectedAmount","receivedAmount","expectedPaymentId","expectedOpReturn","rawMessage","rawOpReturn","isAmountValid","transactionCurrency","isEqualTo","shouldTriggerOnSuccess","currencyTicker","getPrice","handleNewTransaction","isLessThan","SnackbarProvider","PaymentDialog","onClose","disableEnforceFocus","dialogOpen","handleWidgetClose","Dialog","disableScrollLock","active","PayButton","setDialogOpen","setCryptoAmount","setPrice","priceRef","cryptoAmountRef","onOpen","callback","intervalId","setInterval","clearInterval","waitPrice","handleCloseDialog","Components"],"mappings":"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I,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI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"}
1
+ {"version":3,"file":"index.modern.js","sources":["../lib/themes/themes/orange.ts","../lib/themes/themes/paybutton.ts","../lib/themes/themes/xec.ts","../lib/themes/index.tsx","../lib/components/Button/Button.tsx","../lib/util/address.ts","../lib/util/constants.ts","../lib/util/currency.ts","../lib/util/api-client.ts","../node_modules/accounting/accounting.js","../node_modules/object-assign/index.js","../node_modules/locale-currency/map.js","../node_modules/locale-currency/index.js","../node_modules/currency-formatter/index.js","../lib/util/format.ts","../lib/util/opReturn.ts","../lib/util/randomizeSats.ts","../lib/util/number.ts","../lib/util/satoshis.ts","../lib/altpayment/sideshift.ts","../lib/components/BarChart/BarChart.tsx","../lib/components/Widget/SideShiftLogo.tsx","../lib/components/Widget/AltpaymentWidget.tsx","../lib/components/Widget/Widget.tsx","../lib/util/socket.ts","../lib/altpayment/index.ts","../lib/components/Widget/WidgetContainer.tsx","../lib/util/validate.ts","../lib/components/PaymentDialog/PaymentDialog.tsx","../lib/components/PayButton/PayButton.tsx","../index.tsx"],"sourcesContent":["import Theme from '../Theme';\r\n\r\nconst primary = '#ee8b2b';\r\n\r\nconst theme: Theme = {\r\n palette: {\r\n primary,\r\n secondary: '#fefbf8',\r\n tertiary: '#504030',\r\n logo: primary,\r\n },\r\n};\r\n\r\nexport default theme;\r\n","import Theme from '../Theme';\r\n\r\nconst primary = '#4bc846';\r\n\r\nconst theme: Theme = {\r\n palette: {\r\n primary,\r\n secondary: '#f8fdf8',\r\n tertiary: '#374936',\r\n logo: primary,\r\n },\r\n};\r\n\r\nexport default theme;\r\n","import Theme from '../Theme';\r\n\r\nconst primary = '#0074C2';\r\n\r\nconst theme: Theme = {\r\n palette: {\r\n primary,\r\n secondary: '#f8fdf8',\r\n tertiary: '#231F20',\r\n logo: primary,\r\n },\r\n};\r\n\r\nexport default theme;\r\n","import React, { useContext } from 'react';\r\n\r\nimport { Theme } from './Theme';\r\nimport orange from './themes/orange';\r\nimport paybutton from './themes/paybutton';\r\nimport xec from './themes/xec';\r\n\r\nexport const themes: Record<ThemeName, Theme> = { orange, paybutton, xec };\r\n\r\nexport * from './Theme';\r\nexport default themes;\r\n\r\nexport enum ThemeName {\r\n ORANGE = 'orange',\r\n PAYBUTTON = 'paybutton',\r\n XEC = 'xec',\r\n}\r\n\r\nconst DEFAULT_THEME = ThemeName.PAYBUTTON;\r\n\r\nexport const getTheme = (name: ThemeName = DEFAULT_THEME): Theme =>\r\n themes[name];\r\n\r\nconst ThemeContext = React.createContext<Theme | undefined>(undefined);\r\n\r\nexport const ThemeProvider = ThemeContext.Provider;\r\n\r\nconst checkHash = (name: string): string => {\r\n // const textColor = new RegExp(/^[A-Za-z]+$/, 'i');\r\n if (name.startsWith('#')) {\r\n return name;\r\n } else {\r\n return `#${name}`;\r\n }\r\n};\r\n\r\nconst validateColors = (obj: any, isXec?: boolean): Theme => {\r\n const regexp = new RegExp(\r\n /(#(?:[0-9a-f]{2}){2,4}$|(#[0-9a-f]{3}$)|(rgb|hsl)a?\\((-?\\d+%?[,\\s]+){2,3}\\s*[\\d\\.]+%?\\)$|black$|silver$|gray$|whitesmoke$|maroon$|red$|purple$|fuchsia$|green$|lime$|olivedrab$|yellow$|navy$|blue$|teal$|aquamarine$|orange$|aliceblue$|antiquewhite$|aqua$|azure$|beige$|bisque$|blanchedalmond$|blueviolet$|brown$|burlywood$|cadetblue$|chartreuse$|chocolate$|coral$|cornflowerblue$|cornsilk$|crimson$|currentcolor$|darkblue$|darkcyan$|darkgoldenrod$|darkgray$|darkgreen$|darkgrey$|darkkhaki$|darkmagenta$|darkolivegreen$|darkorange$|darkorchid$|darkred$|darksalmon$|darkseagreen$|darkslateblue$|darkslategray$|darkslategrey$|darkturquoise$|darkviolet$|deeppink$|deepskyblue$|dimgray$|dimgrey$|dodgerblue$|firebrick$|floralwhite$|forestgreen$|gainsboro$|ghostwhite$|goldenrod$|gold$|greenyellow$|grey$|honeydew$|hotpink$|indianred$|indigo$|ivory$|khaki$|lavenderblush$|lavender$|lawngreen$|lemonchiffon$|lightblue$|lightcoral$|lightcyan$|lightgoldenrodyellow$|lightgray$|lightgreen$|lightgrey$|lightpink$|lightsalmon$|lightseagreen$|lightskyblue$|lightslategray$|lightslategrey$|lightsteelblue$|lightyellow$|limegreen$|linen$|mediumaquamarine$|mediumblue$|mediumorchid$|mediumpurple$|mediumseagreen$|mediumslateblue$|mediumspringgreen$|mediumturquoise$|mediumvioletred$|midnightblue$|mintcream$|mistyrose$|moccasin$|navajowhite$|oldlace$|olive$|orangered$|orchid$|palegoldenrod$|palegreen$|paleturquoise$|palevioletred$|papayawhip$|peachpuff$|peru$|pink$|plum$|powderblue$|rosybrown$|royalblue$|saddlebrown$|salmon$|sandybrown$|seagreen$|seashell$|sienna$|skyblue$|slateblue$|slategray$|slategrey$|snow$|springgreen$|steelblue$|tan$|thistle$|tomato$|transparent$|turquoise$|violet$|wheat$|white$|yellowgreen$|rebeccapurple$)/,\r\n 'i',\r\n );\r\n if (obj === undefined || obj.palette === undefined) {\r\n return themes[DEFAULT_THEME];\r\n } else {\r\n let { primary, secondary, tertiary, logo } = obj.palette;\r\n\r\n if (primary === undefined || !regexp.test(primary)) {\r\n primary = isXec ? xec.palette.primary : paybutton.palette.primary\r\n } else {\r\n primary = checkHash(primary);\r\n }\r\n\r\n if (secondary === undefined || !regexp.test(secondary)) {\r\n secondary = isXec ? xec.palette.secondary : paybutton.palette.secondary\r\n } else {\r\n secondary = checkHash(secondary);\r\n }\r\n\r\n if (tertiary === undefined || !regexp.test(tertiary)) {\r\n tertiary = isXec ? xec.palette.tertiary : paybutton.palette.tertiary\r\n } else {\r\n tertiary = checkHash(tertiary);\r\n }\r\n\r\n if (logo === undefined || !regexp.test(logo)) {\r\n logo = isXec ? xec.palette.logo : paybutton.palette.logo\r\n } else {\r\n logo = checkHash(logo);\r\n }\r\n\r\n return { palette: { primary, secondary, tertiary, logo } };\r\n }\r\n};\r\n\r\nexport const useTheme = (\r\n defaultTheme?: ThemeName | Theme,\r\n isXec?: boolean,\r\n): Theme => {\r\n const validated =\r\n defaultTheme === undefined && isXec === true\r\n ? ThemeName.XEC\r\n : defaultTheme === 'orange' || defaultTheme === 'xec'\r\n ? defaultTheme\r\n : validateColors(defaultTheme, isXec);\r\n\r\n const theme =\r\n useContext(ThemeContext) ??\r\n (typeof validated === 'object' ? validated : getTheme(validated));\r\n return theme;\r\n};\r\n","import { Button as MuiButton, makeStyles } from '@material-ui/core';\r\nimport { CreateCSSProperties } from '@material-ui/styles';\r\nimport React, { useRef, useState, useLayoutEffect } from 'react';\r\n\r\nimport { Theme, ThemeName, useTheme } from '../../themes';\r\n\r\nexport type animation = 'slide' | 'invert' | 'none' | undefined;\r\n\r\nexport interface ButtonProps {\r\n animation?: animation;\r\n text?: string;\r\n hoverText?: string;\r\n theme?: ThemeName | Theme;\r\n disabled?: boolean;\r\n onClick?: () => void;\r\n}\r\n\r\ninterface StyleProps {\r\n animation: animation;\r\n theme: Theme;\r\n}\r\n\r\nconst useStyles = makeStyles({\r\n container: {\r\n fontSize: '0.8rem !important',\r\n },\r\n button: ({ theme, ...props }: StyleProps): CreateCSSProperties => ({\r\n background: `${theme.palette.secondary} !important`,\r\n transition: '0.6s !important',\r\n ...(props.animation === 'slide'\r\n ? {\r\n background: `linear-gradient(45deg, ${theme.palette.primary} 50%, ${theme.palette.secondary} 50%) 100% center / 300% !important`,\r\n backgroundSize: '300% !important',\r\n backgroundPosition: '100% !important',\r\n transition: 'background-position 0.8s, color 0.15s !important',\r\n }\r\n : {}),\r\n color: `${theme.palette.primary} !important`,\r\n minWidth: '14em !important',\r\n padding: '0.618em 1.618em !important',\r\n margin: 'auto !important',\r\n boxShadow: '3px 3px 3px rgba(0, 0, 0, 0.08) !important',\r\n border: `2px solid ${theme.palette.primary} !important`,\r\n borderRadius: '10px !important',\r\n fontSize: '1em !important',\r\n textTransform: 'none',\r\n '&:hover': {\r\n ...(props.animation === 'slide'\r\n ? {\r\n backgroundPosition: '0 !important',\r\n color: `${theme.palette.secondary} !important`,\r\n }\r\n : {}),\r\n ...(props.animation === 'invert'\r\n ? {\r\n background: `${theme.palette.primary} !important`,\r\n color: `${theme.palette.secondary} !important`,\r\n }\r\n : {}),\r\n ...(props.animation === 'none'\r\n ? {\r\n background: `${theme.palette.secondary} !important`,\r\n color: `${theme.palette.primary} !important`,\r\n }\r\n : {}),\r\n },\r\n '& .MuiTouchRipple-root': {\r\n margin: -2,\r\n color: '#00000044 !important',\r\n },\r\n '&:disabled span': {\r\n filter: 'blur(2px)',\r\n color: 'rgba(0, 0, 0, 0.5)',\r\n },\r\n }),\r\n});\r\n\r\nexport const Button = (props: ButtonProps): React.ReactElement => {\r\n const { animation, text, hoverText, disabled } = Object.assign(\r\n {},\r\n Button.defaultProps,\r\n props,\r\n );\r\n\r\n const [hovering, setHovering] = useState(false);\r\n const [transitioning, setTransitioning] = useState(false);\r\n const timer = useRef<number>();\r\n const buttonRef = useRef<HTMLButtonElement>(null);\r\n\r\n const theme = useTheme(props.theme);\r\n const styleProps: StyleProps = { animation, theme };\r\n const classes = useStyles(styleProps);\r\n\r\n useLayoutEffect(() => {\r\n if (buttonRef !== null && text) {\r\n const { current } = buttonRef;\r\n if (current !== null) {\r\n const { style } = current;\r\n style.width = `${current.clientWidth}px`;\r\n // +4 is a seemingly magic number but it works.\r\n style.height = `${current.clientHeight + 4}px`;\r\n }\r\n }\r\n }, [text, buttonRef]);\r\n\r\n const handleMouseEnter = (): void => {\r\n setHovering(true);\r\n if (animation === 'none') return;\r\n setTransitioning(true);\r\n clearTimeout(timer.current);\r\n timer.current = window.setTimeout(() => setTransitioning(false), 150);\r\n };\r\n\r\n const handleMouseLeave = (): void => {\r\n setHovering(false);\r\n if (animation === 'none') return;\r\n setTransitioning(true);\r\n clearTimeout(timer.current);\r\n timer.current = window.setTimeout(() => setTransitioning(false), 150);\r\n };\r\n\r\n return (\r\n <div className={classes.container}>\r\n <MuiButton\r\n disabled={disabled}\r\n className={classes.button}\r\n onClick={props.onClick}\r\n onMouseEnter={handleMouseEnter}\r\n onMouseLeave={handleMouseLeave}\r\n ref={buttonRef}\r\n >\r\n <span> {transitioning !== hovering ? hoverText : (text && text.trim() !== \"\" ? text : <div>&nbsp;</div>)}\r\n </span>\r\n </MuiButton>\r\n </div>\r\n );\r\n};\r\n\r\nconst buttonDefaultProps: ButtonProps = {\r\n animation: 'slide',\r\n text: 'Donate',\r\n hoverText: 'Send Payment',\r\n disabled: false,\r\n};\r\n\r\nButton.defaultProps = buttonDefaultProps;\r\n\r\nexport default Button;\r\n","import * as xecaddr from 'xecaddrjs';\r\nimport { CryptoCurrency } from './types';\r\n\r\nexport const isValidCashAddress = (address: string): boolean => {\r\n if (!address) return false;\r\n try {\r\n // This should always work, but the xecaddrjs docs warn that some libraries\r\n // it depends on can return InvalidAddressError\r\n return xecaddr.isCashAddress(address);\r\n } catch (err) {\r\n return false;\r\n }\r\n};\r\n\r\nexport const isValidXecAddress = (address: string): boolean => {\r\n if (!address) return false;\r\n try {\r\n // This should always work, but the xecaddrjs docs warn that some libraries\r\n // it depends on can return InvalidAddressError\r\n return xecaddr.isXecAddress(address);\r\n } catch (err) {\r\n return false;\r\n }\r\n};\r\n\r\nexport const getCurrencyTypeFromAddress = (address: string): CryptoCurrency => {\r\n if (isValidCashAddress(address)) {\r\n return 'BCH';\r\n } else if (isValidXecAddress(address)) {\r\n return 'XEC';\r\n } else {\r\n throw new Error('Invalid currency');\r\n }\r\n};\r\n\r\nexport default {\r\n isValidCashAddress,\r\n isValidXecAddress,\r\n getCurrencyTypeFromAddress,\r\n};\r\n","export const FIAT_CURRENCIES = ['USD', 'CAD'];\r\n\r\nexport const CRYPTO_CURRENCIES = ['BCH', 'XEC'];\r\n\r\nexport const DECIMALS: { [key: string]: number } = {\r\n BCH: 8,\r\n XEC: 2,\r\n FIAT: 2,\r\n};\r\n\r\nexport const CURRENCY_PREFIXES_MAP: Record<typeof CRYPTO_CURRENCIES[number], string> = {\r\n bch: 'bitcoincash',\r\n xec: 'ecash',\r\n};","import { CRYPTO_CURRENCIES, FIAT_CURRENCIES } from \"./constants\";\r\nimport { CryptoCurrency, FiatCurrency } from \"./types\";\r\n\r\nexport function isFiat(unknownString: string): unknownString is FiatCurrency {\r\n return FIAT_CURRENCIES.includes(unknownString);\r\n }\r\n \r\n export function isCrypto(\r\n unknownString: string,\r\n ): unknownString is CryptoCurrency {\r\n return CRYPTO_CURRENCIES.includes(unknownString);\r\n }\r\n \r\n export function isValidCurrency(\r\n unknownString: string,\r\n ): unknownString is CryptoCurrency {\r\n return isFiat(unknownString) || isCrypto(unknownString);\r\n }","import axios from 'axios';\r\nimport _ from 'lodash';\r\nimport config from '../../../paybutton-config.json'\r\nimport { isValidCashAddress, isValidXecAddress } from './address';\r\nimport {\r\n Transaction,\r\n UtxoDetails,\r\n PriceData,\r\n TransactionDetails,\r\n Currency,\r\n} from './types';\r\nimport { isFiat } from './currency';\r\n\r\nexport const getAddressDetails = async (\r\n address: string,\r\n rootUrl = config.apiBaseUrl,\r\n): Promise<Transaction[]> => {\r\n const res = await fetch(`${rootUrl}/address/transactions/${address}`);\r\n return res.json();\r\n};\r\n\r\nexport const getAddressBalance = async (\r\n address: string,\r\n rootUrl = config.apiBaseUrl,\r\n): Promise<number | undefined> => {\r\n try {\r\n const res = await axios.get(`${rootUrl}/address/balance/${address}`);\r\n\r\n return isNaN(res.data) ? null : res.data;\r\n } catch (error) {\r\n return;\r\n }\r\n\r\n};\r\n\r\nexport const getUTXOs = async (\r\n address: string,\r\n rootUrl = config.apiBaseUrl,\r\n): Promise<UtxoDetails> => {\r\n const res = await fetch(`${rootUrl}/address/utxo/${address}`);\r\n return res.json();\r\n};\r\n\r\nexport const getBchFiatPrice = async (\r\n currency: Currency,\r\n rootUrl = config.apiBaseUrl,\r\n): Promise<PriceData> => {\r\n const { data } = await axios.get(\r\n `${rootUrl}/price/bitcoincash/${_.lowerCase(currency)}`,\r\n );\r\n\r\n const price: number = data;\r\n return { price };\r\n};\r\n\r\nexport const getXecFiatPrice = async (\r\n currency: Currency,\r\n rootUrl = config.apiBaseUrl,\r\n): Promise<PriceData> => {\r\n const { data } = await axios.get(\r\n `${rootUrl}/price/ecash/${_.lowerCase(currency)}`,\r\n );\r\n\r\n const price: number = data;\r\n return { price };\r\n};\r\n\r\nexport const getFiatPrice = async (currency: string, to: string, apiBaseUrl?: string): Promise<number | null> => {\r\n try {\r\n if (isFiat(currency) && isValidCashAddress(to)) {\r\n const data = await getBchFiatPrice(currency, apiBaseUrl);\r\n return data.price;\r\n } else if (isFiat(currency) && isValidXecAddress(to)) {\r\n const data = await getXecFiatPrice(currency, apiBaseUrl);\r\n return data.price;\r\n }\r\n return null\r\n } catch (error) {\r\n console.log('err', error);\r\n }\r\n return null\r\n}\r\n\r\nexport const getTransactionDetails = async (\r\n txid: string,\r\n rootUrl = config.apiBaseUrl,\r\n): Promise<TransactionDetails> => {\r\n const res = await fetch(`${rootUrl}/transactions/details/${txid}`);\r\n return res.json();\r\n};\r\n\r\nexport default {\r\n getAddressDetails,\r\n getTransactionDetails,\r\n getBchFiatPrice,\r\n getXecFiatPrice,\r\n getAddressBalance,\r\n};\r\n\r\nexport const getCashtabProviderStatus = () => {\r\n const windowAny = window as any\r\n if (window && windowAny.bitcoinAbc && windowAny.bitcoinAbc === 'cashtab') {\r\n return true;\r\n }\r\n return false;\r\n};\r\n\r\n","/*!\n * accounting.js v0.4.1\n * Copyright 2014 Open Exchange Rates\n *\n * Freely distributable under the MIT license.\n * Portions of accounting.js are inspired or borrowed from underscore.js\n *\n * Full details and documentation:\n * http://openexchangerates.github.io/accounting.js/\n */\n\n(function(root, undefined) {\n\n\t/* --- Setup --- */\n\n\t// Create the local library object, to be exported or referenced globally later\n\tvar lib = {};\n\n\t// Current version\n\tlib.version = '0.4.1';\n\n\n\t/* --- Exposed settings --- */\n\n\t// The library's settings configuration object. Contains default parameters for\n\t// currency and number formatting\n\tlib.settings = {\n\t\tcurrency: {\n\t\t\tsymbol : \"$\",\t\t// default currency symbol is '$'\n\t\t\tformat : \"%s%v\",\t// controls output: %s = symbol, %v = value (can be object, see docs)\n\t\t\tdecimal : \".\",\t\t// decimal point separator\n\t\t\tthousand : \",\",\t\t// thousands separator\n\t\t\tprecision : 2,\t\t// decimal places\n\t\t\tgrouping : 3\t\t// digit grouping (not implemented yet)\n\t\t},\n\t\tnumber: {\n\t\t\tprecision : 0,\t\t// default precision on numbers is 0\n\t\t\tgrouping : 3,\t\t// digit grouping (not implemented yet)\n\t\t\tthousand : \",\",\n\t\t\tdecimal : \".\"\n\t\t}\n\t};\n\n\n\t/* --- Internal Helper Methods --- */\n\n\t// Store reference to possibly-available ECMAScript 5 methods for later\n\tvar nativeMap = Array.prototype.map,\n\t\tnativeIsArray = Array.isArray,\n\t\ttoString = Object.prototype.toString;\n\n\t/**\n\t * Tests whether supplied parameter is a string\n\t * from underscore.js\n\t */\n\tfunction isString(obj) {\n\t\treturn !!(obj === '' || (obj && obj.charCodeAt && obj.substr));\n\t}\n\n\t/**\n\t * Tests whether supplied parameter is a string\n\t * from underscore.js, delegates to ECMA5's native Array.isArray\n\t */\n\tfunction isArray(obj) {\n\t\treturn nativeIsArray ? nativeIsArray(obj) : toString.call(obj) === '[object Array]';\n\t}\n\n\t/**\n\t * Tests whether supplied parameter is a true object\n\t */\n\tfunction isObject(obj) {\n\t\treturn obj && toString.call(obj) === '[object Object]';\n\t}\n\n\t/**\n\t * Extends an object with a defaults object, similar to underscore's _.defaults\n\t *\n\t * Used for abstracting parameter handling from API methods\n\t */\n\tfunction defaults(object, defs) {\n\t\tvar key;\n\t\tobject = object || {};\n\t\tdefs = defs || {};\n\t\t// Iterate over object non-prototype properties:\n\t\tfor (key in defs) {\n\t\t\tif (defs.hasOwnProperty(key)) {\n\t\t\t\t// Replace values with defaults only if undefined (allow empty/zero values):\n\t\t\t\tif (object[key] == null) object[key] = defs[key];\n\t\t\t}\n\t\t}\n\t\treturn object;\n\t}\n\n\t/**\n\t * Implementation of `Array.map()` for iteration loops\n\t *\n\t * Returns a new Array as a result of calling `iterator` on each array value.\n\t * Defers to native Array.map if available\n\t */\n\tfunction map(obj, iterator, context) {\n\t\tvar results = [], i, j;\n\n\t\tif (!obj) return results;\n\n\t\t// Use native .map method if it exists:\n\t\tif (nativeMap && obj.map === nativeMap) return obj.map(iterator, context);\n\n\t\t// Fallback for native .map:\n\t\tfor (i = 0, j = obj.length; i < j; i++ ) {\n\t\t\tresults[i] = iterator.call(context, obj[i], i, obj);\n\t\t}\n\t\treturn results;\n\t}\n\n\t/**\n\t * Check and normalise the value of precision (must be positive integer)\n\t */\n\tfunction checkPrecision(val, base) {\n\t\tval = Math.round(Math.abs(val));\n\t\treturn isNaN(val)? base : val;\n\t}\n\n\n\t/**\n\t * Parses a format string or object and returns format obj for use in rendering\n\t *\n\t * `format` is either a string with the default (positive) format, or object\n\t * containing `pos` (required), `neg` and `zero` values (or a function returning\n\t * either a string or object)\n\t *\n\t * Either string or format.pos must contain \"%v\" (value) to be valid\n\t */\n\tfunction checkCurrencyFormat(format) {\n\t\tvar defaults = lib.settings.currency.format;\n\n\t\t// Allow function as format parameter (should return string or object):\n\t\tif ( typeof format === \"function\" ) format = format();\n\n\t\t// Format can be a string, in which case `value` (\"%v\") must be present:\n\t\tif ( isString( format ) && format.match(\"%v\") ) {\n\n\t\t\t// Create and return positive, negative and zero formats:\n\t\t\treturn {\n\t\t\t\tpos : format,\n\t\t\t\tneg : format.replace(\"-\", \"\").replace(\"%v\", \"-%v\"),\n\t\t\t\tzero : format\n\t\t\t};\n\n\t\t// If no format, or object is missing valid positive value, use defaults:\n\t\t} else if ( !format || !format.pos || !format.pos.match(\"%v\") ) {\n\n\t\t\t// If defaults is a string, casts it to an object for faster checking next time:\n\t\t\treturn ( !isString( defaults ) ) ? defaults : lib.settings.currency.format = {\n\t\t\t\tpos : defaults,\n\t\t\t\tneg : defaults.replace(\"%v\", \"-%v\"),\n\t\t\t\tzero : defaults\n\t\t\t};\n\n\t\t}\n\t\t// Otherwise, assume format was fine:\n\t\treturn format;\n\t}\n\n\n\t/* --- API Methods --- */\n\n\t/**\n\t * Takes a string/array of strings, removes all formatting/cruft and returns the raw float value\n\t * Alias: `accounting.parse(string)`\n\t *\n\t * Decimal must be included in the regular expression to match floats (defaults to\n\t * accounting.settings.number.decimal), so if the number uses a non-standard decimal \n\t * separator, provide it as the second argument.\n\t *\n\t * Also matches bracketed negatives (eg. \"$ (1.99)\" => -1.99)\n\t *\n\t * Doesn't throw any errors (`NaN`s become 0) but this may change in future\n\t */\n\tvar unformat = lib.unformat = lib.parse = function(value, decimal) {\n\t\t// Recursively unformat arrays:\n\t\tif (isArray(value)) {\n\t\t\treturn map(value, function(val) {\n\t\t\t\treturn unformat(val, decimal);\n\t\t\t});\n\t\t}\n\n\t\t// Fails silently (need decent errors):\n\t\tvalue = value || 0;\n\n\t\t// Return the value as-is if it's already a number:\n\t\tif (typeof value === \"number\") return value;\n\n\t\t// Default decimal point comes from settings, but could be set to eg. \",\" in opts:\n\t\tdecimal = decimal || lib.settings.number.decimal;\n\n\t\t // Build regex to strip out everything except digits, decimal point and minus sign:\n\t\tvar regex = new RegExp(\"[^0-9-\" + decimal + \"]\", [\"g\"]),\n\t\t\tunformatted = parseFloat(\n\t\t\t\t(\"\" + value)\n\t\t\t\t.replace(/\\((.*)\\)/, \"-$1\") // replace bracketed values with negatives\n\t\t\t\t.replace(regex, '') // strip out any cruft\n\t\t\t\t.replace(decimal, '.') // make sure decimal point is standard\n\t\t\t);\n\n\t\t// This will fail silently which may cause trouble, let's wait and see:\n\t\treturn !isNaN(unformatted) ? unformatted : 0;\n\t};\n\n\n\t/**\n\t * Implementation of toFixed() that treats floats more like decimals\n\t *\n\t * Fixes binary rounding issues (eg. (0.615).toFixed(2) === \"0.61\") that present\n\t * problems for accounting- and finance-related software.\n\t */\n\tvar toFixed = lib.toFixed = function(value, precision) {\n\t\tprecision = checkPrecision(precision, lib.settings.number.precision);\n\t\tvar power = Math.pow(10, precision);\n\n\t\t// Multiply up by precision, round accurately, then divide and use native toFixed():\n\t\treturn (Math.round(lib.unformat(value) * power) / power).toFixed(precision);\n\t};\n\n\n\t/**\n\t * Format a number, with comma-separated thousands and custom precision/decimal places\n\t * Alias: `accounting.format()`\n\t *\n\t * Localise by overriding the precision and thousand / decimal separators\n\t * 2nd parameter `precision` can be an object matching `settings.number`\n\t */\n\tvar formatNumber = lib.formatNumber = lib.format = function(number, precision, thousand, decimal) {\n\t\t// Resursively format arrays:\n\t\tif (isArray(number)) {\n\t\t\treturn map(number, function(val) {\n\t\t\t\treturn formatNumber(val, precision, thousand, decimal);\n\t\t\t});\n\t\t}\n\n\t\t// Clean up number:\n\t\tnumber = unformat(number);\n\n\t\t// Build options object from second param (if object) or all params, extending defaults:\n\t\tvar opts = defaults(\n\t\t\t\t(isObject(precision) ? precision : {\n\t\t\t\t\tprecision : precision,\n\t\t\t\t\tthousand : thousand,\n\t\t\t\t\tdecimal : decimal\n\t\t\t\t}),\n\t\t\t\tlib.settings.number\n\t\t\t),\n\n\t\t\t// Clean up precision\n\t\t\tusePrecision = checkPrecision(opts.precision),\n\n\t\t\t// Do some calc:\n\t\t\tnegative = number < 0 ? \"-\" : \"\",\n\t\t\tbase = parseInt(toFixed(Math.abs(number || 0), usePrecision), 10) + \"\",\n\t\t\tmod = base.length > 3 ? base.length % 3 : 0;\n\n\t\t// Format the number:\n\t\treturn negative + (mod ? base.substr(0, mod) + opts.thousand : \"\") + base.substr(mod).replace(/(\\d{3})(?=\\d)/g, \"$1\" + opts.thousand) + (usePrecision ? opts.decimal + toFixed(Math.abs(number), usePrecision).split('.')[1] : \"\");\n\t};\n\n\n\t/**\n\t * Format a number into currency\n\t *\n\t * Usage: accounting.formatMoney(number, symbol, precision, thousandsSep, decimalSep, format)\n\t * defaults: (0, \"$\", 2, \",\", \".\", \"%s%v\")\n\t *\n\t * Localise by overriding the symbol, precision, thousand / decimal separators and format\n\t * Second param can be an object matching `settings.currency` which is the easiest way.\n\t *\n\t * To do: tidy up the parameters\n\t */\n\tvar formatMoney = lib.formatMoney = function(number, symbol, precision, thousand, decimal, format) {\n\t\t// Resursively format arrays:\n\t\tif (isArray(number)) {\n\t\t\treturn map(number, function(val){\n\t\t\t\treturn formatMoney(val, symbol, precision, thousand, decimal, format);\n\t\t\t});\n\t\t}\n\n\t\t// Clean up number:\n\t\tnumber = unformat(number);\n\n\t\t// Build options object from second param (if object) or all params, extending defaults:\n\t\tvar opts = defaults(\n\t\t\t\t(isObject(symbol) ? symbol : {\n\t\t\t\t\tsymbol : symbol,\n\t\t\t\t\tprecision : precision,\n\t\t\t\t\tthousand : thousand,\n\t\t\t\t\tdecimal : decimal,\n\t\t\t\t\tformat : format\n\t\t\t\t}),\n\t\t\t\tlib.settings.currency\n\t\t\t),\n\n\t\t\t// Check format (returns object with pos, neg and zero):\n\t\t\tformats = checkCurrencyFormat(opts.format),\n\n\t\t\t// Choose which format to use for this value:\n\t\t\tuseFormat = number > 0 ? formats.pos : number < 0 ? formats.neg : formats.zero;\n\n\t\t// Return with currency symbol added:\n\t\treturn useFormat.replace('%s', opts.symbol).replace('%v', formatNumber(Math.abs(number), checkPrecision(opts.precision), opts.thousand, opts.decimal));\n\t};\n\n\n\t/**\n\t * Format a list of numbers into an accounting column, padding with whitespace\n\t * to line up currency symbols, thousand separators and decimals places\n\t *\n\t * List should be an array of numbers\n\t * Second parameter can be an object containing keys that match the params\n\t *\n\t * Returns array of accouting-formatted number strings of same length\n\t *\n\t * NB: `white-space:pre` CSS rule is required on the list container to prevent\n\t * browsers from collapsing the whitespace in the output strings.\n\t */\n\tlib.formatColumn = function(list, symbol, precision, thousand, decimal, format) {\n\t\tif (!list) return [];\n\n\t\t// Build options object from second param (if object) or all params, extending defaults:\n\t\tvar opts = defaults(\n\t\t\t\t(isObject(symbol) ? symbol : {\n\t\t\t\t\tsymbol : symbol,\n\t\t\t\t\tprecision : precision,\n\t\t\t\t\tthousand : thousand,\n\t\t\t\t\tdecimal : decimal,\n\t\t\t\t\tformat : format\n\t\t\t\t}),\n\t\t\t\tlib.settings.currency\n\t\t\t),\n\n\t\t\t// Check format (returns object with pos, neg and zero), only need pos for now:\n\t\t\tformats = checkCurrencyFormat(opts.format),\n\n\t\t\t// Whether to pad at start of string or after currency symbol:\n\t\t\tpadAfterSymbol = formats.pos.indexOf(\"%s\") < formats.pos.indexOf(\"%v\") ? true : false,\n\n\t\t\t// Store value for the length of the longest string in the column:\n\t\t\tmaxLength = 0,\n\n\t\t\t// Format the list according to options, store the length of the longest string:\n\t\t\tformatted = map(list, function(val, i) {\n\t\t\t\tif (isArray(val)) {\n\t\t\t\t\t// Recursively format columns if list is a multi-dimensional array:\n\t\t\t\t\treturn lib.formatColumn(val, opts);\n\t\t\t\t} else {\n\t\t\t\t\t// Clean up the value\n\t\t\t\t\tval = unformat(val);\n\n\t\t\t\t\t// Choose which format to use for this value (pos, neg or zero):\n\t\t\t\t\tvar useFormat = val > 0 ? formats.pos : val < 0 ? formats.neg : formats.zero,\n\n\t\t\t\t\t\t// Format this value, push into formatted list and save the length:\n\t\t\t\t\t\tfVal = useFormat.replace('%s', opts.symbol).replace('%v', formatNumber(Math.abs(val), checkPrecision(opts.precision), opts.thousand, opts.decimal));\n\n\t\t\t\t\tif (fVal.length > maxLength) maxLength = fVal.length;\n\t\t\t\t\treturn fVal;\n\t\t\t\t}\n\t\t\t});\n\n\t\t// Pad each number in the list and send back the column of numbers:\n\t\treturn map(formatted, function(val, i) {\n\t\t\t// Only if this is a string (not a nested array, which would have already been padded):\n\t\t\tif (isString(val) && val.length < maxLength) {\n\t\t\t\t// Depending on symbol position, pad after symbol or at index 0:\n\t\t\t\treturn padAfterSymbol ? val.replace(opts.symbol, opts.symbol+(new Array(maxLength - val.length + 1).join(\" \"))) : (new Array(maxLength - val.length + 1).join(\" \")) + val;\n\t\t\t}\n\t\t\treturn val;\n\t\t});\n\t};\n\n\n\t/* --- Module Definition --- */\n\n\t// Export accounting for CommonJS. If being loaded as an AMD module, define it as such.\n\t// Otherwise, just add `accounting` to the global object\n\tif (typeof exports !== 'undefined') {\n\t\tif (typeof module !== 'undefined' && module.exports) {\n\t\t\texports = module.exports = lib;\n\t\t}\n\t\texports.accounting = lib;\n\t} else if (typeof define === 'function' && define.amd) {\n\t\t// Return the library as an AMD module:\n\t\tdefine([], function() {\n\t\t\treturn lib;\n\t\t});\n\t} else {\n\t\t// Use accounting.noConflict to restore `accounting` back to its original value.\n\t\t// Returns a reference to the library's `accounting` object;\n\t\t// e.g. `var numbers = accounting.noConflict();`\n\t\tlib.noConflict = (function(oldAccounting) {\n\t\t\treturn function() {\n\t\t\t\t// Reset the value of the root's `accounting` variable:\n\t\t\t\troot.accounting = oldAccounting;\n\t\t\t\t// Delete the noConflict method:\n\t\t\t\tlib.noConflict = undefined;\n\t\t\t\t// Return reference to the library to re-assign it:\n\t\t\t\treturn lib;\n\t\t\t};\n\t\t})(root.accounting);\n\n\t\t// Declare `fx` on the root (global/window) object:\n\t\troot['accounting'] = lib;\n\t}\n\n\t// Root will be `window` in browser or `global` on the server:\n}(this));\n","/*\nobject-assign\n(c) Sindre Sorhus\n@license MIT\n*/\n\n'use strict';\n/* eslint-disable no-unused-vars */\nvar getOwnPropertySymbols = Object.getOwnPropertySymbols;\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\nvar propIsEnumerable = Object.prototype.propertyIsEnumerable;\n\nfunction toObject(val) {\n\tif (val === null || val === undefined) {\n\t\tthrow new TypeError('Object.assign cannot be called with null or undefined');\n\t}\n\n\treturn Object(val);\n}\n\nfunction shouldUseNative() {\n\ttry {\n\t\tif (!Object.assign) {\n\t\t\treturn false;\n\t\t}\n\n\t\t// Detect buggy property enumeration order in older V8 versions.\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=4118\n\t\tvar test1 = new String('abc'); // eslint-disable-line no-new-wrappers\n\t\ttest1[5] = 'de';\n\t\tif (Object.getOwnPropertyNames(test1)[0] === '5') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test2 = {};\n\t\tfor (var i = 0; i < 10; i++) {\n\t\t\ttest2['_' + String.fromCharCode(i)] = i;\n\t\t}\n\t\tvar order2 = Object.getOwnPropertyNames(test2).map(function (n) {\n\t\t\treturn test2[n];\n\t\t});\n\t\tif (order2.join('') !== '0123456789') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test3 = {};\n\t\t'abcdefghijklmnopqrst'.split('').forEach(function (letter) {\n\t\t\ttest3[letter] = letter;\n\t\t});\n\t\tif (Object.keys(Object.assign({}, test3)).join('') !==\n\t\t\t\t'abcdefghijklmnopqrst') {\n\t\t\treturn false;\n\t\t}\n\n\t\treturn true;\n\t} catch (err) {\n\t\t// We don't expect any of the above to throw, but better to be safe.\n\t\treturn false;\n\t}\n}\n\nmodule.exports = shouldUseNative() ? Object.assign : function (target, source) {\n\tvar from;\n\tvar to = toObject(target);\n\tvar symbols;\n\n\tfor (var s = 1; s < arguments.length; s++) {\n\t\tfrom = Object(arguments[s]);\n\n\t\tfor (var key in from) {\n\t\t\tif (hasOwnProperty.call(from, key)) {\n\t\t\t\tto[key] = from[key];\n\t\t\t}\n\t\t}\n\n\t\tif (getOwnPropertySymbols) {\n\t\t\tsymbols = getOwnPropertySymbols(from);\n\t\t\tfor (var i = 0; i < symbols.length; i++) {\n\t\t\t\tif (propIsEnumerable.call(from, symbols[i])) {\n\t\t\t\t\tto[symbols[i]] = from[symbols[i]];\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn to;\n};\n","// Generated using ShowCurrencies.java\nvar map = {\nAD: 'EUR',\nAE: 'AED',\nAF: 'AFN',\nAG: 'XCD',\nAI: 'XCD',\nAL: 'ALL',\nAM: 'AMD',\nAN: 'ANG',\nAO: 'AOA',\nAR: 'ARS',\nAS: 'USD',\nAT: 'EUR',\nAU: 'AUD',\nAW: 'AWG',\nAX: 'EUR',\nAZ: 'AZN',\nBA: 'BAM',\nBB: 'BBD',\nBD: 'BDT',\nBE: 'EUR',\nBF: 'XOF',\nBG: 'BGN',\nBH: 'BHD',\nBI: 'BIF',\nBJ: 'XOF',\nBL: 'EUR',\nBM: 'BMD',\nBN: 'BND',\nBO: 'BOB',\nBQ: 'USD',\nBR: 'BRL',\nBS: 'BSD',\nBT: 'BTN',\nBV: 'NOK',\nBW: 'BWP',\nBY: 'BYR',\nBZ: 'BZD',\nCA: 'CAD',\nCC: 'AUD',\nCD: 'CDF',\nCF: 'XAF',\nCG: 'XAF',\nCH: 'CHF',\nCI: 'XOF',\nCK: 'NZD',\nCL: 'CLP',\nCM: 'XAF',\nCN: 'CNY',\nCO: 'COP',\nCR: 'CRC',\nCU: 'CUP',\nCV: 'CVE',\nCW: 'ANG',\nCX: 'AUD',\nCY: 'EUR',\nCZ: 'CZK',\nDE: 'EUR',\nDJ: 'DJF',\nDK: 'DKK',\nDM: 'XCD',\nDO: 'DOP',\nDZ: 'DZD',\nEC: 'USD',\nEE: 'EUR',\nEG: 'EGP',\nEH: 'MAD',\nER: 'ERN',\nES: 'EUR',\nET: 'ETB',\nFI: 'EUR',\nFJ: 'FJD',\nFK: 'FKP',\nFM: 'USD',\nFO: 'DKK',\nFR: 'EUR',\nGA: 'XAF',\nGB: 'GBP',\nGD: 'XCD',\nGE: 'GEL',\nGF: 'EUR',\nGG: 'GBP',\nGH: 'GHS',\nGI: 'GIP',\nGL: 'DKK',\nGM: 'GMD',\nGN: 'GNF',\nGP: 'EUR',\nGQ: 'XAF',\nGR: 'EUR',\nGS: 'GBP',\nGT: 'GTQ',\nGU: 'USD',\nGW: 'XOF',\nGY: 'GYD',\nHK: 'HKD',\nHM: 'AUD',\nHN: 'HNL',\nHR: 'HRK',\nHT: 'HTG',\nHU: 'HUF',\nID: 'IDR',\nIE: 'EUR',\nIL: 'ILS',\nIM: 'GBP',\nIN: 'INR',\nIO: 'USD',\nIQ: 'IQD',\nIR: 'IRR',\nIS: 'ISK',\nIT: 'EUR',\nJE: 'GBP',\nJM: 'JMD',\nJO: 'JOD',\nJP: 'JPY',\nKE: 'KES',\nKG: 'KGS',\nKH: 'KHR',\nKI: 'AUD',\nKM: 'KMF',\nKN: 'XCD',\nKP: 'KPW',\nKR: 'KRW',\nKW: 'KWD',\nKY: 'KYD',\nKZ: 'KZT',\nLA: 'LAK',\nLB: 'LBP',\nLC: 'XCD',\nLI: 'CHF',\nLK: 'LKR',\nLR: 'LRD',\nLS: 'LSL',\nLT: 'LTL',\nLU: 'EUR',\nLV: 'LVL',\nLY: 'LYD',\nMA: 'MAD',\nMC: 'EUR',\nMD: 'MDL',\nME: 'EUR',\nMF: 'EUR',\nMG: 'MGA',\nMH: 'USD',\nMK: 'MKD',\nML: 'XOF',\nMM: 'MMK',\nMN: 'MNT',\nMO: 'MOP',\nMP: 'USD',\nMQ: 'EUR',\nMR: 'MRO',\nMS: 'XCD',\nMT: 'EUR',\nMU: 'MUR',\nMV: 'MVR',\nMW: 'MWK',\nMX: 'MXN',\nMY: 'MYR',\nMZ: 'MZN',\nNA: 'NAD',\nNC: 'XPF',\nNE: 'XOF',\nNF: 'AUD',\nNG: 'NGN',\nNI: 'NIO',\nNL: 'EUR',\nNO: 'NOK',\nNP: 'NPR',\nNR: 'AUD',\nNU: 'NZD',\nNZ: 'NZD',\nOM: 'OMR',\nPA: 'PAB',\nPE: 'PEN',\nPF: 'XPF',\nPG: 'PGK',\nPH: 'PHP',\nPK: 'PKR',\nPL: 'PLN',\nPM: 'EUR',\nPN: 'NZD',\nPR: 'USD',\nPS: 'ILS',\nPT: 'EUR',\nPW: 'USD',\nPY: 'PYG',\nQA: 'QAR',\nRE: 'EUR',\nRO: 'RON',\nRS: 'RSD',\nRU: 'RUB',\nRW: 'RWF',\nSA: 'SAR',\nSB: 'SBD',\nSC: 'SCR',\nSD: 'SDG',\nSE: 'SEK',\nSG: 'SGD',\nSH: 'SHP',\nSI: 'EUR',\nSJ: 'NOK',\nSK: 'EUR',\nSL: 'SLL',\nSM: 'EUR',\nSN: 'XOF',\nSO: 'SOS',\nSR: 'SRD',\nST: 'STD',\nSV: 'SVC',\nSX: 'ANG',\nSY: 'SYP',\nSZ: 'SZL',\nTC: 'USD',\nTD: 'XAF',\nTF: 'EUR',\nTG: 'XOF',\nTH: 'THB',\nTJ: 'TJS',\nTK: 'NZD',\nTL: 'USD',\nTM: 'TMT',\nTN: 'TND',\nTO: 'TOP',\nTR: 'TRY',\nTT: 'TTD',\nTV: 'AUD',\nTW: 'TWD',\nTZ: 'TZS',\nUA: 'UAH',\nUG: 'UGX',\nUM: 'USD',\nUS: 'USD',\nUY: 'UYU',\nUZ: 'UZS',\nVA: 'EUR',\nVC: 'XCD',\nVE: 'VEF',\nVG: 'USD',\nVI: 'USD',\nVN: 'VND',\nVU: 'VUV',\nWF: 'XPF',\nWS: 'WST',\nYE: 'YER',\nYT: 'EUR',\nZA: 'ZAR',\nZM: 'ZMK',\nZW: 'ZWL'\n};\n\nmodule.exports = map;","var map = require(\"./map\");\n\nvar getCountryCode = function(localeString) {\n var components = localeString.split(\"_\");\n if (components.length == 2) {\n return components.pop();\n }\n components = localeString.split(\"-\");\n if (components.length == 2) {\n return components.pop();\n }\n return localeString;\n}\n\nexports.getCurrency = function(locale) {\n var countryCode = getCountryCode(locale).toUpperCase();\n if (countryCode in map) {\n return map[countryCode];\n }\n return null;\n}\n\nexports.getLocales = function(currencyCode) {\n currencyCode = currencyCode.toUpperCase();\n var locales = [];\n for (countryCode in map) {\n if (map[countryCode] === currencyCode) {\n locales.push(countryCode);\n }\n }\n return locales;\n}","var accounting = require('accounting')\nvar assign = require('object-assign')\nvar localeCurrency = require('locale-currency')\nvar currencies = require('./currencies.json')\nvar localeFormats = require('./localeFormats.json')\n\nvar defaultCurrency = {\n symbol: '',\n thousandsSeparator: ',',\n decimalSeparator: '.',\n symbolOnLeft: true,\n spaceBetweenAmountAndSymbol: false,\n decimalDigits: 2\n}\n\nvar defaultLocaleFormat = {}\n\nvar formatMapping = [\n {\n symbolOnLeft: true,\n spaceBetweenAmountAndSymbol: false,\n format: {\n pos: '%s%v',\n neg: '-%s%v',\n zero: '%s%v'\n }\n },\n {\n symbolOnLeft: true,\n spaceBetweenAmountAndSymbol: true,\n format: {\n pos: '%s %v',\n neg: '-%s %v',\n zero: '%s %v'\n }\n },\n {\n symbolOnLeft: false,\n spaceBetweenAmountAndSymbol: false,\n format: {\n pos: '%v%s',\n neg: '-%v%s',\n zero: '%v%s'\n }\n },\n {\n symbolOnLeft: false,\n spaceBetweenAmountAndSymbol: true,\n format: {\n pos: '%v %s',\n neg: '-%v %s',\n zero: '%v %s'\n }\n }\n]\n\nfunction format(value, options) {\n var code = options.code || (options.locale && localeCurrency.getCurrency(options.locale))\n var localeMatch = /^([a-z]+)([_-]([a-z]+))?$/i.exec(options.locale) || []\n var language = localeMatch[1]\n var region = localeMatch[3]\n var localeFormat = assign({}, defaultLocaleFormat,\n localeFormats[language] || {},\n localeFormats[language + '-' + region] || {})\n var currency = assign({}, defaultCurrency, findCurrency(code), localeFormat)\n \n var symbolOnLeft = currency.symbolOnLeft\n var spaceBetweenAmountAndSymbol = currency.spaceBetweenAmountAndSymbol\n\n var format = formatMapping.filter(function(f) {\n return f.symbolOnLeft == symbolOnLeft && f.spaceBetweenAmountAndSymbol == spaceBetweenAmountAndSymbol\n })[0].format\n\n return accounting.formatMoney(value, {\n symbol: isUndefined(options.symbol)\n ? currency.symbol\n : options.symbol,\n\n decimal: isUndefined(options.decimal)\n ? currency.decimalSeparator\n : options.decimal,\n\n thousand: isUndefined(options.thousand)\n ? currency.thousandsSeparator\n : options.thousand,\n\n precision: typeof options.precision === 'number'\n ? options.precision\n : currency.decimalDigits,\n\n format: ['string', 'object'].indexOf(typeof options.format) > -1\n ? options.format\n : format\n })\n}\n\nfunction findCurrency (currencyCode) {\n return currencies[currencyCode]\n}\n\nfunction isUndefined (val) {\n return typeof val === 'undefined'\n}\n\nfunction unformat(value, options) {\n var code = options.code || (options.locale && localeCurrency.getCurrency(options.locale))\n var localeFormat = localeFormats[options.locale] || defaultLocaleFormat\n var currency = assign({}, defaultCurrency, findCurrency(code), localeFormat)\n var decimal = isUndefined(options.decimal) ? currency.decimalSeparator : options.decimal\n return accounting.unformat(value, decimal)\n}\n\nmodule.exports = {\n defaultCurrency: defaultCurrency,\n get currencies() {\n // In favor of backwards compatibility, the currencies map is converted to an array here\n return Object.keys(currencies).map(function(key) {\n return currencies[key]\n })\n },\n findCurrency: findCurrency,\n format: format,\n unformat: unformat\n}","import currencyFormat from 'currency-formatter';\r\nimport { Currency } from './types';\r\nimport { DECIMALS } from './constants'\r\n\r\nexport const amount = (x?: number | null): string | undefined => {\r\n const clean = +x!;\r\n if (clean === 0) return;\r\n return clean\r\n ?.toFixed(8)\r\n .replace(/\\.0*$/, '')\r\n .replace(/(\\.\\d*?)0*$/, '$1');\r\n};\r\n\r\nexport const formatPrice = (\r\n price: number,\r\n currencyType: Currency,\r\n precision = DECIMALS.FIAT,\r\n) => {\r\n return Intl.NumberFormat(undefined, {\r\n style: 'currency',\r\n currency: currencyType,\r\n currencyDisplay: 'narrowSymbol',\r\n minimumFractionDigits: precision,\r\n maximumFractionDigits: precision,\r\n }).format(price);\r\n};\r\n\r\nexport const formatComma = (number: number) => {\r\n const formattedString = currencyFormat.format(number, {\r\n symbol: '',\r\n decimal: '',\r\n thousand: ',',\r\n precision: 0,\r\n format: '%v',\r\n });\r\n\r\n return formattedString;\r\n};\r\n\r\nexport const formatBCH = (bch: string) => {\r\n const val = +bch;\r\n const formattedString = currencyFormat.format(val, {\r\n symbol: '',\r\n decimal: '.',\r\n thousand: ',',\r\n precision: 8,\r\n format: '%v',\r\n });\r\n\r\n return formattedString;\r\n};\r\n\r\nexport const formatXEC = (xec: string) => {\r\n const val = +xec;\r\n const formattedString = currencyFormat.format(val, {\r\n symbol: '',\r\n decimal: '.',\r\n thousand: ',',\r\n precision: 2,\r\n format: '%v',\r\n });\r\n\r\n return formattedString;\r\n};\r\n\r\nexport const isPropsTrue = (value?: string | boolean) => {\r\n switch (typeof value) {\r\n case \"string\":\r\n return value === \"true\"\r\n case \"boolean\":\r\n return value\r\n case \"undefined\":\r\n return false\r\n }\r\n}\r\n\r\nexport default {\r\n amount,\r\n formatPrice,\r\n formatComma,\r\n formatBCH,\r\n formatXEC,\r\n};\r\n","import { lib, enc } from 'crypto-js';\r\n\r\n// All the below variables are already encoded to HEX\r\nexport const OP_RETURN_PREFIX_PUSHDATA = '04'; // \\x04\r\nexport const OP_RETURN_PREFIX = '50415900'; // PAY\\x00\r\nexport const VERSION = '00'; // \\x00\r\n\r\n// 223 total bytes\r\n// - 1 from the OP_RETURN op code: '\\x6a'\r\n// - 1 from the protocol pushdata: '\\x04'\r\n// - 4 from the 4-byte procol prefix: 'PAY\\x00'\r\n// - 1 for the version byte: '\\x00'\r\n// - 2 from the maximum size for the data pushdata\r\n// - 1 from the paymentId pushdata\r\n// = 213 available bytes\r\nexport const USER_DATA_BYTES_LIMIT = 213;\r\n\r\n// Pushdata is self-describing up to 75 bytes, since 0x4c (76 in hex) is\r\n// a special OP code.\r\nconst SINGLE_PUSHDATA_BYTE_LIMIT = 75;\r\n\r\nfunction prependPaymentIdWithPushdata(hexString: string): string {\r\n // 2 hex chars == 1 byte\r\n if (hexString.length % 2 !== 0) {\r\n throw new Error(\r\n `Malformed input; paymentId hex should never be of odd length`,\r\n );\r\n }\r\n const bytesQuantity = hexString.length / 2;\r\n // We limit the paymentId size to 75 bytes,\r\n // since this is way more than necessary for security.\r\n if (bytesQuantity > SINGLE_PUSHDATA_BYTE_LIMIT) {\r\n throw new Error(\r\n `Maximum ${SINGLE_PUSHDATA_BYTE_LIMIT} byte size exceeded for paymentId: ${bytesQuantity}`,\r\n );\r\n }\r\n const pushdata = bytesQuantity.toString(16).padStart(2, '0');\r\n return `${pushdata}${hexString}`;\r\n}\r\n\r\n// UTF8 encoding\r\nfunction stringToHex(str: string): string {\r\n const encoder = new TextEncoder();\r\n const encoded = encoder.encode(str);\r\n const encodedBytes = Array.from(encoded);\r\n return encodedBytes.map(byte => byte.toString(16).padStart(2, '0')).join('');\r\n}\r\n\r\nexport function generatePaymentId(bytesAmount: number): string {\r\n // Generate random bytes\r\n const wordArray = lib.WordArray.random(bytesAmount);\r\n\r\n // Convert the word array to a hex string\r\n return enc.Hex.stringify(wordArray);\r\n}\r\n\r\nfunction generatePushdataPrefixedPaymentId(\r\n bytesAmount: number,\r\n disabled = false,\r\n): string {\r\n if (disabled) {\r\n return '00';\r\n }\r\n const hexString = generatePaymentId(bytesAmount);\r\n\r\n // The result is 18 char long:\r\n // ---\r\n // a hex character encodes 4 bits of information (2⁴ = 16);\r\n // ... therefore; 8 bytes = 64 bits => 64/4 = 16 hex chars\r\n // + 1 byte of pushdata at the beggining = 2 hex chars\r\n // = 18 chars\r\n return prependPaymentIdWithPushdata(hexString);\r\n}\r\n\r\nfunction getDataPushdata(data: string, disablePaymentId = false): string {\r\n const bytesQuantity = new Blob([data]).size;\r\n // If paymentId is expected, limit is 8 bytes smaller\r\n const bytesLimit = USER_DATA_BYTES_LIMIT - (disablePaymentId ? 0 : 8);\r\n if (bytesQuantity > bytesLimit) {\r\n throw new Error(\r\n `Maximum ${bytesLimit} byte size exceeded for user data: ${bytesQuantity}`,\r\n );\r\n }\r\n const rawPushdata = bytesQuantity.toString(16).padStart(2, '0');\r\n if (bytesQuantity > SINGLE_PUSHDATA_BYTE_LIMIT) {\r\n return '4c' + rawPushdata;\r\n }\r\n return rawPushdata;\r\n}\r\n\r\n// Example:\r\n// If the user wants to send \"hello world\" in the OP_RETURN, the\r\n// function below constructs it in the following way:\r\n//\r\n// `04` - Pushdata of the Protocol Identifier, `50415900`\r\n// `50415900` - PayButton protocol identifier, ascii \"PAY\"\r\n// `00` - Version 0, pushed as `OP_0`\r\n// `16` - pushdata for the data payload, signifying this tx has 22 bytes of data\r\n// `68656c6c6f20776f726c64` - data payload, 'hello world' as ASCII encoded to hex\r\n// `08` - pushdata for the optional paymentId (paymentId), signifying this tx has 8 bytes of paymentId data\r\n// `0102030405060708` - The 8-byte paymentId (paymentId)\r\n//\r\n// Result: 0450415900001668656c6c6f20776f726c64080102030405060708\r\n\r\nexport interface EncodeOpReturnParams {\r\n opReturn?: string;\r\n disablePaymentId: boolean;\r\n paymentId?: string;\r\n}\r\n\r\n// specs defined at:\r\n// https://github.com/Bitcoin-ABC/bitcoin-abc/blob/master/doc/standards/paybutton.md\r\nexport function encodeOpReturnProps({\r\n opReturn,\r\n disablePaymentId,\r\n paymentId\r\n}: EncodeOpReturnParams): string {\r\n if (opReturn === undefined) {\r\n opReturn = '';\r\n }\r\n\r\n const dataPushdata = getDataPushdata(opReturn, disablePaymentId);\r\n if (paymentId === undefined || disablePaymentId) {\r\n paymentId = ''\r\n }\r\n const pushDataPrefixedPaymentId = prependPaymentIdWithPushdata(paymentId ?? '');\r\n return (\r\n OP_RETURN_PREFIX_PUSHDATA +\r\n OP_RETURN_PREFIX +\r\n VERSION +\r\n dataPushdata +\r\n stringToHex(opReturn) +\r\n pushDataPrefixedPaymentId\r\n );\r\n}\r\n\r\nexport const exportedForTesting = {\r\n prependPaymentIdWithPushdata,\r\n generatePaymentId,\r\n generatePushdataPrefixedPaymentId,\r\n stringToHex,\r\n getDataPushdata,\r\n};\r\n","import { CryptoCurrency } from \"./types\";\r\n\r\nconst DEFAULT = 3\r\nconst MAX = 4\r\n\r\n\r\nexport const getNSatoshis = (amount: number, randomSatoshis: boolean | number, satsPrecision: number): number => {\r\n const amountDigits = amount.toFixed(satsPrecision).toString().replace('.', '').length;\r\n if (randomSatoshis === true) {\r\n return Math.min(DEFAULT, amountDigits)\r\n } else if (randomSatoshis === false) {\r\n throw new Error(\"Trying to randomize satoshis when not allowed.\")\r\n }\r\n if (randomSatoshis > MAX) {\r\n randomSatoshis = MAX\r\n }\r\n return Math.min(randomSatoshis, amountDigits)\r\n}\r\n\r\nexport const randomizeSatoshis = (amount: number, addressType: CryptoCurrency, randomSatoshis: boolean | number): number => {\r\n if (amount === 0) {\r\n return 0;\r\n }\r\n let nSatoshis: number\r\n let random: number\r\n let randomizedAmount: number\r\n let ret: number\r\n switch (addressType) {\r\n case 'BCH':\r\n nSatoshis = getNSatoshis(amount, randomSatoshis, 8)\r\n random = Math.floor(Math.random() * 10 ** nSatoshis) * 1e-8\r\n\r\n randomizedAmount =\r\n Math.max(0, +amount.toFixed(nSatoshis)) + // zero out the least-significant digits\r\n random\r\n ret = +randomizedAmount.toFixed(8);\r\n break\r\n case 'XEC':\r\n nSatoshis = getNSatoshis(amount, randomSatoshis, 2)\r\n random = Math.floor(Math.random() * 10 ** nSatoshis) * 1e-2\r\n\r\n const multiplier = 10 ** (nSatoshis - 2)\r\n randomizedAmount = Math.max(0, +(Math.floor(amount / multiplier) * multiplier)) + // zero out the least-significant digits\r\n random\r\n ret = +randomizedAmount.toFixed(2);\r\n break\r\n default:\r\n throw new Error(`Invalid currency: ${addressType}`)\r\n }\r\n return ret\r\n};\r\n\r\nexport default randomizeSatoshis;\r\n","import BigNumber from 'bignumber.js';\r\n\r\nexport const zero = new BigNumber(0);\r\n\r\nexport const resolveNumber = (value: BigNumber.Value) => {\r\n return new BigNumber(value);\r\n};\r\n\r\nexport const isGreaterThanZero = (value: BigNumber.Value) => {\r\n return zero.isLessThan(value)\r\n}\r\n","import { DECIMALS } from './constants';\r\nimport { isCrypto } from './currency';\r\nimport { formatBCH, formatPrice, formatXEC } from './format';\r\nimport { resolveNumber } from './number';\r\nimport randomizeSatoshis from './randomizeSats';\r\nimport { Currency, CurrencyObject } from './types';\r\n\r\nexport const getCurrencyObject = (\r\n amount: number,\r\n currencyType: Currency,\r\n randomSatoshis: boolean | number | undefined,\r\n): CurrencyObject => {\r\n let string = '';\r\n let float = 0;\r\n\r\n if (isCrypto(currencyType)) {\r\n let newAmount = randomSatoshis ? randomizeSatoshis(amount, currencyType, randomSatoshis) : amount;\r\n const decimals = DECIMALS[currencyType]\r\n const primaryUnit = resolveNumber(`${newAmount}`);\r\n\r\n if (primaryUnit?.c !== null) {\r\n float = parseFloat(resolveNumber(primaryUnit).toFixed(decimals));\r\n string = resolveNumber(`${primaryUnit}`).toFixed(decimals);\r\n\r\n if (currencyType === 'BCH') {\r\n string = formatBCH(string);\r\n } else if (currencyType === 'XEC') {\r\n string = formatXEC(string);\r\n }\r\n }\r\n } else {\r\n float = amount;\r\n string = formatPrice(amount, currencyType, DECIMALS.FIAT)\r\n }\r\n\r\n return {\r\n float,\r\n string,\r\n currency: currencyType,\r\n };\r\n};\r\n\r\nexport default {\r\n getCurrencyObject,\r\n};\r\n","import { AltpaymentClient } from \".\";\r\n\r\nexport const SIDESHIFT_BASE_URL = 'https://sideshift.ai/api/v2/'\r\n\r\ninterface SideshiftTokenDetails {\r\n [network: string]: {\r\n contractAddress: string;\r\n decimals: number;\r\n }\r\n}\r\n\r\nexport interface SideshiftCoin {\r\n networks: string[];\r\n coin: string;\r\n name: string;\r\n hasMemo: boolean;\r\n fixedOnly: string[] | boolean;\r\n variableOnly: string[] | boolean;\r\n tokenDetails: SideshiftTokenDetails;\r\n depositOffline?: string[] | boolean;\r\n settleOffline?: string[] | boolean;\r\n}\r\n\r\n\r\nexport interface SideshiftQuote {\r\n id: string;\r\n createdAt: string;\r\n depositCoin: string;\r\n settleCoin: string;\r\n depositNetwork: string;\r\n settleNetwork: string;\r\n expiresAt: string;\r\n depositAmount: string;\r\n settleAmount: string;\r\n rate: string;\r\n affiliateId: string;\r\n}\r\n\r\n\r\nexport interface SideshiftPair {\r\n min: string;\r\n max: string;\r\n rate: string;\r\n depositCoin: string;\r\n settleCoin: string;\r\n depositNetwork: string;\r\n settleNetwork: string;\r\n}\r\n\r\nexport interface SideshiftShift {\r\n id: string;\r\n createdAt: string;\r\n depositCoin: string;\r\n settleCoin: string;\r\n depositNetwork: string;\r\n settleNetwork: string;\r\n depositAddress: string;\r\n settleAddress: string;\r\n depositMin: string;\r\n depositMax: string;\r\n averageShiftSeconds: string;\r\n depositAmount: string;\r\n expiresAt: string;\r\n quoteId: string;\r\n rate: string;\r\n settleAmount: string;\r\n status: string;\r\n type: string;\r\n}\r\n\r\ntype ErrorType = 'quote-error' | 'shift-error'\r\nexport interface SideshiftError {\r\n errorType: ErrorType\r\n errorMessage: string\r\n}\r\n\r\nexport class SideshiftClient implements AltpaymentClient {\r\n public async getPaymentStatus (shiftId: string): Promise<SideshiftShift> {\r\n const res = await fetch(`${SIDESHIFT_BASE_URL}/shifts/${shiftId}?t=${(new Date()).getTime()}`);\r\n return (await res.json()) as SideshiftShift;\r\n }\r\n}\r\n","import React, { useEffect, useState, CSSProperties } from 'react';\r\nimport { isPropsTrue } from '../../util';\r\n\r\nexport interface BarChartProps {\r\n value: number;\r\n color: string;\r\n disabled: boolean;\r\n}\r\n\r\nexport const BarChart = (props: BarChartProps): React.ReactElement => {\r\n const { value, color, disabled } = props;\r\n const [barWidth, setBarWidth] = useState(0);\r\n\r\n\r\n const blurCSS = isPropsTrue(disabled) ? { filter: 'blur(5px)' } : {};\r\n\r\n const containerStyle: CSSProperties = {\r\n width: '100%',\r\n marginBottom: '20px',\r\n };\r\n\r\n const barHolder: CSSProperties = {\r\n height: '8px',\r\n borderRadius: '20px',\r\n backgroundColor: '#dddddd',\r\n position: 'relative',\r\n } as React.CSSProperties;\r\n\r\n const bar: CSSProperties = {\r\n left: '0',\r\n top: '0',\r\n bottom: '0',\r\n height: '8px',\r\n borderRadius: '20px',\r\n backgroundColor: `${color}`,\r\n transition: 'width 0.8s ease-out',\r\n position: 'absolute',\r\n };\r\n\r\n useEffect(() => {\r\n setTimeout(() => {\r\n setBarWidth(value > 100 ? 100 : Math.round(value));\r\n }, 800);\r\n }, [value]);\r\n\r\n return (\r\n <div style={containerStyle}>\r\n <div style={barHolder}>\r\n <div style={{ ...bar, width: `${barWidth}%`, ...blurCSS}} />\r\n </div>\r\n </div>\r\n );\r\n};\r\n\r\nBarChart.defaultProps = {\r\n value: 34,\r\n color: '#4bc846',\r\n};\r\n\r\nexport default BarChart;\r\n","export const sideShiftLogo = 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAABYAAAADACAYAAAC9McflAAAACXBIWXMAAAsTAAALEwEAmpwYAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAABs7SURBVHgB7d3blRvHobbhz/p1b2bgdgTmjmBDEZiOYOAIREVAOALRERCOQFYEHEcgKoLpffffiTsCbdTCwByN5wAMGkBV9fOsVWt4sjwD9AH9olD9u/CYYTNebcbr21//4fb3r25/nzu/f8j4wNf/2YzPm/HpzlcAAAAAgJP4XShe344/bcYiX+LvOZQIPG7Gv25/vYvDAAAAAABHmWsAXmQbfP98+/VcsXdf19mG4B8jCAMAAAAAPKkE3uVmfNiMXzbj18bGx9vvfwgAAAAAAP+OviWethh9xWAAAAAAgHsWm/F9+oq+z8VgAAAAAIBuldm+b7MNoi2E26nHTbbRewgAAAAAQCdK+H2Xecz23Xd8iBAMAAAAADRM+BWCAQAAAIDOCL9CMAAAAADQoW8j/B4zrBEMAAAAAFRnkfne3G3qcbMZywAAAAAAXFhZ7qHMWm0lrrYWgocAAAAAAFzAIttI2UJMbXm8CwAAAADAmZj1e/5xE7OBAQAAAIATex2zfi81ys313gYAAAAA4AS+TVvBtNfxIdtZ2AAAAAAARyuxsUTHFuLoXMZNLAkBAAAAABxp2Iyf0lYcncsoS0K8CQAAAADAC1jvt43xOgAAAAAAB7jKdoZpKxF0rmMZAAAAAIADuNmb+AsAAAAAdOhd2oqg4i8AAAAAwB7epa0IKv4CAAAAAOzhXdqKoOIvAAAAAMAe3qWtCCr+AgAAAADs4SptRVDxFwAAAABgD6/TVgQVfwEAAAAA9jBsxi9pK4SKvwAAAAAAzxg24yZthVDxFwAAAABgDx/TVggVfwEAAAAA9vAubYVQ8RcAAAAAYA/LtBVCxV8AAAAAgD0Mse6v+AsAAAAAdOlj2oqh4i8AAAAAMAtf5zjvNmMRavXXzViH2i2ynUnfguvNGNOeV5vxJvNznfM8X69vB9vH+zp9WaSdY1TrPm/GP9OGIe28BhzTz365zOHKNvU587bI4cexT7fj1IbM83rqXNtlef33KpzDmMOOtctwLuc6nvEyrRynWnqd+hzXrwca0tZMWDN/qdFV2tqubtLmi+ghbT3OrR0HVmn/sZpyXKUv67T1+Lc8btKGIe0t/3WVPrzkZ1+EdQ5/3FY5j2Xq339OMYacx8ckvxpnGR9zmFZ+rh7GKtTqXdralj6kD6u09bhPMr7Ky30MtTLztw1Xae95GrLd982kgMetI7jQr3L8/yHtzQpfp783ZwCAdpXXJau0ZZl+IvDsvDQAL+PjoLUSf9vQYvzdKR+VEIHhaSWQ+VgRvSnH/XL8b3XbXkcEBgAur+UesNyM70NzXhKAh2ynqVMf8bcN5cJ5nbaJwPC01kMZ3NfLNv0+9ksA4HJajr87b6MLNuclAbg8yUOojfjbhl047YEIDE8TgelFT9uy/RIAuJQe4u/OKiJwUw4NwEPcXKxG4m8begym5Wf6IcBjxCZa1+M2bL8EAM6tp/i7s4oI3IxDA7B1Puoj/rah59myi1gIHp6yi01DoD3l+N5jKBWBAYBz6WEZyMesIgI34ZAAvNiMN6Em4m8b5rBUwjIiMDxFBKZF5bje82s/+yUAcGo9LQP5mFVE4OodEoA9mXURf9swZD7r5C4jAsNThohNtKMcz5fpnwgMAJzKnO6bs4puWLV9A/DidlAH8bcNQ+Z3k7RlRGB4yhCxifrNJf7uDLFfAgDTmuNN01cRgau1bwD2BNZD/G3DkPleTC7jmAFPGSI2Ua+5xd+dIfZLAGAac4y/O6voAVXaJwAvYvZvLcTfNgxxEbmKgz48ZYjjBPUpN/tdZr6G2C8BgOMMm/FD5hl/d1bRA6qzTwC+CjUQf9swxMXjzioO+vCUIY4X1KMcr9+GIfZLAOBlhngdsbOK15ZV+fqZvx8y75kgtRB/2zBkuoP9P7I9YF7KkGnetVzdfv1bLmvcjD/mtG5yuL9sxqeczufU6zrbY1vLyguab3OcIdvjxjfZbqe9+DFe8LWkxN9VjleOOeW4NuZyVjl+8sKQPvdL6vTPbM+Jp7LIy+7PcOrXTWPq9ffNeB9O7dTb2DFeck33Xbb7c41qviboyZDpekC5fl7ncoZM0wPKp8t+ybZv1KQc49c5nTfZ/uyHGLN97Xkx5Rv+1bjoWIYWDNkGwCme8x9Sh7JuUTlYT/EzvUv/XvK4LNKHVQ7/2T+mD+tMs4/cpN6ZAusc/vN8CK14l2m24XK+eJ06fEy/++WczzXHWOfwx22VPizysu2mFx8z3+eel7vJ4dvNMszZkOl6wCp1WGSan6eMq8zLMoc/Rjc5seeWgHgTLsnM3zYMme6dvjIbtJZZkeV7Ke9ATfGO8SqWg6BPy0zzjvYQHxfj/MpxeZXjlfNEOV+c8hMNh5jq0xVD7JcAwNOGTDvzd5U6XGe6NrGO5WUv7qkAXOLvEC5F/G3DkGnj71TBdSq772kKq4jA9GmZaSPwnG8Ywfn0Gn+LKb+nIW7kAgA8bEif8XdnHRG4G08F4D+HSxF/2zCk7/i7M+Ws5FVEYPq0zDRrOA4RgTm9qeJvUVv83ZkyApelLeyXAMBdQ/q5B9BT1hGBu/BYAC4vcJfhEsTfNgyZR/zdWWfaCOzmUPRoqo+di02c0pTxt5wXaoy/O7sIPOZ49ksAYGfItPF3mbqts73R4RTKDdhquW/ErDwWgK39exnibxvKxV/5OOiQ442pP/7urDNdBC43mPTOH70x45DaTR1/16mfCAwATGnIvOLvTgm3f8vxyuuo8viJwGf2WAC2/MP5ib9tmPJgNaad+Luzjo9/wFNEYGo1x/i7M2b6CAwAzM+Q6eLvddr75P0qInCzzACuwxQXUp6z0ztF/B3TnnWmOejv/lsiML0pEbgsBzHmeCIwU/g2842/O2OmjcAfAgDMya4HDDlemSzyl7RpFRG4SQ8FYCHxvKa4kCqzesqSBN+HUxF/f2sVERieMmba2OT4zkuV4+v7TKMc99dp15jp9stlRGAAmIup429rnwS+bxURuDkPBWDLP5zPVPF3dfvrt3FzrVMRf//TKtNG4EWgL2PEJi6rxN91plGO96u0b4z9EgDY35SRsof4u7PKdBF4qnss8YSHAvAinMPU8ffun3n3ZFrl4k78fdgq00XgctC37dKbMWITl1E+0bXONHqJvztj7JcAwH6mnAxWln3oIf7urDJNDxgy3QxrHnE/AA/xgJ/DqeJvsXv3xHqR01nmeGP6i787q/j4BzxlzLSxCfYx1ZJevcXfnTHT7peWaQGA/gwxGew5q834R443xITUk7ofgIWX0ztl/N0ZYjZKTcb0e7DfWUUEhqeM6f84QH96jb87Y6abiVOW4HoXAIDfGtP/dcAy00RgTuh+AF6EUzpH/N0pM3+sB3x5Y+YTfVaZLgJDj8aIwLSj9/i7M+VafH8MAMAXY+bz+n8ZEbhq9wPwf4dTOWf8vfvvh3ApY+YXe1Y5/qBf9pVPgT6N6W/tL/ozl/i7M0UELue+ZQAAtsbMrwcsIwJXyxIQ53GJ+FuUmZSWgriMchFZIs+Y+Vnm5Qf9KfYVqF1Pd/+lP3OLvzvH7Jflf7sMAMDWmPl+8q98Et2ErgrdDcDi72lcKv7uLGIpiEso8XfOB71lDo/A30X8ZT7K8eGvgbr8mHnG352yX3532P/k3+EYAGBnrpPBivJmuskuFbobgIcwtUvH37v/jSGc0xiW2T8Clxln7wPz4kURtfklrLP/mzNm8wMAD5n7a4PP8RhU524AXoQp1RJ/C0tBcCnLPD8Teq4fNwagTus8H4HHWM8bAIBG3A3AfwhTqSn+7iwi8nMZZXbUYxFY/AWgRus8HoHHzHddPwAAGmQJiOnVGH93zALmEnZrAN2PwOIvADVbZ3uuumuM+AsAQGME4GnVHH+LIW4Ix2Xcj8DiLwAtWOVLBB4j/gIA0KBdAH51O3i52uPv3f8PzzWXUCJwWS/x7xF/AWjHajO+i/gLAECjdgF4CMdoJf4WJf6aBcyljLH9AdCe9xF/AQBo1N0ZwLxMS/F359t4zgEAAACgewLwcVqMv4VZwAAAAAAwAwLwy7Uaf3fMAgYAAACAzlkD+GVaj79Fib/LAAAAAADd+iocqof4u3MVAAAAAKBbAvBheoq/xevNWAQAAAAA6JIAvL/e4u/Ou3AK1lcGoDXOXQAA0CEBeD+9xt9iERd8p/DTZnyI9bUBaMebzbiJewQAAEBXBODn9Rx/d5bhFJbZXkgLwQC0Ysj2vFXeyFwEAABongD8tDnE3+LP4ZSW2Ybgsi0MAYD6lfsEfLwdiwAAAM0SgB83l/hbLCJMnsMq2wtpIRiAViyyPXf5NAsAADRqF4A/h7vmFH93luEchvw2BANAC5axrBEAADRJAP5Pc4y/xX+Hcxqy3UbcbAeAliwjBAMAQFME4N+aa/wtFpvxKpzbkO1FtBAMQEuWEYIBAKAJX99+HcOc4+/Omxz/GPAyQ7YX0WUb+ttmXKc+n+PNImA/5Q3FIe0Zw6GWt2O9GX9PneeJMfM2RKT/fWB/ZXsZ0hav06EuQ6BSw2b8OuOxzPHe5bTf4znGh/CQZbaznFp4Ds+xjQzhIS95PBfpwyqH/+wfwyIv227ObZ16jkGnHDfpy5D5PHf7PLfL9KGVx7yHsUofFnnZz9+Lj6l7O5tqfAxTusnhz8Ey9GhI3ft+b2OZPixz+M9+kxPbLQExZr7M/P3iTXjIejP+mO22MmbeltkemMo2PwSAWo3ZHrPL+esfmbch2zcwP6afN94AAGBvX9359Zj5+S7i712tfmT3XNYRgndW2V5IvwsANRvzJQRfZ94W2Z67SgweAgAAM3E3AM9tzaCyzur7HKen+LtjFvDz1hGCiyHb7b/MCF4GgJqNm/HN7bjOvC3jBnYAAMzI3QD8c+ajxN9VjtNj/C3+FPa1zjYEl+1pzHwN2V5EC8EA9buOELyzjBAMAMAM3A3AnzIP4u/TFuFQq2wvpIVgIRigFdcRgneW2Z67vo8QDABAh+a2BrD4+7wh27WAOcwYIXhnyJcQvAgANbvO9txlffvkbaxvDwBAh+Y0A1j83d8QXmqMELwzZHsh/TG2KYDarWN9+2KI9e0BAOjM/RnAvd4ITvw9zOtwrDFfQvA/Mm+LWGMRoBXrCMHFEMsaAQDQia/u/f46/RF/DycAT2fM9sKxXEzPPQQvIwQDtGIdIbgYIgQDANC4+wH45/RF/H2Z34epjRGCd5YRggFasY4QXAyxvj0AAI3qeQaw+PtyZgCfzhgheGe5GT9lu58NAaBm6wjBxRDr2wMA0Jj7AbjcCK6HdYDF3+MM4dTGCMHFq2z3s3IhvQwAtVtHCC4W8WkWAAAa8fW935f4WyLwIu0Sf4/3KpzLmG34XKXO/W6xGVc5vSHbi+hiHaB1/0p7+3KvN8I9lfXteJP6XjeU7+fbnCfMLrM9V/4x9SqvjcfMW3ktswjs55+b8WPa4hwGdXm7Gf+befs+2lJVvn7gz8rJbpE2ib/TGeJi4ZzG1BlL1tnuD2WcIwQDfSgzI9dhDv6ZOr3PNs5aZmi7xNt15m0R2F+5L846AC9XutqYeSuvwQTginz1wJ9dp03i77TsqOyMsVwFAO1Zx3IVAADwYAAuS0CMaYv4Oz0BmPvGCMEAtGcdIRgAgBn76pE/b2nNI/H3NIbAw8YIwQC0Z70Z/xVr4gIAMDOPBeBa13O7T/yFyxmzDcHlYvo6AFC/cqOk1WZ8k+3rSAAA6N5jAfg69d9JVPyFOpRlY765HWMAoH5jtq8BfZoFAIDuffXE3/099RJ/oT7XscYiAG0ZY1kjAAA691QAXqdO4i/UbZ3thXQrS8kAwJgvyxoBAEBXngrAY+pb11P8hXb8bwCgLbUvgQYAAAf76pm/r2kZCPEXAAAAAOAAzwXg8hHuGmZCiL8AAAAAAAd6LgAXl54FLP4CAAAAALzAPgH4fS43C1j8vZwxAAAAAEDT9gnAJf5eYhaw+AsAAAAAcIR9AnBx7lnA4u/ljQEAAAAAmrZvAD7nLGDxtw413PyvdsNmvAkAtMW5CwAAZmTfAFycYxaw+FsPAfhprzbj42b8sBlXAYA2lNdJ5dz1IQAAwCwcEoBPPQtY/K3Hp/CUXfwdbn9f3hx5HQCo293XScuIwAAAMAuHBODiVLOAxd+6mP37uF38ff3MnwFATcqnVVb3/my5Gd8HAADo2qEBuITB7zIt8bc+P4fHlNlSD4VeERiAWpX4u37k795m+zoKAADo1KEBuFhvxnWmIf7WaQwPKfH3qRvniMAA1Kact9bP/JtVRGAAAOjWSwJwMcUsYPG3XtYA/k8l/i73+HclApeb6wzh9wHgksobkvuu87uKCFy8CgAAdOalAbgEwr/l5cTfugnAv1W2teUB/37Ib28SN0flMXsT4DFD3ICL0yrxt5yLDgmaq8w7Ag/ZvokLAABdeWkALsoN4cYcTvyt2xg3gbvrpdvakPlG4G9j/4SnDPEmEac15PD4u7PKPCPwEPslAACdOiYAl0j4lxxG/K2fG8B9cey2NmR+F5PlRkPvAzxmiMjEaQ15efzdWWVeEXiI/RIAgI4dE4CLslTAvusBi79tsPzDF4scb8h8Liqfuss8IDJxHotMs42tMo8IPMR+CQBA544NwEWZ7Xf9zL8Rf9txHXbKDPcpgviQ/i8uxV94WpmNKTJxDuvN+Gumscr2+N4r+yUAALMwRQAuyoXG+Mjfib9tuQ47ZZmTbyICP2fK+DsG+jNlZPIpDfaxzv6f0Nrnv9VjBLZfAgAwG1MF4DEPzzYRf9tyHe47RQQ+Zl3G2pS7zK8zjXIMuQ70ZReZXud4Y7bHI9hH+YTW3zKNdfqKwFPul+X1wVQzrgEA4CSmCsDFdX4720T8bc+P4SEi8MPKhfPHTKMcO9aBvpwi/n4O7G8VEfi+qeOv/RIAgOp9nWmV2SZDti+EVzmO+Ht+1+ExZZsuawJP8XHRXTht+aJx9zNMEbJLnHgf6M/3mTb+joHDrW6/TnFDt3Ks/jntLnkg/gIAMEtTzgDeeRvxt0VjrGH3nDHTRZgpA+q5TR1/V4H+fNiMZY43RvzleKtMMxN4yoB6CVO/KSP+AsDjVpvx6wvHIsCkThGAjyX+XsZ12MeYaSPwD2mL+AvPE3+p0SrzjsBT75fiLwAAzagtAIu/l/OPsK8x00WZRbYXpS0Ysg3W4i88rswwXOZ4Y8RfprfKPCOwN2UAAJi1mgKw+Hs5Y8wAPtSY6S4Cl6k/Ag+ZZv3jQvylV+U89jbHGyMycTqrTBeBy5uCQ+om/gIAMHu1BGDx97Kuw0uMmUcEHiL+wnOmOo+NEZk4vVWmicBDpjs/nIIZ+QAAkDoCsPh7eX8PLzVm2gj8feoyRPyF54i/tGiVaZZ/GlJnBDYjHwAAbl06AIu/l/fpdvByY6a7OCwXq+9ShyHTXdSXNxlWgf6Iv7RsmT4jsP0SAADuuGQAFn/rYPbvNMZMd1fwVS4fgYdMdzFf4sIUs7CgNiITPVimrwhsvwQAgHu+zmWIv3UYN+OfYSpjtheL5QL4VY6zyjTrFr7Uqxz/MxQlKixzeUO2z0ttyg2UpnjT4DHfpd59fLEZN2nbkOOV5/8v6S8yvcn2OeYwY7bnkXNb3n69ynGGzfgppz2u7fM9HGuM+Mv5lONlbUuAFac+R9vHALiUMkHt25zOS1rKkBOfey8RgMXfelznshdpPSrLaUwVgYe0rZb4uzOkPlOF9qf++zUbMm/l+FuOFz0uw3PqbZvpLTfjDzk+3Lf+3Pf6pgz1KvvLkPoMAYA+zfLce+4lIMTfukxxB3D+0y4Czzmul1mnywCP6Tn+0q4SPue8TdovAQDo0jkDsPhbl3XMbjmlOUfg8rP/NcBjRCZqNedt034JAEC3zhWAxd/6mP17enMMoWY/w/NEJmo2xxAq/gIA0LVzBGDxtz7rmP17LmUphLlEYPEXnleOByITtZtbEC03zLRfAgDQrVMHYPG3Tmb/ntc6/Udg8ReeV44D60AbdhF4TN/slwAAdO+UAVj8rdM6Zv9ewjr9RuAx2xsHib/wOJGJFvUege2XAADMwqkCsPhbL7N/L2ed/iLwmHnMEINjiEy0bEyfx3n7JQAAs3GKACz+1qvE3zFc0jr9RPgx4i88R2SiB2P6Ot6X8/A6AAAwE1MH4KuIv7Ua47mpxSrtR+Ax4i88R2SiJ2P6OO6X/XIVAACYkSkDcIm/61ArSz/UZZV2n5Mx4i88R2SiR2PaPv7bLwEAmKWpArD4W7d1PD81WqW9CDxG/IXniEz0bEyb5wH7JQAAs/V1jif+1m2M2b81W2V7l/U/pQ2triNdHuN15mfMeXyK88DOz5vxPn253oxfwzl8ThvGbCPwu7Shp/1yncO1sl2d0nUOP459ynmMmec59Fzb5Y85/PXQuZ576lW2m9/nMGO475hrhFrOXS+9jnTurXs/cv36AiX+/mpUPZYBAAAAADjQVdoKoXMcHwIAAAAAcKCrtBVC5zhuNmMIAAAAAMABrtJWCJ3rGAIAAAAAcICrtBVB5zpWAQAAAAA4wFXaiqBzHb3dfR4AAAAAOLGrtBVB5zpuNuNVAAAAAAD2dJW2Iuic4+8QAAAAAIA9XaWtCDrX8UvEXwAAAADgAFdpK4LOebwOAAAAAMCertJWAJ3zWAYAAAAAYE9XaSuAir8AAAAAAHu4SlsBVPwFAAAAANjDVdoKoOIvAAAAAMAertJWAJ3r+CXiLwAAAABwgKu0FUHnHH9fBwAAAABgT19txh9D7cbN+K/N+BQAAAAAgD39v8243ozfbcYi1Oh6M77ZjP8fAAAAAIAXKssL3KStZRF6H+8DAAAAADCRYTN+SluRtMfhZm8AAAAAwMms0lYw7WmUAD8EAAAAAOCELAlx/mHJBwAAAADgbF5lGyVbiqgtjpu4CR8AAAAAcCGLmA18qrHKNrQDAAAAAFzUKm3F1ZrHx1jrFwAAAACozLAZ67QVW2saN7HcAwAAAABQuWEzfkhb8fWS45dY7gEAAAAAaMwi2+UMWgmxwi8AAAAAwIEWsTSE8AsAAAAAdG3INgTfpK1gO9X4GGv8AgAAAACdKzNfl5nH8hBltu/7CL8AAAAAwAwN2S6HcJO2wu5z0fdDRF8AAAAAgH97vRlv0+bM4Lszfa3tCwAAAABU7Xe5rBJRF5vxZjP+lG0crsnnzbjejH/dfv0UAAAAAIBGXDoA31eCcInAi2yD8JDzReESe0vg/fn26/VmjAEAAAAAaFRtAfgxJQK/uvP1D9nG4Tzw9b7Pt6MY8yXq/s/trz/dfv0cAAAAAICO/B/Aac9sk4ABJgAAAABJRU5ErkJggg=='\r\nexport const copyIcon = 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAGQAAABuCAMAAADmp0YAAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAyRpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMy1jMDExIDY2LjE0NTY2MSwgMjAxMi8wMi8wNi0xNDo1NjoyNyAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvIiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RSZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENTNiAoTWFjaW50b3NoKSIgeG1wTU06SW5zdGFuY2VJRD0ieG1wLmlpZDpDQTk0NEI3OThFMzIxMUVGQkNERDhEQjQ1RTlGOTk2OCIgeG1wTU06RG9jdW1lbnRJRD0ieG1wLmRpZDpDQTk0NEI3QThFMzIxMUVGQkNERDhEQjQ1RTlGOTk2OCI+IDx4bXBNTTpEZXJpdmVkRnJvbSBzdFJlZjppbnN0YW5jZUlEPSJ4bXAuaWlkOkNBOTQ0Qjc3OEUzMjExRUZCQ0REOERCNDVFOUY5OTY4IiBzdFJlZjpkb2N1bWVudElEPSJ4bXAuZGlkOkNBOTQ0Qjc4OEUzMjExRUZCQ0REOERCNDVFOUY5OTY4Ii8+IDwvcmRmOkRlc2NyaXB0aW9uPiA8L3JkZjpSREY+IDwveDp4bXBtZXRhPiA8P3hwYWNrZXQgZW5kPSJyIj8+PQtV5wAAAYBQTFRFOTk5Tk5OTExMGhoaLCwsPz8/IiIiJycnBAQEICAgKioqFRUVHBwcCAgICwsLHx8fAQEB4ODgDQ0N8vLyMTExqKiovLy8FhYWMDAwzs7O5OTkHh4e+Pj4MzMz8fHx2dnZLy8v2NjY5+fn4uLiNDQ09/f3qqqqWlpaDg4Ozc3Nl5eXt7e3FxcX3t7ea2tr6urq6+vrZmZm9fX129vblpaWvb29DAwMw8PD7Ozsra2twsLC6enpPT09goKC+vr67u7uv7+/Nzc3WVlZmJiYioqKiYmJaGhosrKy0NDQ1dXVpKSkj4+PSEhI4eHhz8/PExMTo6Ojr6+vdnZ2QkJCnJyccXFxOjo65eXltbW1fn5+RkZGn5+fi4uLjIyM5ubmsLCw8/Pz9PT0NTU16Ojo2traKSkp/f39kJCQ/Pz8xsbGXl5ebm5uxcXFbGxsgYGBoKCgoaGhnZ2dmZmZjY2NJCQkiIiIQEBAW1tbaWlpYGBgYWFhXFxcXV1dV1dXAAAA////NCYxYAAAAIB0Uk5T/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////wA4BUtnAAACdElEQVR42uzaZ1PbQBAGYDkY48SWhS2FCFeMTQgtgdA7CYH03hPSe+896P56GMB3irwnsG7lT/t+9Gn2mbM0exrdaQxO+UXENnJG0OSMfefev6oV00CiM+JgRJvxQcYcrByWIT2vHbxUZ2Gky8FMG4h8dnDzA0AexZERZ6Ye+YttOMk65IiDnwde5FoISK8X+SXGRm51KGRe54VsL3KDD40xtdzllb56EZsPLSoi4u4aciSriGR5pZwXsfhQWhFJy2dCSENIgQ/NhodU+dBUCMiTM6vfC1YhxYeij63dxbZae++Vd4GUfuqKDSoysBPyBqMPHjvqi1zF6baxbh9kBKunt+SlyCe8lUNbkCAVzPXpmwQ5jv0CBCBF3KX2FIj0uy/ZfB1qb7Duf9e/AxHxb8XPlrPpjZx/ejrdSCpDlzK8iAUic56X40AZF0/xcwgRvf2gQjccrBXJPIQQsahPKyCxWpGJov9M9isgBp+JSQghhBBCCCGEEEIIIYQQQgghhBBCCCFNRirNQIbDQw7xnybFN3xsZOKmuZWONrETg420Z7bj+la8BxuB0o+E7PUx4mYTZrLMcJB8Qm5EGRLSI0fi97EQlpMZ+hJDQ2Q3vjrK8BD4xusrW6PhIRfvfKmdG8BGUpMXOjfS11dybW26tjZU9k9i9Q3SFU0cTzqJMpMihGgcmQ9uDPEDSIkFCFkXz8KHKTNYBlqAjTM3csL9yGWCxVXiN4iUcDczL4MIm8M0Bl/CyCgmcpvBCLuOZ6RMGcKiaMhbJkWGkc4LJsaZHGHsD/4RiXqETSdVCf1Knu2AsPzHdds4EDDJZ61r3T5d558AAwDxw6DYwVV5JQAAAABJRU5ErkJggg=='","import React, { useEffect, useState } from 'react';\r\nimport {\r\n TextField,\r\n Grid,\r\n Select,\r\n MenuItem,\r\n makeStyles,\r\n InputLabel,\r\n FormControl,\r\n Typography\r\n} from '@material-ui/core';\r\nimport {\r\n resolveNumber,\r\n CryptoCurrency,\r\n DECIMALS\r\n} from '../../util';\r\nimport { Button, animation } from '../Button/Button';\r\nimport { Socket } from 'socket.io-client';\r\nimport { AltpaymentCoin, AltpaymentError, AltpaymentPair, AltpaymentShift } from '../../altpayment';\r\nimport { sideShiftLogo, copyIcon } from './SideShiftLogo'\r\n\r\ninterface AltpaymentProps {\r\n altpaymentSocket?: Socket;\r\n setUseAltpayment: Function;\r\n altpaymentShift?: AltpaymentShift;\r\n setAltpaymentShift: Function;\r\n shiftCompleted: boolean;\r\n setShiftCompleted: Function;\r\n altpaymentError?: AltpaymentError;\r\n setAltpaymentError: Function;\r\n coins: AltpaymentCoin[];\r\n loadingPair: boolean;\r\n setLoadingPair: Function;\r\n loadingShift: boolean;\r\n setLoadingShift: Function;\r\n coinPair?: AltpaymentPair;\r\n setCoinPair: Function;\r\n altpaymentEditable: boolean;\r\n animation?: animation;\r\n addressType: CryptoCurrency;\r\n to: string;\r\n thisAmount?: string | number | null\r\n updateAmount: Function;\r\n}\r\n\r\nexport const AltpaymentWidget: React.FunctionComponent<AltpaymentProps> = props => {\r\n\r\n const {\r\n altpaymentSocket,\r\n setUseAltpayment,\r\n altpaymentShift,\r\n setAltpaymentShift,\r\n shiftCompleted,\r\n setShiftCompleted,\r\n altpaymentError,\r\n setAltpaymentError,\r\n coins,\r\n loadingPair,\r\n loadingShift,\r\n coinPair,\r\n setCoinPair,\r\n altpaymentEditable,\r\n animation,\r\n addressType,\r\n thisAmount,\r\n updateAmount,\r\n setLoadingPair,\r\n setLoadingShift,\r\n to\r\n } = Object.assign({}, props);\r\n\r\n const [pairAmountMaxLength, setPairAmountMaxLength] = useState<number | undefined>(undefined);\r\n const [isAboveMinimumAltpaymentAmount, setIsAboveMinimumAltpaymentAmount] = useState<boolean | null>(null);\r\n const [isBelowMaximumAltpaymentAmount, setIsBelowMaximumAltpaymentAmount] = useState<boolean | null>(null);\r\n const [selectedCoin, setSelectedCoin] = useState<AltpaymentCoin|undefined>();\r\n const [selectedCoinNetwork, setSelectedCoinNetwork] = useState<string | undefined>(undefined);\r\n const [pairAmountFixedDecimals, setPairAmountFixedDecimals] = useState<string | undefined>(undefined);\r\n const [pairAmount, setPairAmount] = useState<string | undefined>(undefined);\r\n\r\n useEffect(() => {\r\n if (pairAmount && coinPair) {\r\n setIsBelowMaximumAltpaymentAmount(+pairAmount <= +coinPair.max)\r\n setIsAboveMinimumAltpaymentAmount(+pairAmount >= +coinPair.min)\r\n } else {\r\n setIsBelowMaximumAltpaymentAmount(true)\r\n setIsAboveMinimumAltpaymentAmount(true)\r\n }\r\n }, [pairAmount, coinPair])\r\n\r\n useEffect(() => {\r\n if (selectedCoin?.networks.length === 1) {\r\n setSelectedCoinNetwork(selectedCoin.networks[0])\r\n }\r\n }, [selectedCoin])\r\n\r\n useEffect(() => {\r\n if (coinPair && thisAmount && selectedCoin && selectedCoinNetwork) {\r\n const bigNumber = resolveNumber(+thisAmount / +coinPair.rate)\r\n const tokenDetails = selectedCoin.tokenDetails\r\n let decimals: number\r\n if (tokenDetails !== undefined) {\r\n decimals = tokenDetails[selectedCoinNetwork].decimals\r\n } else {\r\n decimals = coinPair.min.split('.')[1].length\r\n }\r\n\r\n const amountString = bigNumber.toFixed(decimals)\r\n setPairAmountFixedDecimals(amountString)\r\n\r\n // Besides decimals, account for the non-decimal part of the bigNumber\r\n // plus the '.' character.\r\n const floorAmount = pairAmount ? Math.floor(+pairAmount) : 1\r\n const nonDecimalCharCount = 1 + Math.ceil(Math.log10(floorAmount + 1))\r\n setPairAmountMaxLength(nonDecimalCharCount + decimals)\r\n }\r\n }, [coinPair, selectedCoin, thisAmount, pairAmount, selectedCoinNetwork])\r\n\r\n const requestPairRate = (): void => {\r\n if (selectedCoin !== undefined) {\r\n const from = `${selectedCoin.coin}-${selectedCoin?.networks[0]}`\r\n const to = addressType === 'XEC' ? `ecash-mainnet` : `bitcoincash-mainnet`\r\n if (altpaymentSocket !== undefined) {\r\n altpaymentSocket.emit('get-altpayment-rate', {from, to})\r\n }\r\n }\r\n }\r\n\r\n const handleCoinChange = async (e: React.ChangeEvent<{ name?: string; value: unknown }>) => {\r\n const coinName = e.target.value as string\r\n const selectedCoin = coins.find(c => c.coin === coinName)\r\n setSelectedCoinNetwork(selectedCoin?.networks[0])\r\n setSelectedCoin(selectedCoin)\r\n }\r\n\r\n const handleGetRateButtonClick = () => {\r\n setLoadingPair(true)\r\n requestPairRate()\r\n }\r\n\r\n const handleNetworkChange = async (e: React.ChangeEvent<{ name?: string; value: unknown }>) => {\r\n const networkName = e.target.value as string\r\n setSelectedCoinNetwork(networkName)\r\n }\r\n\r\n const handlePairAmountChange = (e: React.ChangeEvent<HTMLInputElement>) => {\r\n let pairAmount = e.target.value;\r\n if (pairAmount === '') {\r\n pairAmount = '0';\r\n }\r\n setPairAmount(pairAmount)\r\n\r\n if (coinPair !== undefined) {\r\n const settleCoinAmount = +coinPair.rate * +pairAmount\r\n\r\n if(Object.keys(DECIMALS).includes(coinPair.settleCoin)){\r\n updateAmount(settleCoinAmount.toFixed(DECIMALS[coinPair.settleCoin]))\r\n }\r\n }\r\n };\r\n\r\n const handleCreateQuoteButtonClick = () => {\r\n if (altpaymentSocket !== undefined && selectedCoin !== undefined) {\r\n setLoadingShift(true)\r\n altpaymentSocket.emit('create-altpayment-quote', {\r\n depositAmount: pairAmountFixedDecimals,\r\n settleCoin: addressType,\r\n depositCoin: selectedCoin?.coin,\r\n depositNetwork: selectedCoinNetwork,\r\n settleAddress: to\r\n });\r\n }\r\n }\r\n\r\n const resetTrade = () => {\r\n setCoinPair(undefined)\r\n setAltpaymentError(undefined)\r\n setAltpaymentShift(undefined)\r\n setPairAmount(undefined)\r\n setShiftCompleted(false)\r\n }\r\n\r\n const copyToClipboard = (elementId: string) => {\r\n const contentElement = document.getElementById(elementId);\r\n const copiedMessage = document.createElement(\"div\");\r\n copiedMessage.textContent = \"Copied!\";\r\n copiedMessage.style.position = \"absolute\";\r\n copiedMessage.style.width = \"calc(100% - 10px)\";\r\n copiedMessage.style.height = \"calc(100% - 20px)\";\r\n copiedMessage.style.alignItems = \"center\";\r\n copiedMessage.style.top = \"0\";\r\n copiedMessage.style.left = \"0\";\r\n copiedMessage.style.backgroundColor = \"#fff\";\r\n copiedMessage.style.borderRadius = \"5px\";\r\n copiedMessage.style.padding = \"10px 0 10px 10px\";\r\n copiedMessage.style.zIndex = \"10\";\r\n copiedMessage.style.display = \"none\";\r\n\r\n if (contentElement) {\r\n const content = contentElement.textContent || \"\";\r\n navigator.clipboard.writeText(content);\r\n contentElement.appendChild(copiedMessage);\r\n copiedMessage.style.display = \"flex\";\r\n\r\n setTimeout(() => {\r\n copiedMessage.style.display = \"none\";\r\n if (copiedMessage.parentElement === contentElement) {\r\n contentElement.removeChild(copiedMessage);\r\n }\r\n }, 2000);\r\n }\r\n };\r\n\r\n const useStyles = makeStyles({\r\n select_box: {\r\n minWidth: '220px'\r\n },\r\n option_outer_ctn: {\r\n display: 'flex',\r\n alignItems: 'center'\r\n },\r\n option_ctn: {\r\n display: 'flex',\r\n flexDirection: 'column',\r\n margin: '5px 0'\r\n },\r\n list_icon: {\r\n width: '28px',\r\n height: '28px',\r\n marginRight: '10px'\r\n },\r\n coin: {\r\n fontWeight: 'bold',\r\n lineHeight: '1em'\r\n },\r\n coin_name: {\r\n fontSize: '14px'\r\n },\r\n spacer: {\r\n height: '20px'\r\n },\r\n sideshift_ctn: {\r\n alignItems: 'center',\r\n display: 'flex',\r\n flexDirection: 'column',\r\n height: 'calc(100% - 20px)',\r\n width: '100%',\r\n position: 'absolute',\r\n zIndex: 9,\r\n top: '0',\r\n left: '0',\r\n background: '#f5f5f7',\r\n paddingTop: '20px'\r\n },\r\n header: {\r\n marginBottom:'30px',\r\n display: 'flex',\r\n alignItems: 'center',\r\n flexDirection: 'column',\r\n color: 'rgb(35, 31, 32)',\r\n fontSize: '0.9rem',\r\n\r\n '& img': {\r\n width: '150px',\r\n marginTop: '10px'\r\n },\r\n },\r\n back_link: {\r\n fontSize: '14px',\r\n marginTop: '20px',\r\n cursor: 'pointer',\r\n border: '1px solid #000',\r\n opacity: '0.7',\r\n padding: '2px 20px',\r\n borderRadius: '3px',\r\n '&:hover': {\r\n opacity: '1'\r\n },\r\n },\r\n shift_ready: {\r\n width: '100%',\r\n display: 'flex',\r\n flexDirection: 'column',\r\n '& h4': {\r\n margin: '0',\r\n fontSize: '20px',\r\n borderBottom: '1px solid #000',\r\n paddingBottom: '10px',\r\n textAlign: 'center',\r\n },\r\n },\r\n copy_ctn: {\r\n display: 'flex',\r\n alignItems: 'center',\r\n '& > div': {\r\n position: 'relative'\r\n },\r\n },\r\n editAmount: {\r\n width: '100%',\r\n margin: '12px auto 10px',\r\n display: 'flex',\r\n alignItems: 'flex-end',\r\n '& > div': {\r\n width: '100%',\r\n },\r\n '& span': {\r\n marginLeft: '4px',\r\n fontSize: '16px',\r\n }\r\n },\r\n amount_error: {\r\n position: 'absolute',\r\n bottom: '10px',\r\n textAlign: 'center',\r\n background: '#00000014',\r\n padding: '10px',\r\n borderRadius: '5px'\r\n },\r\n error_msg: {\r\n textAlign: 'center',\r\n background: '#ee010119',\r\n padding: '10px',\r\n borderRadius: '5px',\r\n color: 'red'\r\n },\r\n shift_label: {\r\n fontSize: '14px',\r\n marginLeft: '5px',\r\n marginTop: '20px',\r\n marginBottom: '2px',\r\n fontWeight: 600\r\n },\r\n shift_input: {\r\n background: '#ffffff',\r\n padding: '10px',\r\n borderRadius: '5px',\r\n fontSize: '14px',\r\n border: '1px solid #b3b3b3',\r\n wordBreak: 'break-all',\r\n flexGrow: 1,\r\n position: 'relative',\r\n },\r\n copy_btn: {\r\n background: '#ffffff',\r\n padding: '10px',\r\n borderRadius: '5px',\r\n border: '1px solid #b3b3b3',\r\n marginLeft: '5px',\r\n display: 'flex',\r\n alignItems: 'center',\r\n cursor: 'pointer',\r\n alignSelf: 'stretch',\r\n transition: 'all ease-in-out 200ms',\r\n '&:hover': {\r\n background: '#f1f1f1'\r\n },\r\n '& img': {\r\n width: '15px',\r\n },\r\n },\r\n shift_complete: {\r\n display: 'flex',\r\n alignItems: 'center',\r\n height: '100%',\r\n flex: '1',\r\n width: '100%',\r\n fontSize: '18px'\r\n }\r\n });\r\n\r\n const classes = useStyles();\r\n\r\n const checkCoin = (coin:string) => {\r\n let coinString = coin.toLowerCase();\r\n if (coinString.includes('.')) {\r\n return 'btc';\r\n }\r\n if (coinString === 'bitcoin') {\r\n return 'harrypotterobamasonic10inu';\r\n }\r\n return coinString;\r\n }\r\n\r\n return (\r\n <Typography component=\"div\" className={classes.sideshift_ctn}>\r\n {altpaymentError ? (\r\n <>\r\n <p className={classes.error_msg}>Error: {altpaymentError.errorMessage}</p>\r\n <div className={classes.back_link} onClick={resetTrade}>Back</div>\r\n </>\r\n ) : (\r\n <>\r\n {\r\n altpaymentShift ? (\r\n shiftCompleted ? (\r\n <div className={classes.shift_complete}>Shift Completed!</div>\r\n ) : (\r\n <div className={classes.shift_ready}>\r\n <h4>Shift Ready!</h4>\r\n <span className={classes.shift_label}>Send</span>\r\n <div className={classes.copy_ctn}>\r\n <div className={classes.shift_input}>\r\n <span id=\"shift_amount\">{altpaymentShift.depositAmount}</span>{' '}{altpaymentShift.depositCoin}\r\n </div>\r\n <div className={classes.copy_btn} onClick={() => copyToClipboard('shift_amount')}>\r\n <img\r\n src={copyIcon}\r\n alt=\"Copy\"\r\n />\r\n </div>\r\n </div>\r\n <span className={classes.shift_label}>To</span>\r\n <div className={classes.copy_ctn}>\r\n <div id=\"to_address\" className={classes.shift_input}>\r\n {altpaymentShift.depositAddress}\r\n </div>\r\n <div className={classes.copy_btn} onClick={() => copyToClipboard('to_address')}>\r\n <img\r\n src={copyIcon}\r\n alt=\"Copy\"\r\n />\r\n </div>\r\n </div>\r\n <span className={classes.shift_label}>Network</span>\r\n <div className={classes.shift_input}>{selectedCoinNetwork}</div>\r\n <span className={classes.shift_label}>SideShift ID</span>\r\n <div className={classes.copy_ctn}>\r\n <div id=\"sideshift_id\" className={classes.shift_input}>\r\n {altpaymentShift.id}\r\n </div>\r\n <div className={classes.copy_btn} onClick={() => copyToClipboard('sideshift_id')}>\r\n <img\r\n src={copyIcon}\r\n alt=\"Copy\"\r\n />\r\n </div>\r\n </div>\r\n </div>\r\n )\r\n ) : loadingShift ? (\r\n <p>Loading Shift...</p>\r\n ) : coinPair ? (\r\n <>\r\n <p>\r\n {' '}\r\n 1 {selectedCoin?.name} ~={' '}\r\n {resolveNumber(coinPair.rate).toFixed(DECIMALS[coinPair.settleCoin])} {coinPair.settleCoin}{' '}\r\n </p>\r\n {altpaymentEditable ? (\r\n <Grid\r\n container\r\n spacing={2}\r\n alignItems=\"center\"\r\n justifyContent=\"center\"\r\n style={{ margin: '6px auto', width: '100%' }}\r\n >\r\n <Grid item>\r\n <TextField\r\n label=\"Amount\"\r\n value={pairAmount ?? 0}\r\n onChange={handlePairAmountChange}\r\n inputProps={{\r\n maxLength: pairAmountMaxLength,\r\n type: 'number',\r\n pattern: '[0-9]*',\r\n inputMode: 'numeric'\r\n }}\r\n />\r\n </Grid>\r\n </Grid>\r\n ) : (\r\n null\r\n )}\r\n <div></div>\r\n <div style={loadingPair ||\r\n selectedCoinNetwork === undefined ||\r\n (altpaymentEditable && !pairAmount) ||\r\n !isAboveMinimumAltpaymentAmount ||\r\n !isBelowMaximumAltpaymentAmount ? {opacity: '0.5', cursor: 'not-allowed'} : {}}>\r\n <Button\r\n text={`Send ${selectedCoin?.name}`}\r\n hoverText={`Send ${selectedCoin?.name}`}\r\n onClick={handleCreateQuoteButtonClick}\r\n disabled={\r\n loadingPair ||\r\n selectedCoinNetwork === undefined ||\r\n (altpaymentEditable && !pairAmount) ||\r\n !isAboveMinimumAltpaymentAmount ||\r\n !isBelowMaximumAltpaymentAmount\r\n }\r\n animation={animation}\r\n />\r\n </div>\r\n {!isAboveMinimumAltpaymentAmount && (\r\n <p className={classes.amount_error}>Amount is below minimum.</p>\r\n )}\r\n {!isBelowMaximumAltpaymentAmount && (\r\n <p className={classes.amount_error}>Amount is above maximum.</p>\r\n )}\r\n </>\r\n ) : (\r\n <>\r\n {coins.length === 0 && <div>Loading...</div>}\r\n {coins.length > 0 && (\r\n <>\r\n <div className={classes.header}>\r\n Swap coins with\r\n <a href=\"https://sideshift.ai\" target=\"_blank\">\r\n <img src={sideShiftLogo} alt='SideShift' />\r\n </a>\r\n </div>\r\n <FormControl>\r\n <InputLabel id=\"select-coin-label\">\r\n Select a coin\r\n </InputLabel>\r\n <Select\r\n labelId=\"select-coin-label\"\r\n className={classes.select_box}\r\n value={selectedCoin?.coin ?? null}\r\n onChange={e => {\r\n handleCoinChange(e);\r\n }}\r\n >\r\n {coins.map(coin => (\r\n <MenuItem key={coin.coin} value={coin.coin}>\r\n <div className={classes.option_outer_ctn}>\r\n <img\r\n className={classes.list_icon}\r\n src={`https://sideshift.ai/coin-icons/${checkCoin(\r\n coin.coin,\r\n )}.svg`}\r\n />\r\n <div className={classes.option_ctn}>\r\n <span className={classes.coin}>\r\n {coin.coin}\r\n </span>\r\n <span className={classes.coin_name}>\r\n {coin.name}\r\n </span>\r\n </div>\r\n </div>\r\n </MenuItem>\r\n ))}\r\n </Select>\r\n </FormControl>\r\n <div className={classes.spacer} />\r\n {selectedCoin && selectedCoin.networks.length > 1 && (\r\n <>\r\n {\r\n <FormControl>\r\n <InputLabel id=\"select-network-label\">\r\n Select a network\r\n </InputLabel>\r\n\r\n <Select\r\n labelId=\"select-network-label\"\r\n className={classes.select_box}\r\n value={selectedCoinNetwork ?? null}\r\n onChange={e => {\r\n handleNetworkChange(e);\r\n }}\r\n >\r\n {selectedCoin.networks.map(network => (\r\n <MenuItem key={network} value={network}>\r\n <div className={classes.option_outer_ctn}>\r\n <div className={classes.option_ctn}>\r\n <span className={classes.coin}>\r\n {network.charAt(0).toUpperCase() +\r\n network.slice(1)}\r\n </span>\r\n </div>\r\n </div>\r\n </MenuItem>\r\n ))}\r\n </Select>\r\n </FormControl>\r\n }\r\n </>\r\n )}\r\n </>\r\n )}\r\n <div className={classes.spacer} />\r\n {loadingPair ||\r\n selectedCoin === undefined ||\r\n selectedCoinNetwork === undefined ? null : (\r\n <Button\r\n text={'Send with SideShift'}\r\n hoverText={'Send with SideShift'}\r\n onClick={handleGetRateButtonClick}\r\n disabled={\r\n loadingPair ||\r\n selectedCoin === undefined ||\r\n selectedCoinNetwork === undefined\r\n }\r\n animation={animation}\r\n />\r\n )}\r\n <div className={classes.back_link} onClick={() => {setUseAltpayment(false)}}>Back</div>\r\n </>\r\n )\r\n // END: Altpayment region\r\n }\r\n {coinPair && !loadingShift && (\r\n <div className={classes.back_link} onClick={resetTrade}>Back</div>\r\n )}\r\n </>\r\n )}\r\n </Typography>\r\n );\r\n};\r\n\r\nexport default AltpaymentWidget;\r\n","import {\r\n Box,\r\n CircularProgress,\r\n Fade,\r\n Typography,\r\n makeStyles,\r\n TextField,\r\n} from '@material-ui/core';\r\nimport React, { useCallback, useEffect, useMemo, useState } from 'react';\r\nimport copy from 'copy-to-clipboard';\r\nimport QRCode, { BaseQRCodeProps } from 'qrcode.react';\r\nimport io, { Socket } from 'socket.io-client';\r\nimport config from '../../../../paybutton-config.json';\r\nimport { Theme, ThemeName, ThemeProvider, useTheme } from '../../themes';\r\nimport { Button, animation } from '../Button/Button';\r\nimport BarChart from '../BarChart/BarChart';\r\nimport {\r\n Currency,\r\n getAddressBalance,\r\n getAddressDetails,\r\n isFiat,\r\n Transaction,\r\n getCashtabProviderStatus,\r\n CryptoCurrency,\r\n DECIMALS,\r\n CurrencyObject,\r\n getCurrencyObject,\r\n formatPrice,\r\n txsListener,\r\n encodeOpReturnProps,\r\n isValidCashAddress,\r\n isValidXecAddress,\r\n getCurrencyTypeFromAddress,\r\n altpaymentListener,\r\n CURRENCY_PREFIXES_MAP,\r\n CRYPTO_CURRENCIES,\r\n isPropsTrue\r\n} from '../../util';\r\nimport AltpaymentWidget from './AltpaymentWidget';\r\nimport { AltpaymentPair, AltpaymentShift, AltpaymentError, AltpaymentCoin, MINIMUM_ALTPAYMENT_DOLLAR_AMOUNT } from '../../altpayment';\r\n\r\ntype QRCodeProps = BaseQRCodeProps & { renderAs: 'svg' };\r\n\r\nexport interface WidgetProps {\r\n to: string;\r\n amount?: number | null | string;\r\n setAmount?: Function;\r\n opReturn?: string;\r\n paymentId?: string;\r\n disablePaymentId?: boolean;\r\n text?: string;\r\n ButtonComponent?: React.ComponentType;\r\n success: boolean;\r\n successText?: string;\r\n theme?: ThemeName | Theme;\r\n foot?: React.ReactNode;\r\n disabled: boolean;\r\n goalAmount?: number | string | null;\r\n currency?: Currency;\r\n animation?: animation;\r\n currencyObject?: CurrencyObject | undefined;\r\n setCurrencyObject?: Function;\r\n randomSatoshis?: boolean | number;\r\n price?: number | undefined;\r\n usdPrice?: number | undefined;\r\n editable?: boolean;\r\n setNewTxs: Function;\r\n newTxs?: Transaction[];\r\n wsBaseUrl?: string;\r\n apiBaseUrl?: string;\r\n loading?: boolean;\r\n hoverText?: string;\r\n setAltpaymentShift: Function;\r\n altpaymentShift?: AltpaymentShift | undefined,\r\n useAltpayment: boolean\r\n setUseAltpayment: Function;\r\n shiftCompleted: boolean\r\n setShiftCompleted: Function;\r\n disableAltpayment?: boolean;\r\n contributionOffset?: number\r\n}\r\n\r\ninterface StyleProps {\r\n success: boolean;\r\n loading: boolean;\r\n theme: Theme;\r\n recentlyCopied: boolean\r\n copied: boolean\r\n}\r\n\r\nconst useStyles = makeStyles({\r\n root: {\r\n minWidth: '240px !important',\r\n background: '#f5f5f7 !important',\r\n position: 'relative',\r\n },\r\n qrCode: ({ success, loading, theme }: StyleProps) => ({\r\n background: '#fff !important',\r\n border: '1px solid #eee !important',\r\n borderRadius: '4px !important',\r\n outline: 'none !important',\r\n lineHeight: '0 !important',\r\n maxWidth: '28vh !important',\r\n maxHeight: '28vh !important',\r\n position: 'relative',\r\n padding: '1rem !important',\r\n cursor: 'pointer !important',\r\n userSelect: 'none',\r\n '&:active': {\r\n borderWidth: '2px !important',\r\n margin: '-1px !important',\r\n },\r\n '& path': {\r\n opacity: loading ? 0 : success ? 0.35 : 1,\r\n color: theme.palette.secondary,\r\n },\r\n '& image': {\r\n opacity: loading ? 0 : 1,\r\n },\r\n }),\r\n copyTextContainer: ({ loading }: StyleProps) => ({\r\n display: loading ? 'none' : 'block',\r\n background: '#ffffffcc !important',\r\n padding: '0 0.15rem 0.15rem 0 !important',\r\n }),\r\n copyText: ({ theme }: StyleProps) => ({\r\n lineHeight: '1.2em !important',\r\n fontSize: '0.7em !important',\r\n color: `${theme.palette.tertiary} !important`,\r\n textShadow:\r\n '#fff -2px 0 1px, #fff 0 -2px 1px, #fff 0 2px 1px, #fff 2px 0 1px !important',\r\n '&:disabled span': {\r\n filter: 'blur(2px)',\r\n color: 'rgba(0, 0, 0, 0.5)',\r\n },\r\n }),\r\n text: ({ theme }: StyleProps) => ({\r\n fontSize: '0.9rem !important',\r\n color: `${theme.palette.tertiary} !important`,\r\n }),\r\n spinner: ({ theme }: StyleProps) => ({\r\n color: `${theme.palette.primary} !important`,\r\n }),\r\n footer: () => ({\r\n fontSize: '0.6rem !important',\r\n color: '#a8a8a8 !important',\r\n fontWeight: 'normal',\r\n userSelect: 'none',\r\n }),\r\n sideShiftLink: ({ theme }: StyleProps) => ({\r\n fontSize: '14px',\r\n cursor: 'pointer',\r\n padding: '6px 12px',\r\n marginTop: '20px',\r\n background: '#e9e9e9',\r\n borderRadius: '5px',\r\n transition: 'all ease-in-out 200ms',\r\n opacity: 0,\r\n '&:hover': {\r\n background: `${theme.palette.primary}`,\r\n color: `${theme.palette.secondary}`,\r\n },\r\n }),\r\n animate_sideshift: ({ success }: StyleProps) => ({\r\n animation: success\r\n ? 'button-slide-out 0.4s ease-in-out forwards'\r\n : 'button-slide 0.6s ease-in-out forwards',\r\n animationDelay: success ? '0' : '0.5s',\r\n }),\r\n hide_sideshift: {\r\n display: 'none',\r\n },\r\n editAmount: {\r\n width: '100%',\r\n margin: '12px auto 10px',\r\n display: 'flex',\r\n alignItems: 'flex-end',\r\n '& > div': {\r\n width: '100%',\r\n },\r\n '& span': {\r\n marginLeft: '4px',\r\n fontSize: '16px',\r\n },\r\n },\r\n error: () => ({\r\n fontSize: '0.9rem !important',\r\n color: '#EB3B3B !important',\r\n }),\r\n '@global': {\r\n '@keyframes reveal-qr': {\r\n from: { clipPath: 'circle(0% at 50% 50%)', transform: 'rotate(-10deg)' },\r\n to: { clipPath: 'circle(100% at 50% 50%)', transform: 'rotate(0deg)' },\r\n },\r\n '@keyframes fade-scale': {\r\n from: {\r\n opacity: 0,\r\n transform: 'scale(0.3)',\r\n },\r\n '80%': {\r\n opacity: 1,\r\n transform: 'scale(1.3)',\r\n },\r\n to: {\r\n opacity: 1,\r\n transform: 'scale(1)',\r\n },\r\n },\r\n '@keyframes button-slide': {\r\n from: {\r\n opacity: 0,\r\n transform: 'translateY(20px)',\r\n },\r\n to: {\r\n opacity: 1,\r\n transform: 'translateY(0px)',\r\n },\r\n },\r\n '@keyframes button-slide-out': {\r\n from: {\r\n opacity: 1,\r\n transform: 'translateY(0px)',\r\n },\r\n to: {\r\n opacity: 0,\r\n transform: 'translateY(20px)',\r\n },\r\n },\r\n '@keyframes copy-qr': {\r\n '0%': { transform: 'scale(1)' },\r\n '50%': { transform: 'scale(1.1)' },\r\n '100%': { transform: 'scale(1)' },\r\n },\r\n '@keyframes copy-svg': {\r\n '0%': { opacity: 1 },\r\n '50%': { opacity: 0 },\r\n '100%': { opacity: 1 },\r\n },\r\n '@keyframes copy-icon': {\r\n '0%': { transform: 'scale(1)' },\r\n '50%': { transform: 'scale(0.7)' },\r\n '100%': { transform: 'scale(1)' },\r\n },\r\n '@keyframes success-qr': {\r\n '0%': { transform: 'scale(1)' },\r\n '50%': { transform: 'scale(0.7)' },\r\n '100%': { transform: 'scale(1)' },\r\n },\r\n '@keyframes success-icon': {\r\n '0%': { transform: 'rotate(0deg)' },\r\n '20%': { transform: 'rotate(-10deg)' },\r\n '60%': { transform: 'rotate(370deg)' },\r\n '100%': { transform: 'rotate(360deg)' },\r\n },\r\n },\r\n qrAnimations: ({ success, loading, recentlyCopied, copied }: StyleProps) => ({\r\n animation: success\r\n ? 'success-qr 0.4s ease-in-out forwards'\r\n : recentlyCopied\r\n ? 'copy-qr 0.3s ease-in-out forwards'\r\n : !loading && !copied\r\n ? 'reveal-qr 0.8s ease-in-out forwards'\r\n : 'none',\r\n '& svg': {\r\n animation: recentlyCopied ? 'copy-svg 0.3s ease-in-out forwards' : 'none',\r\n },\r\n '& image': {\r\n animation: success\r\n ? 'success-icon 1s ease-in-out forwards'\r\n : recentlyCopied\r\n ? 'copy-icon 0.3s ease-in-out forwards'\r\n : !loading && !copied\r\n ? 'fade-scale 0.6s ease-in-out forwards'\r\n : 'none',\r\n transformOrigin: 'center center',\r\n },\r\n }),\r\n button_container: {\r\n opacity: 0,\r\n animation: 'button-slide 0.6s ease-in-out forwards',\r\n animationDelay: '0.4s',\r\n },\r\n});\r\n\r\nexport const Widget: React.FunctionComponent<WidgetProps> = props => {\r\n const {\r\n to,\r\n foot,\r\n success,\r\n paymentId,\r\n successText,\r\n disablePaymentId,\r\n goalAmount,\r\n ButtonComponent = Button,\r\n currency = getCurrencyTypeFromAddress(to),\r\n animation,\r\n randomSatoshis = false,\r\n editable,\r\n setNewTxs,\r\n newTxs,\r\n apiBaseUrl,\r\n usdPrice,\r\n wsBaseUrl,\r\n hoverText = Button.defaultProps.hoverText,\r\n setAltpaymentShift,\r\n altpaymentShift,\r\n useAltpayment,\r\n setUseAltpayment,\r\n shiftCompleted,\r\n setShiftCompleted,\r\n disableAltpayment,\r\n contributionOffset\r\n } = Object.assign({}, Widget.defaultProps, props);\r\n\r\n const [loading, setLoading] = useState(true);\r\n const [copied, setCopied] = useState(false);\r\n const [recentlyCopied, setRecentlyCopied] = useState(false);\r\n const [totalReceived, setTotalReceived] = useState<number | undefined>(\r\n undefined,\r\n );\r\n const [disabled, setDisabled] = useState(false);\r\n const [errorMsg, setErrorMsg] = useState('');\r\n const [goalText, setGoalText] = useState('');\r\n const [goalPercent, setGoalPercent] = useState(0);\r\n const [socket, setSocket] = useState<Socket | undefined>(undefined);\r\n const [addressType, setAddressType] = useState<CryptoCurrency>(\r\n getCurrencyTypeFromAddress(to),\r\n );\r\n\r\n const price = props.price ?? 0;\r\n const [url, setUrl] = useState('');\r\n const [userEditedAmount, setUserEditedAmount] = useState<CurrencyObject>();\r\n const [text, setText] = useState(`Send any amount of ${addressType}`);\r\n const [widgetButtonText, setWidgetButtonText] = useState('Send Payment');\r\n const [opReturn, setOpReturn] = useState<string | undefined>();\r\n\r\n const [altpaymentSocket, setAltpaymentSocket] = useState<Socket | undefined>(undefined);\r\n const [coins, setCoins] = useState<AltpaymentCoin[]>([]);\r\n const [loadingPair, setLoadingPair] = useState<boolean>(false);\r\n const [coinPair, setCoinPair] = useState<AltpaymentPair | undefined>();\r\n const [loadingShift, setLoadingShift] = useState(false);\r\n const [altpaymentError, setAltpaymentError] = useState<AltpaymentError | undefined>(undefined);\r\n const [altpaymentEditable, setAltpaymentEditable] = useState<boolean>(false);\r\n const [isAboveMinimumAltpaymentUSDAmount, setIsAboveMinimumAltpaymentUSDAmount] = useState<boolean | null>(null);\r\n\r\n const theme = useTheme(props.theme, isValidXecAddress(to));\r\n const classes = useStyles({ success, loading, theme, recentlyCopied, copied });\r\n\r\n const [thisAmount, setThisAmount] = useState(props.amount);\r\n const [hasPrice, setHasPrice] = useState(props.price !== undefined && props.price > 0);\r\n const [thisCurrencyObject, setThisCurrencyObject] = useState(\r\n props.currencyObject,\r\n );\r\n\r\n const blurCSS = isPropsTrue(disabled) ? { filter: 'blur(5px)' } : {};\r\n\r\n const bchSvg = useMemo((): string => {\r\n const color = theme.palette.logo ?? theme.palette.primary;\r\n return `data:image/svg+xml,%3C%3Fxml version='1.0' encoding='UTF-8'%3F%3E%3Csvg version='1.1' viewBox='0 0 34 34' xmlns='http://www.w3.org/2000/svg'%3E%3Cg transform='translate(1,1)'%3E%3Ccircle cx='16' cy='16' r='17' fill='%23fff' stroke-width='1.0625'/%3E%3C/g%3E%3Cg transform='translate(1,1)' fill-rule='evenodd'%3E%3Ccircle cx='16' cy='16' r='16' fill='${window.encodeURIComponent(\r\n color,\r\n )}'/%3E%3Cpath d='m21.207 10.534c-0.776-1.972-2.722-2.15-4.988-1.71l-0.807-2.813-1.712 0.491 0.786 2.74c-0.45 0.128-0.908 0.27-1.363 0.41l-0.79-2.758-1.711 0.49 0.805 2.813c-0.368 0.114-0.73 0.226-1.085 0.328l-3e-3 -0.01-2.362 0.677 0.525 1.83s1.258-0.388 1.243-0.358c0.694-0.199 1.035 0.139 1.2 0.468l0.92 3.204c0.047-0.013 0.11-0.029 0.184-0.04l-0.181 0.052 1.287 4.49c0.032 0.227 4e-3 0.612-0.48 0.752 0.027 0.013-1.246 0.356-1.246 0.356l0.247 2.143 2.228-0.64c0.415-0.117 0.825-0.227 1.226-0.34l0.817 2.845 1.71-0.49-0.807-2.815a65.74 65.74 0 0 0 1.372-0.38l0.802 2.803 1.713-0.491-0.814-2.84c2.831-0.991 4.638-2.294 4.113-5.07-0.422-2.234-1.724-2.912-3.471-2.836 0.848-0.79 1.213-1.858 0.642-3.3zm-0.65 6.77c0.61 2.127-3.1 2.929-4.26 3.263l-1.081-3.77c1.16-0.333 4.704-1.71 5.34 0.508zm-2.322-5.09c0.554 1.935-2.547 2.58-3.514 2.857l-0.98-3.419c0.966-0.277 3.915-1.455 4.494 0.563z' fill='%23fff' fill-rule='nonzero'/%3E%3C/g%3E%3C/svg%3E%0A`;\r\n }, [theme]);\r\n\r\n const xecSvg =\r\n \"data:image/svg+xml;charset=UTF-8,%3csvg version='1.1' id='Layer_1' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' x='0px' y='0px' width='576px' height='576px' viewBox='0 0 576 576' enable-background='new 0 0 576 576' xml:space='preserve'%3e%3cg transform='translate(1,1)'%3e%3ccircle fill='%23FFFFFF' cx='287' cy='287' r='288'/%3e%3c/g%3e%3cpath fill='%23FFFFFF' d='M325.089,228.325l-67.15,38.668c-1.734,0.995-2.794,2.85-2.773,4.849v32.443 c-0.019,1.954,1.05,3.757,2.773,4.681l28.122,16.22c1.635,1.039,3.723,1.039,5.359,0l116.046-66.833 c19.694-11.393,19.694-44.216,0-55.609l-104.294-60.057c-8.867-5.357-19.975-5.357-28.842,0l-104.294,60.078 c-9.056,5.074-14.637,14.671-14.569,25.052c0,40.235,0.17,80.28,0,120.325c-0.085,10.362,5.461,19.954,14.485,25.052l104.294,60.247 c8.914,5.188,19.928,5.188,28.843,0l104.378-60.247c9.017-5.085,14.521-14.702,14.337-25.052v-52.306l-124.136,71.83 c-5.537,3.283-12.423,3.283-17.959,0l-55.439-32.124c-5.612-3.147-9.056-9.11-8.979-15.545V255.96 c-0.028-6.327,3.322-12.188,8.788-15.374c18.487-10.716,37.122-21.409,55.609-32.125c5.542-3.262,12.416-3.262,17.958,0 l27.53,15.713c1.13,0.727,1.459,2.233,0.732,3.365C325.7,227.862,325.42,228.131,325.089,228.325z'/%3e%3cpath fill='%230074C2' d='M288.878,16.941C139.176,16.941,17.819,138.298,17.819,288c0,149.701,121.357,271.059,271.059,271.059 c149.701,0,271.059-121.357,271.059-271.059C559.937,138.298,438.579,16.941,288.878,16.941z M325.089,224.174l-27.529-15.713 c-5.541-3.262-12.415-3.262-17.957,0c-18.487,10.715-37.122,21.409-55.609,32.125c-5.466,3.186-8.816,9.047-8.788,15.374v64.037 c-0.078,6.435,3.366,12.397,8.979,15.545l55.418,32.124c5.536,3.283,12.422,3.283,17.957,0l124.138-71.83v52.306 c0.204,10.327-5.257,19.938-14.231,25.052L303.193,433.44c-8.915,5.188-19.928,5.188-28.843,0l-104.315-60.247 c-9.056-5.075-14.637-14.671-14.569-25.052c0.17-40.045,0-80.111,0-120.325c-0.085-10.363,5.461-19.956,14.485-25.052 l104.294-60.078c8.868-5.357,19.975-5.357,28.843,0l104.378,60.078c19.694,11.393,19.694,44.217,0,55.609L291.42,325.186 c-1.636,1.039-3.724,1.039-5.359,0l-28.122-16.22c-1.724-0.924-2.792-2.727-2.773-4.681v-32.443 c-0.021-1.999,1.04-3.854,2.773-4.849l67.15-38.668c1.146-0.705,1.506-2.204,0.802-3.35 C325.689,224.649,325.416,224.375,325.089,224.174z'/%3e%3c/svg%3e\";\r\n\r\n const checkSvg = useMemo((): string => {\r\n const color = theme.palette.logo ?? theme.palette.primary;\r\n return `data:image/svg+xml,%3Csvg version='1.1' viewBox='1.65 1.65 20.65 20.65' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm-2 15l-5-5 1.41-1.41L10 14.17l7.59-7.59L19 8l-9 9z' fill='${window.encodeURIComponent(\r\n color,\r\n )}' stroke='%23fff' stroke-width='.6'/%3E%3Cpath d='m7.2979 14.697-2.6964-2.6966 0.89292-0.8934c0.49111-0.49137 0.90364-0.88958 0.91675-0.88491 0.013104 0.0047 0.71923 0.69866 1.5692 1.5422 0.84994 0.84354 1.6548 1.6397 1.7886 1.7692l0.24322 0.23547 7.5834-7.5832 1.8033 1.8033-9.4045 9.4045z' fill='%23fff' stroke-width='.033708'/%3E%3C/svg%3E%0A`;\r\n }, [theme]);\r\n\r\n useEffect((): (() => void) | undefined => {\r\n if (!recentlyCopied) return;\r\n\r\n const timer = setTimeout((): void => {\r\n setRecentlyCopied(false);\r\n }, 1000);\r\n\r\n return (): void => clearTimeout(timer);\r\n }, [recentlyCopied]);\r\n\r\n useEffect(() => {\r\n setHasPrice(price !== undefined && price > 0)\r\n }, [price])\r\n\r\n useEffect(() => {\r\n const setupAltpaymentSocket = async (): Promise<void> => {\r\n if (altpaymentSocket !== undefined) {\r\n altpaymentSocket.disconnect();\r\n }\r\n const newSocket = io(`${wsBaseUrl ?? config.wsBaseUrl}/altpayment`, {\r\n forceNew: true,\r\n });\r\n setAltpaymentSocket(newSocket);\r\n altpaymentListener({\r\n addressType,\r\n socket: newSocket,\r\n setCoins,\r\n setCoinPair,\r\n setLoadingPair,\r\n setAltpaymentShift,\r\n setLoadingShift,\r\n setAltpaymentError,\r\n })\r\n }\r\n\r\n const setupTxsSocket = async (): Promise<void> => {\r\n void getAddressDetails(to, apiBaseUrl);\r\n if (socket !== undefined) {\r\n socket.disconnect();\r\n }\r\n const newSocket = io(`${wsBaseUrl ?? config.wsBaseUrl}/addresses`, {\r\n forceNew: true,\r\n query: { addresses: [to], dummy: 'hehe' },\r\n });\r\n setSocket(newSocket);\r\n txsListener(newSocket, setNewTxs);\r\n }\r\n\r\n (async () => {\r\n await setupTxsSocket()\r\n if (useAltpayment) {\r\n await setupAltpaymentSocket()\r\n } else if (altpaymentSocket) {\r\n altpaymentSocket.disconnect()\r\n }\r\n })()\r\n\r\n return () => {\r\n if (socket !== undefined) {\r\n socket.disconnect();\r\n }\r\n if (altpaymentSocket !== undefined) {\r\n altpaymentSocket.disconnect();\r\n }\r\n }\r\n }, [to, useAltpayment]);\r\n\r\n const tradeWithAltpayment = () => {\r\n if (setUseAltpayment) {\r\n setUseAltpayment(true)\r\n }\r\n }\r\n\r\n useEffect(() => {\r\n if (thisAmount === undefined || thisAmount === null || thisAmount === 0) {\r\n setAltpaymentEditable(true)\r\n }\r\n if (isPropsTrue(editable)) {\r\n setAltpaymentEditable(true)\r\n }\r\n }, [])\r\n\r\n useEffect(() => {\r\n (async (): Promise<void> => {\r\n const balance = await getAddressBalance(to, apiBaseUrl);\r\n setTotalReceived(balance);\r\n setLoading(false);\r\n })();\r\n }, [newTxs]);\r\n\r\n useEffect(() => {\r\n const invalidAmount =\r\n thisAmount !== undefined && thisAmount && isNaN(+thisAmount);\r\n\r\n if (isValidCashAddress(to) || isValidXecAddress(to)) {\r\n setDisabled(isPropsTrue(props.disabled));\r\n setErrorMsg('');\r\n } else if (invalidAmount) {\r\n setDisabled(true);\r\n setErrorMsg('Amount should be a number');\r\n } else {\r\n setDisabled(true);\r\n setErrorMsg('Invalid Recipient');\r\n }\r\n if (usdPrice && thisAmount) {\r\n const usdAmount = usdPrice * +thisAmount\r\n setIsAboveMinimumAltpaymentUSDAmount(usdAmount >= MINIMUM_ALTPAYMENT_DOLLAR_AMOUNT)\r\n }\r\n }, [to, thisAmount, usdPrice]);\r\n\r\n useEffect(() => {\r\n const invalidAmount =\r\n thisAmount !== undefined && thisAmount && isNaN(+thisAmount);\r\n const isNegativeNumber =\r\n typeof thisAmount === 'string' && thisAmount.startsWith('-');\r\n let cleanAmount: any;\r\n\r\n if (invalidAmount) {\r\n setDisabled(true);\r\n setErrorMsg('Amount should be a number');\r\n } else if (isNegativeNumber) {\r\n setDisabled(true);\r\n setErrorMsg('Amount should be positive');\r\n } else {\r\n if (isValidCashAddress(to) || isValidXecAddress(to)) {\r\n setErrorMsg('');\r\n } else {\r\n setErrorMsg('Invalid Recipient');\r\n }\r\n }\r\n\r\n if (userEditedAmount !== undefined && thisAmount && addressType) {\r\n const obj = getCurrencyObject(+thisAmount, currency, false);\r\n setThisCurrencyObject(obj);\r\n if (props.setCurrencyObject) {\r\n props.setCurrencyObject(obj);\r\n }\r\n } else if (thisAmount && addressType) {\r\n cleanAmount = +thisAmount;\r\n const obj = getCurrencyObject(cleanAmount, currency, randomSatoshis);\r\n setThisCurrencyObject(obj);\r\n if (props.setCurrencyObject) {\r\n props.setCurrencyObject(obj);\r\n }\r\n }\r\n }, [thisAmount, currency, userEditedAmount]);\r\n\r\n useEffect(() => {\r\n if (to === undefined) {\r\n return;\r\n }\r\n const address = to;\r\n let url;\r\n\r\n const addressType: Currency = getCurrencyTypeFromAddress(address);\r\n setAddressType(addressType);\r\n setWidgetButtonText(`Send with ${addressType} wallet`);\r\n\r\n if (thisCurrencyObject && hasPrice) {\r\n const convertedAmount = thisCurrencyObject.float / price\r\n const convertedObj = price\r\n ? getCurrencyObject(\r\n convertedAmount,\r\n addressType,\r\n randomSatoshis,\r\n )\r\n : null;\r\n if (convertedObj) {\r\n setText(\r\n `Send ${thisCurrencyObject.string} ${thisCurrencyObject.currency} = ${convertedObj.string} ${addressType}`,\r\n );\r\n url = resolveUrl(addressType, convertedObj.float);\r\n setUrl(url ?? \"\");\r\n }\r\n } else {\r\n const notZeroValue: boolean =\r\n thisCurrencyObject?.float !== undefined && thisCurrencyObject.float > 0;\r\n if (!isFiat(currency) && thisCurrencyObject && notZeroValue) {\r\n const currency: string = thisCurrencyObject.currency;\r\n setText(`Send ${thisCurrencyObject.string} ${currency}`);\r\n url = resolveUrl(currency, thisCurrencyObject?.float);\r\n } else {\r\n setText(`Send any amount of ${addressType}`);\r\n url = resolveUrl(addressType);\r\n }\r\n setUrl(url ?? \"\");\r\n }\r\n }, [to, thisCurrencyObject, price, thisAmount, opReturn, hasPrice]);\r\n\r\n useEffect(() => {\r\n try {\r\n setOpReturn(\r\n encodeOpReturnProps({\r\n opReturn: props.opReturn,\r\n paymentId,\r\n disablePaymentId: disablePaymentId ?? false,\r\n }),\r\n );\r\n } catch (err) {\r\n console.error(err);\r\n setErrorMsg((err as Error).message);\r\n setDisabled(true)\r\n }\r\n }, [props.opReturn, paymentId, disablePaymentId]);\r\n\r\n useEffect(() => {\r\n setThisAmount(props.amount);\r\n }, [props.amount]);\r\n\r\n useEffect(() => {\r\n if (totalReceived !== undefined) {\r\n const progress = getCurrencyObject(totalReceived, currency, false);\r\n\r\n const goal = getCurrencyObject(cleanGoalAmount, currency, false);\r\n if (!isFiat(currency)) {\r\n if (goal !== undefined) {\r\n let progressFloat = progress.float;\r\n if(contributionOffset !== undefined){\r\n progressFloat = Number(progressFloat) + Number(contributionOffset)\r\n };\r\n setGoalPercent((100 * progressFloat) / goal.float);\r\n setGoalText(`${progressFloat} / ${cleanGoalAmount}`);\r\n setLoading(false);\r\n }\r\n } else {\r\n if (hasPrice) {\r\n const receivedVal: number = totalReceived * price;\r\n const receivedText: string = formatPrice(\r\n receivedVal,\r\n currency,\r\n DECIMALS.FIAT,\r\n );\r\n const goalText: string = formatPrice(\r\n cleanGoalAmount,\r\n currency,\r\n DECIMALS.FIAT,\r\n );\r\n const receivedRatio = `${receivedText} / ${goalText}`;\r\n const receivedPercentage: number =\r\n 100 * (receivedVal / cleanGoalAmount);\r\n setLoading(false);\r\n setGoalPercent(receivedPercentage);\r\n setGoalText(receivedRatio);\r\n }\r\n }\r\n if (shouldDisplayGoal && goal.float !== undefined && goal.float <= 0) {\r\n setDisabled(true);\r\n setErrorMsg('Goal Value must be a number');\r\n }\r\n }\r\n }, [totalReceived, currency, goalAmount, price, hasPrice, contributionOffset]);\r\n\r\n const handleButtonClick = () => {\r\n if (addressType === 'XEC') {\r\n const hasExtension = getCashtabProviderStatus();\r\n if (!hasExtension) {\r\n const webUrl = `https://cashtab.com/#/send?bip21=${url}`;\r\n window.open(webUrl, '_blank');\r\n } else {\r\n return window.postMessage(\r\n {\r\n type: 'FROM_PAGE',\r\n text: 'Cashtab',\r\n txInfo: {\r\n bip21: url\r\n },\r\n },\r\n '*',\r\n );\r\n }\r\n } else {\r\n window.location.href = url;\r\n }\r\n };\r\n\r\n const handleQrCodeClick = useCallback((): void => {\r\n if (disabled || to === undefined) return;\r\n if (!url || !copy(url)) return;\r\n setCopied(true);\r\n setRecentlyCopied(true);\r\n }, [disabled, to, url, copy, setCopied, setRecentlyCopied]);\r\n\r\n const resolveUrl = useCallback((currency: string, amount?: number) => {\r\n if (disabled || !to) return;\r\n\r\n const prefix = CURRENCY_PREFIXES_MAP[currency.toLowerCase() as typeof CRYPTO_CURRENCIES[number]];\r\n if (!prefix) return;\r\n\r\n let thisUrl = `${prefix}:${to.replace(/^.*:/, '')}`;\r\n\r\n if (amount) {\r\n thisUrl += `?amount=${amount}`;\r\n }\r\n\r\n if (opReturn) {\r\n const separator = thisUrl.includes('?') ? '&' : '?';\r\n thisUrl += `${separator}op_return_raw=${opReturn}`;\r\n }\r\n\r\n return thisUrl;\r\n }, [disabled, to, currency, opReturn]);\r\n\r\n const qrCodeProps: QRCodeProps = {\r\n renderAs: 'svg',\r\n size: 300,\r\n level: 'H', // High error correction allows for a larger logo\r\n value: url,\r\n fgColor: theme.palette.tertiary,\r\n imageSettings: {\r\n src: success ? checkSvg : isValidCashAddress(to) ? bchSvg : xecSvg,\r\n excavate: false,\r\n height: 112,\r\n width: 112,\r\n },\r\n };\r\n\r\n const qrCode = (\r\n <div className={classes.qrAnimations}>\r\n <QRCode\r\n {...qrCodeProps}\r\n style={{ flex: 1, width: '100%', height: 'auto', ...blurCSS }}\r\n />\r\n </div>\r\n );\r\n\r\n let cleanGoalAmount: any;\r\n if (goalAmount) {\r\n cleanGoalAmount = +goalAmount;\r\n }\r\n\r\n const shouldDisplayGoal: boolean = goalAmount !== undefined;\r\n const handleAmountChange = (e: React.ChangeEvent<HTMLInputElement>) => {\r\n let amount = e.target.value;\r\n if (amount === '') {\r\n amount = '0';\r\n }\r\n\r\n const userEdited = getCurrencyObject(+amount, currency, false);\r\n\r\n setUserEditedAmount(userEdited);\r\n updateAmount(amount)\r\n };\r\n\r\n const updateAmount = (amount: string) => {\r\n setThisAmount(amount);\r\n if (props.setAmount) {\r\n props.setAmount(amount);\r\n }\r\n }\r\n\r\n return (\r\n <ThemeProvider value={theme}>\r\n <Box\r\n className={classes.root}\r\n pt={0}\r\n display=\"flex\"\r\n flexDirection=\"column\"\r\n alignItems=\"center\"\r\n >\r\n <Box\r\n flex=\"shrink\"\r\n alignSelf=\"stretch\"\r\n style={{ background: '#fff' }}\r\n py={1}\r\n textAlign=\"center\"\r\n >\r\n <Typography className={errorMsg ? classes.error : classes.text}>\r\n {(() => {\r\n if (errorMsg) return errorMsg;\r\n if (disabled) return 'Not yet ready for payment';\r\n if (loading) return 'Loading...';\r\n if (success) return successText;\r\n return text;\r\n })()}\r\n </Typography>\r\n </Box>\r\n <Box\r\n display=\"flex\"\r\n flexDirection=\"column\"\r\n alignItems=\"center\"\r\n px={3}\r\n pt={2}\r\n position=\"relative\"\r\n >\r\n {// Altpayment region\r\n useAltpayment &&\r\n <AltpaymentWidget\r\n altpaymentSocket={altpaymentSocket}\r\n thisAmount={thisAmount}\r\n updateAmount={updateAmount}\r\n setUseAltpayment={setUseAltpayment}\r\n altpaymentShift={altpaymentShift}\r\n setAltpaymentShift={setAltpaymentShift}\r\n shiftCompleted={shiftCompleted}\r\n setShiftCompleted={setShiftCompleted}\r\n altpaymentError={altpaymentError}\r\n setAltpaymentError={setAltpaymentError}\r\n coins={coins}\r\n loadingPair={loadingPair}\r\n setLoadingPair={setLoadingPair}\r\n loadingShift={loadingShift}\r\n setLoadingShift={setLoadingShift}\r\n coinPair={coinPair}\r\n setCoinPair={setCoinPair}\r\n altpaymentEditable={altpaymentEditable}\r\n animation={animation}\r\n addressType={addressType}\r\n to={to}\r\n />\r\n }\r\n <>\r\n {loading && shouldDisplayGoal ? (\r\n <Typography\r\n className={classes.text}\r\n style={{ margin: '10px auto 20px' }}\r\n >\r\n <CircularProgress\r\n size={15}\r\n thickness={4}\r\n className={classes.spinner}\r\n />\r\n </Typography>\r\n ) : (\r\n <>\r\n {shouldDisplayGoal && (\r\n <>\r\n <Typography\r\n className={classes.copyText}\r\n style={{ marginBottom: '0.61rem', ...blurCSS}}\r\n >\r\n {goalText}\r\n <strong>&nbsp;{currency}</strong>\r\n </Typography>\r\n <BarChart\r\n color={theme.palette.primary}\r\n value={Math.round(goalPercent)}\r\n disabled={disabled}\r\n />\r\n </>\r\n )}\r\n </>\r\n )}\r\n\r\n <Box\r\n flex={1}\r\n position=\"relative\"\r\n className={classes.qrCode}\r\n onClick={handleQrCodeClick}\r\n >\r\n <Fade in={!loading && url !== ''}>\r\n <React.Fragment>\r\n {qrCode}\r\n <Box position=\"absolute\" bottom={0} right={0}>\r\n <Fade\r\n appear={false}\r\n in={!copied || recentlyCopied}\r\n timeout={{ enter: 0, exit: 2000 }}\r\n >\r\n <Box className={classes.copyTextContainer}>\r\n {!isPropsTrue(disabled) && (\r\n <Typography className={classes.copyText}>\r\n {copied ? 'Payment copied!' : 'Click to copy'}\r\n </Typography>\r\n )}\r\n </Box>\r\n </Fade>\r\n </Box>\r\n </React.Fragment>\r\n </Fade>\r\n {loading && (\r\n <Box\r\n position=\"absolute\"\r\n top={0}\r\n bottom={0}\r\n left={0}\r\n right={0}\r\n display=\"flex\"\r\n justifyContent=\"center\"\r\n alignItems=\"center\"\r\n >\r\n <CircularProgress\r\n size={70}\r\n thickness={4}\r\n className={classes.spinner}\r\n />\r\n </Box>\r\n )}\r\n </Box>\r\n\r\n {isPropsTrue(editable) && (\r\n <div className={classes.editAmount}>\r\n <TextField\r\n label='Edit amount'\r\n value={thisAmount || 0}\r\n onChange={handleAmountChange}\r\n inputProps={{ maxlength: '12' }}\r\n name=\"Amount\"\r\n placeholder='Enter Amount'\r\n id=\"userEditedAmount\"\r\n />\r\n <Typography component=\"span\">{currency}</Typography>\r\n </div>\r\n )}\r\n\r\n {success || (\r\n <Box pt={2} flex={1} className={classes.button_container}>\r\n <ButtonComponent\r\n text={widgetButtonText}\r\n hoverText={hoverText}\r\n onClick={handleButtonClick}\r\n disabled={isPropsTrue(disabled)}\r\n animation={animation}\r\n />\r\n </Box>\r\n )}\r\n {!isPropsTrue(disableAltpayment) && (\r\n <Typography\r\n component=\"div\"\r\n className={`${classes.sideShiftLink} ${isAboveMinimumAltpaymentUSDAmount || altpaymentEditable ? classes.animate_sideshift : classes.hide_sideshift}`}\r\n onClick={isAboveMinimumAltpaymentUSDAmount || altpaymentEditable ? tradeWithAltpayment : undefined}\r\n style={{cursor: isAboveMinimumAltpaymentUSDAmount || altpaymentEditable ? 'pointer' : 'default'}}\r\n >\r\n Don't have any {addressType}?\r\n </Typography>\r\n )}\r\n </>\r\n {foot && (\r\n <Box pt={2} flex={1}>\r\n {foot}\r\n </Box>\r\n )}\r\n <Box py={0.8}>\r\n <Typography className={classes.footer}>\r\n Powered by PayButton.org\r\n </Typography>\r\n </Box>\r\n </Box>\r\n </Box>\r\n </ThemeProvider>\r\n );\r\n};\r\n\r\nWidget.defaultProps = {\r\n success: false,\r\n successText: 'Thank you!',\r\n editable: false,\r\n};\r\n\r\nexport default Widget;\r\n","import { Socket } from 'socket.io-client';\r\nimport { AltpaymentCoin, AltpaymentError, AltpaymentPair, AltpaymentShift } from '../altpayment';\r\n\r\nimport { BroadcastTxData } from './types';\r\n\r\nexport const txsListener = (socket: Socket, setNewTxs: Function): void => {\r\n socket.on('incoming-txs', (broadcastedTxData: BroadcastTxData) => {\r\n const unconfirmedTxs = broadcastedTxData.txs.filter(\r\n tx => tx.confirmed === false,\r\n );\r\n if (\r\n broadcastedTxData.messageType === 'NewTx' &&\r\n unconfirmedTxs.length !== 0\r\n ) {\r\n setNewTxs(unconfirmedTxs);\r\n }\r\n });\r\n};\r\n\r\ninterface AltpaymentListenerParams {\r\n addressType: string\r\n socket: Socket\r\n setCoins: Function\r\n setCoinPair: Function\r\n setLoadingPair: Function\r\n setAltpaymentShift: Function\r\n setLoadingShift: Function\r\n setAltpaymentError: Function\r\n}\r\n\r\nexport const altpaymentListener = (params: AltpaymentListenerParams): void => {\r\n params.socket.on('send-altpayment-coins-info', (coins: AltpaymentCoin[]) => {\r\n params.setCoins(coins.filter(c => c.coin !== params.addressType))\r\n })\r\n params.socket.on('shift-creation-error', (error: AltpaymentError) => {\r\n params.setAltpaymentError(error)\r\n params.setLoadingShift(false)\r\n return\r\n });\r\n params.socket.on('quote-creation-error', (error: AltpaymentError) => {\r\n params.setAltpaymentError(error)\r\n params.setLoadingShift(false)\r\n return\r\n });\r\n params.socket.on('shift-created', (shift: AltpaymentShift) => {\r\n params.setAltpaymentShift(shift)\r\n params.setLoadingShift(false)\r\n });\r\n params.socket.on('send-altpayment-rate', (pair: AltpaymentPair) => {\r\n params.setCoinPair(pair)\r\n params.setLoadingPair(false)\r\n })\r\n};\r\n","import { MockedPaymentClient } from \"./mocked\"\r\nimport { SideshiftClient, SideshiftCoin, SideshiftError, SideshiftPair, SideshiftQuote, SideshiftShift } from \"./sideshift\"\r\nimport config from '../../../paybutton-config.json'\r\n\r\nexport const MINIMUM_ALTPAYMENT_DOLLAR_AMOUNT = 10\r\n\r\nexport const SOCKET_MESSAGES = {\r\n GET_ALTPAYMENT_RATE: 'get-altpayment-rate',\r\n SEND_ALTPAYMENT_RATE: 'send-altpayment-rate',\r\n SEND_ALTPAYMENT_COINS_INFO: 'send-altpayment-coins-info',\r\n CREATE_ALTPAYMENT_QUOTE: 'create-altpayment-quote',\r\n SHIFT_CREATED: 'altpayment-shift-created',\r\n ERROR_WHEN_CREATING_QUOTE: 'quote-creation-error',\r\n ERROR_WHEN_CREATING_SHIFT: 'shift-creation-error'\r\n}\r\n\r\nexport type AltpaymentClientOptions = 'sideshift' | 'mocked'\r\n\r\nexport type AltpaymentCoin = SideshiftCoin\r\nexport type AltpaymentQuote = SideshiftQuote\r\nexport type AltpaymentPair = SideshiftPair\r\nexport type AltpaymentShift = SideshiftShift\r\nexport type AltpaymentError = SideshiftError\r\n\r\nexport interface AltpaymentClient {\r\n getPaymentStatus: (id: string) => Promise<AltpaymentShift>\r\n}\r\n\r\nexport function getAltpaymentClient (): AltpaymentClient {\r\n switch (config.altpaymentClient) {\r\n case 'sideshift' as AltpaymentClientOptions:\r\n return new SideshiftClient()\r\n case 'mocked' as AltpaymentClientOptions:\r\n return new MockedPaymentClient()\r\n default:\r\n throw new Error(\"ERROR: Invalid alternative payment client\")\r\n }\r\n}\r\n","import { OptionsObject, SnackbarProvider, useSnackbar } from 'notistack';\r\nimport React, { useCallback, useEffect, useMemo, useState } from 'react';\r\nimport { AltpaymentShift, getAltpaymentClient } from '../../altpayment';\r\n\r\nimport successSound from '../../assets/success.mp3.json';\r\n\r\nimport {\r\n getFiatPrice,\r\n Currency,\r\n CurrencyObject,\r\n Transaction,\r\n generatePaymentId,\r\n getCurrencyTypeFromAddress,\r\n isCrypto,\r\n isGreaterThanZero,\r\n isValidCurrency,\r\n resolveNumber,\r\n shouldTriggerOnSuccess,\r\n getCurrencyObject\r\n} from '../../util';\r\n\r\nimport Widget, { WidgetProps } from './Widget';\r\n\r\nexport interface WidgetContainerProps\r\n extends Omit<WidgetProps, 'success' | 'setNewTxs' | 'setCurrencyObject' | 'setAltpaymentShift' | 'useAltpayment' | 'setUseAltpayment' | 'shiftCompleted' | 'setShiftCompleted' > {\r\n active?: boolean;\r\n amount?: number;\r\n opReturn?: string;\r\n paymentId?: string;\r\n disablePaymentId?: boolean;\r\n currency?: Currency;\r\n currencyObj?: CurrencyObject;\r\n cryptoAmount?: string;\r\n price?: number;\r\n setCurrencyObj: Function;\r\n randomSatoshis?: boolean | number;\r\n hideToasts?: boolean;\r\n onSuccess?: (transaction: Transaction) => void;\r\n onTransaction?: (transaction: Transaction) => void;\r\n sound?: boolean;\r\n goalAmount?: number | string;\r\n disabled: boolean;\r\n editable: boolean;\r\n wsBaseUrl?: string;\r\n apiBaseUrl?: string;\r\n successText?: string;\r\n disableAltpayment?: boolean\r\n contributionOffset?: number\r\n}\r\n\r\nconst snackbarOptions: OptionsObject = {\r\n variant: 'success',\r\n autoHideDuration: 8000,\r\n anchorOrigin: {\r\n vertical: 'bottom',\r\n horizontal: 'center',\r\n },\r\n};\r\n\r\nexport interface Output {\r\n index: number;\r\n value: number;\r\n pubkeyScript: string;\r\n address: string;\r\n scriptClass: string;\r\n disassembledScript: string;\r\n}\r\n\r\nconst withSnackbar =\r\n <T extends object>(\r\n Component: React.ComponentType<T>,\r\n ): React.FunctionComponent<T> =>\r\n (props): React.ReactElement =>\r\n (\r\n <SnackbarProvider>\r\n <Component {...props} />\r\n </SnackbarProvider>\r\n );\r\n\r\nexport const WidgetContainer: React.FunctionComponent<WidgetContainerProps> =\r\n withSnackbar((props): React.ReactElement => {\r\n let {\r\n to,\r\n opReturn,\r\n disablePaymentId,\r\n paymentId,\r\n amount,\r\n setAmount,\r\n setCurrencyObj,\r\n currencyObj,\r\n currency = '' as Currency,\r\n cryptoAmount,\r\n price,\r\n animation,\r\n randomSatoshis = false,\r\n hideToasts = false,\r\n sound = true,\r\n onSuccess,\r\n onTransaction,\r\n goalAmount,\r\n disabled,\r\n editable,\r\n wsBaseUrl,\r\n apiBaseUrl,\r\n successText,\r\n hoverText,\r\n disableAltpayment,\r\n contributionOffset,\r\n ...widgetProps\r\n } = props;\r\n\r\n const [thisPaymentId, setThisPaymentId] = useState<string | undefined>();\r\n const [thisPrice, setThisPrice] = useState(0);\r\n const [usdPrice, setUsdPrice] = useState(0);\r\n useEffect(() => {\r\n if ((paymentId === undefined || paymentId === '') && !disablePaymentId) {\r\n const newPaymentId = generatePaymentId(8);\r\n setThisPaymentId(newPaymentId)\r\n } else {\r\n setThisPaymentId(paymentId)\r\n }\r\n }, [paymentId, disablePaymentId]);\r\n const [success, setSuccess] = useState(false);\r\n const { enqueueSnackbar } = useSnackbar();\r\n\r\n const [newTxs, setNewTxs] = useState<Transaction[] | undefined>();\r\n const [useAltpayment, setUseAltpayment] = useState(false);\r\n const [altpaymentShift, setAltpaymentShift] = useState<AltpaymentShift | undefined>();\r\n const [shiftCompleted, setShiftCompleted] = useState(false);\r\n\r\n const paymentClient = getAltpaymentClient()\r\n\r\n const addrType = getCurrencyTypeFromAddress(to);\r\n if (\r\n !isValidCurrency(currency) ||\r\n (isCrypto(currency) && addrType !== currency)\r\n ) {\r\n currency = addrType;\r\n }\r\n\r\n const txSound = useMemo(\r\n (): HTMLAudioElement => new Audio(successSound.base64),\r\n [],\r\n );\r\n\r\n const handlePayment = useCallback(\r\n async (transaction: Transaction) => {\r\n if (altpaymentShift) {\r\n const shiftStatus = await paymentClient.getPaymentStatus(altpaymentShift.id)\r\n if (shiftStatus.status === 'settled') {\r\n if (sound) txSound.play().catch(() => {});\r\n onSuccess?.(transaction);\r\n setShiftCompleted(true)\r\n }\r\n } else {\r\n const expectedAmount = amount ? resolveNumber(amount) : undefined;\r\n const receivedAmount = resolveNumber(transaction.amount);\r\n\r\n if (await shouldTriggerOnSuccess(\r\n transaction,\r\n currency,\r\n thisPrice,\r\n disablePaymentId,\r\n thisPaymentId,\r\n expectedAmount,\r\n opReturn,\r\n currencyObj ?? getCurrencyObject(\r\n Number(props.amount),\r\n currency,\r\n randomSatoshis,\r\n ),\r\n )) {\r\n if (sound) {\r\n txSound.play().catch(() => {});\r\n }\r\n\r\n const currencyTicker = getCurrencyTypeFromAddress(to);\r\n if (!hideToasts)\r\n enqueueSnackbar(\r\n `${\r\n successText ? successText + ' | ' : ''\r\n }Received ${receivedAmount} ${currencyTicker}`,\r\n snackbarOptions,\r\n );\r\n\r\n setSuccess(true);\r\n onSuccess?.(transaction);\r\n } else {\r\n onTransaction?.(transaction);\r\n }\r\n }\r\n setNewTxs([]);\r\n },\r\n [\r\n onSuccess,\r\n onTransaction,\r\n enqueueSnackbar,\r\n hideToasts,\r\n sound,\r\n txSound,\r\n cryptoAmount,\r\n successText,\r\n to,\r\n thisPaymentId,\r\n altpaymentShift,\r\n thisPrice,\r\n currencyObj,\r\n ],\r\n );\r\n\r\n const getPrice = useCallback(\r\n async () => {\r\n const price = await getFiatPrice(currency, to, apiBaseUrl)\r\n const usdPrice = await getFiatPrice('USD', to, apiBaseUrl)\r\n if (price !== null) setThisPrice(price)\r\n if (usdPrice !== null) setUsdPrice(usdPrice)\r\n }\r\n , [currency, to, apiBaseUrl]\r\n );\r\n\r\n useEffect(() => {\r\n if (price === undefined || price === 0) {\r\n (async () => {\r\n getPrice();\r\n })()\r\n } else {\r\n setThisPrice(price)\r\n }\r\n }, [currency, price, usdPrice]);\r\n\r\n const handleNewTransaction = useCallback(\r\n (tx: Transaction) => {\r\n if (\r\n tx.confirmed === false &&\r\n isGreaterThanZero(resolveNumber(tx.amount))\r\n ) {\r\n handlePayment(tx);\r\n }\r\n },\r\n [handlePayment],\r\n );\r\n\r\n useEffect(() => {\r\n newTxs?.map(tx => {\r\n handleNewTransaction(tx);\r\n });\r\n }, [newTxs, handleNewTransaction]);\r\n\r\n return (\r\n <React.Fragment>\r\n <Widget\r\n to={to}\r\n {...widgetProps}\r\n amount={amount}\r\n setAmount={setAmount}\r\n opReturn={opReturn}\r\n paymentId={thisPaymentId}\r\n disablePaymentId={disablePaymentId}\r\n goalAmount={goalAmount}\r\n currency={currency}\r\n animation={animation}\r\n currencyObject={currencyObj}\r\n setCurrencyObject={setCurrencyObj}\r\n randomSatoshis={randomSatoshis}\r\n price={thisPrice}\r\n usdPrice={usdPrice}\r\n success={success}\r\n disabled={disabled}\r\n editable={editable}\r\n setNewTxs={setNewTxs}\r\n newTxs={newTxs}\r\n wsBaseUrl={wsBaseUrl}\r\n apiBaseUrl={apiBaseUrl}\r\n successText={successText}\r\n hoverText={hoverText}\r\n altpaymentShift={altpaymentShift}\r\n setAltpaymentShift={setAltpaymentShift}\r\n useAltpayment={useAltpayment}\r\n setUseAltpayment={setUseAltpayment}\r\n shiftCompleted={shiftCompleted}\r\n setShiftCompleted={setShiftCompleted}\r\n disableAltpayment={disableAltpayment}\r\n contributionOffset={contributionOffset}\r\n />\r\n </React.Fragment>\r\n );\r\n });\r\n\r\nexport default WidgetContainer;\r\n","import BigNumber from \"bignumber.js\";\r\nimport { getCurrencyTypeFromAddress } from \"./address\";\r\nimport { resolveNumber } from \"./number\";\r\nimport { Currency, CurrencyObject, Transaction } from \"./types\";\r\nimport { DECIMALS } from \"./constants\";\r\n\r\nexport const shouldTriggerOnSuccess = async (\r\n transaction: Transaction,\r\n currency: string,\r\n price: number,\r\n disablePaymentId?: boolean,\r\n expectedPaymentId?: string,\r\n expectedAmount?: BigNumber,\r\n expectedOpReturn?: string,\r\n currencyObject?: CurrencyObject,\r\n ) => {\r\n const {\r\n paymentId,\r\n rawMessage:rawOpReturn,\r\n message,\r\n amount, \r\n address } = transaction; \r\n \r\n let isAmountValid = true;\r\n\r\n if(expectedAmount) {\r\n const transactionCurrency: Currency = getCurrencyTypeFromAddress(address);\r\n if (transactionCurrency !== currency) {\r\n if (currencyObject){\r\n const value = (currencyObject.float / price).toFixed(DECIMALS[transactionCurrency])\r\n isAmountValid = resolveNumber(value).isEqualTo(amount)\r\n }else {\r\n isAmountValid = false\r\n }\r\n } else {\r\n isAmountValid = expectedAmount.isEqualTo(amount)\r\n }\r\n } \r\n \r\n const paymentIdsMatch = expectedPaymentId === paymentId;\r\n const isPaymentIdValid = disablePaymentId ? true : paymentIdsMatch;\r\n\r\n const rawOpReturnIsEmptyOrUndefined = rawOpReturn === '' || rawOpReturn === undefined;\r\n const opReturn = rawOpReturnIsEmptyOrUndefined ? message : rawOpReturn\r\n const opReturnIsEmptyOrUndefined = opReturn === '' || opReturn === undefined;\r\n \r\n const opReturnsMatch = opReturn === expectedOpReturn;\r\n const isOpReturnValid = expectedOpReturn ? opReturnsMatch : opReturnIsEmptyOrUndefined;\r\n \r\n return isAmountValid && isPaymentIdValid && isOpReturnValid;\r\n};","import { Dialog, Zoom } from '@material-ui/core';\r\nimport React, { useState, useEffect } from 'react';\r\nimport { Theme, ThemeName, ThemeProvider, useTheme } from '../../themes';\r\nimport Button, { ButtonProps } from '../Button/Button';\r\nimport { WidgetContainer } from '../Widget/WidgetContainer';\r\nimport { Currency, CurrencyObject, Transaction, isPropsTrue, isValidCashAddress, isValidXecAddress } from '../../util';\r\n\r\nexport interface PaymentDialogProps extends ButtonProps {\r\n to: string;\r\n amount?: number | string;\r\n setAmount: Function;\r\n opReturn?: string;\r\n paymentId?: string;\r\n disablePaymentId?: boolean;\r\n currency?: Currency;\r\n currencyObj?: CurrencyObject;\r\n cryptoAmount?: string;\r\n price?: number;\r\n hoverText?: string;\r\n setCurrencyObj: Function;\r\n theme?: ThemeName | Theme;\r\n successText?: string;\r\n randomSatoshis?: boolean | number;\r\n hideToasts?: boolean;\r\n goalAmount?: number | string;\r\n disableEnforceFocus?: boolean;\r\n editable?: boolean;\r\n dialogOpen: boolean;\r\n disableScrollLock?: boolean;\r\n active?: boolean;\r\n container?: HTMLElement;\r\n onClose?: (success?: boolean, paymentId?: string) => void;\r\n onSuccess?: (transaction: Transaction) => void;\r\n onTransaction?: (transaction: Transaction) => void;\r\n wsBaseUrl?: string;\r\n apiBaseUrl?: string;\r\n disableAltpayment?: boolean;\r\n contributionOffset?:number;\r\n}\r\n\r\nexport const PaymentDialog = (\r\n props: PaymentDialogProps,\r\n): React.ReactElement => {\r\n const [success, setSuccess] = useState(false);\r\n const [disabled, setDisabled] = useState(false);\r\n\r\n const {\r\n to,\r\n amount,\r\n setAmount,\r\n opReturn,\r\n paymentId,\r\n disablePaymentId,\r\n currency,\r\n currencyObj,\r\n setCurrencyObj,\r\n cryptoAmount,\r\n price,\r\n successText,\r\n animation,\r\n randomSatoshis,\r\n hideToasts,\r\n onClose,\r\n onSuccess,\r\n onTransaction,\r\n goalAmount,\r\n disableEnforceFocus,\r\n editable,\r\n dialogOpen,\r\n container,\r\n wsBaseUrl,\r\n apiBaseUrl,\r\n hoverText,\r\n disableAltpayment,\r\n contributionOffset\r\n } = Object.assign({}, PaymentDialog.defaultProps, props);\r\n\r\n const handleWidgetClose = (): void => {\r\n if (onClose) onClose(success, paymentId);\r\n setSuccess(false);\r\n };\r\n const handleSuccess = (transaction: Transaction): void => {\r\n setSuccess(true);\r\n onSuccess?.(transaction);\r\n };\r\n useEffect(() => {\r\n const invalidAmount = amount !== undefined && isNaN(+amount);\r\n\r\n if (to !== undefined && (isValidCashAddress(to) || isValidXecAddress(to))) {\r\n setDisabled(isPropsTrue(props.disabled));\r\n } else if (invalidAmount) {\r\n setDisabled(true);\r\n } else {\r\n setDisabled(true);\r\n }\r\n }, [to, amount, props.disabled]);\r\n\r\n const ButtonComponent: React.FunctionComponent<ButtonProps> = (\r\n props: ButtonProps,\r\n ): React.ReactElement => <Button animation={animation} {...props} />;\r\n\r\n const theme = useTheme(props.theme, isValidXecAddress(to));\r\n\r\n let cleanAmount: any;\r\n\r\n if (amount) {\r\n cleanAmount = +amount;\r\n }\r\n\r\n return (\r\n <ThemeProvider value={theme}>\r\n <Dialog\r\n container={container}\r\n open={dialogOpen}\r\n onClose={handleWidgetClose}\r\n disableEnforceFocus={disableEnforceFocus}\r\n disableScrollLock\r\n TransitionComponent={Zoom}\r\n transitionDuration={{ enter: 300, exit: 300 }}\r\n >\r\n <WidgetContainer\r\n ButtonComponent={ButtonComponent}\r\n active={dialogOpen}\r\n to={to}\r\n amount={cleanAmount}\r\n opReturn={opReturn}\r\n paymentId={paymentId}\r\n disablePaymentId={disablePaymentId}\r\n setAmount={setAmount}\r\n currencyObj={currencyObj}\r\n setCurrencyObj={setCurrencyObj}\r\n cryptoAmount={cryptoAmount}\r\n price={price}\r\n currency={currency}\r\n animation={animation}\r\n randomSatoshis={randomSatoshis}\r\n hideToasts={hideToasts}\r\n onSuccess={handleSuccess}\r\n onTransaction={onTransaction}\r\n successText={successText}\r\n disabled={disabled}\r\n editable={editable}\r\n goalAmount={goalAmount}\r\n wsBaseUrl={wsBaseUrl}\r\n apiBaseUrl={apiBaseUrl}\r\n hoverText={hoverText}\r\n disableAltpayment={disableAltpayment}\r\n contributionOffset={contributionOffset}\r\n foot={success && (\r\n <ButtonComponent\r\n onClick={handleWidgetClose}\r\n text=\"Close\"\r\n hoverText=\"Close\"\r\n disabled={disabled} />\r\n )} />\r\n </Dialog>\r\n </ThemeProvider>\r\n );\r\n};\r\n\r\nPaymentDialog.defaultProps = {\r\n animation: 'slide',\r\n hideToasts: false,\r\n randomSatoshis: false,\r\n successText: 'Thank you!',\r\n disableEnforceFocus: false,\r\n disabled: false,\r\n editable: false,\r\n dialogOpen: true,\r\n};\r\n\r\nexport default PaymentDialog;\r\n","import React, { useState, useEffect, useCallback, useRef } from 'react';\r\n\r\nimport { Theme, ThemeName, ThemeProvider, useTheme } from '../../themes';\r\nimport Button, { ButtonProps } from '../Button/Button';\r\n\r\nimport {\r\n Transaction,\r\n Currency,\r\n isFiat,\r\n getFiatPrice,\r\n getCurrencyTypeFromAddress,\r\n isValidCashAddress,\r\n isValidXecAddress,\r\n CurrencyObject,\r\n generatePaymentId,\r\n getCurrencyObject,\r\n isPropsTrue\r\n} from '../../util';\r\nimport { PaymentDialog } from '../PaymentDialog';\r\nexport interface PayButtonProps extends ButtonProps {\r\n to: string;\r\n amount?: number | string;\r\n opReturn?: string;\r\n disablePaymentId?: boolean;\r\n currency?: Currency;\r\n theme?: ThemeName | Theme;\r\n text?: string;\r\n hoverText?: string;\r\n successText?: string;\r\n randomSatoshis?: boolean | number | undefined;\r\n hideToasts?: boolean;\r\n disabled?: boolean;\r\n goalAmount?: number | string;\r\n disableEnforceFocus?: boolean;\r\n editable?: boolean;\r\n onSuccess?: (transaction: Transaction) => void;\r\n onTransaction?: (transaction: Transaction) => void;\r\n onOpen?: (\r\n amount?: number | string,\r\n to?: string,\r\n paymentId?: string,\r\n ) => void;\r\n onClose?: (success?: boolean, paymentId?:string) => void;\r\n wsBaseUrl?: string;\r\n apiBaseUrl?: string;\r\n disableAltpayment?:boolean\r\n contributionOffset?:number\r\n}\r\n\r\nexport const PayButton = (props: PayButtonProps): React.ReactElement => {\r\n const [dialogOpen, setDialogOpen] = useState(false);\r\n const [disabled, setDisabled] = useState(false);\r\n const [errorMsg, setErrorMsg] = useState('');\r\n const [amount, setAmount] = useState(props.amount);\r\n\r\n const [currencyObj, setCurrencyObj] = useState<CurrencyObject | undefined>();\r\n const [cryptoAmount, setCryptoAmount] = useState<string>();\r\n const [price, setPrice] = useState(0);\r\n const priceRef = useRef<number>(price);\r\n const cryptoAmountRef = useRef<string | undefined>(cryptoAmount);\r\n\r\n\r\n const {\r\n to,\r\n opReturn,\r\n disablePaymentId,\r\n currency = '' as Currency,\r\n text,\r\n hoverText,\r\n successText,\r\n animation,\r\n randomSatoshis,\r\n hideToasts,\r\n onSuccess,\r\n onTransaction,\r\n onOpen,\r\n onClose,\r\n goalAmount,\r\n disableEnforceFocus,\r\n editable,\r\n wsBaseUrl,\r\n apiBaseUrl,\r\n disableAltpayment,\r\n contributionOffset\r\n } = Object.assign({}, PayButton.defaultProps, props);\r\n\r\n const [paymentId] = useState(!disablePaymentId ? generatePaymentId(8) : undefined);\r\n\r\n useEffect(() => {\r\n priceRef.current = price;\r\n }, [price]);\r\n\r\n useEffect(() => {\r\n cryptoAmountRef.current = cryptoAmount;\r\n }, [cryptoAmount]);\r\n\r\n const waitPrice = (callback: Function) => {\r\n const intervalId = setInterval(() => {\r\n if (priceRef.current !== 0) {\r\n clearInterval(intervalId);\r\n callback();\r\n }\r\n }, 300);\r\n };\r\n const handleButtonClick = useCallback(async (): Promise<void> => {\r\n if (onOpen !== undefined) {\r\n if (isFiat(currency)) {\r\n void waitPrice(() => { onOpen(cryptoAmountRef.current, to, paymentId) })\r\n } else {\r\n onOpen(amount, to, paymentId)\r\n }\r\n }\r\n setDialogOpen(true);\r\n }, [cryptoAmount, to, paymentId, price])\r\n\r\n const handleCloseDialog = (success?: boolean, paymentId?: string): void => {\r\n if (onClose !== undefined) onClose(success, paymentId);\r\n setDialogOpen(false);\r\n };\r\n\r\n useEffect(() => {\r\n setAmount(props.amount);\r\n }, [props.amount]);\r\n\r\n useEffect(() => {\r\n const invalidAmount = props.amount !== undefined && isNaN(+props.amount);\r\n\r\n if (to !== undefined) {\r\n setDisabled(isPropsTrue(props.disabled));\r\n setErrorMsg('');\r\n } else if (invalidAmount) {\r\n setDisabled(true);\r\n setErrorMsg('Amount should be a number');\r\n } else {\r\n setDisabled(true);\r\n setErrorMsg('Invalid Recipient');\r\n }\r\n }, [to, props.amount, props.disabled]);\r\n\r\n useEffect(() => {\r\n if (!to) {\r\n setErrorMsg('Enter an address');\r\n } else if (isValidCashAddress(to)) {\r\n setErrorMsg('');\r\n } else if (isValidXecAddress(to)) {\r\n setErrorMsg('');\r\n } else {\r\n setErrorMsg('Invalid Recipient');\r\n }\r\n }, [to]);\r\n\r\n useEffect(() => {\r\n if (dialogOpen === false && props.amount && currency) {\r\n const obj = getCurrencyObject(\r\n Number(props.amount),\r\n currency,\r\n randomSatoshis,\r\n );\r\n setTimeout(() => {\r\n setAmount(obj.float);\r\n setCurrencyObj(obj);\r\n }, 300);\r\n }\r\n }, [dialogOpen, props.amount, currency, randomSatoshis]);\r\n\r\n const getPrice = useCallback(\r\n async () => {\r\n const price = await getFiatPrice(currency, to, apiBaseUrl)\r\n if (price !== null) setPrice(price)\r\n }\r\n , [currency, to, apiBaseUrl]\r\n );\r\n\r\n useEffect(() => {\r\n (async () => {\r\n if (isFiat(currency) && price === 0) {\r\n await getPrice();\r\n }\r\n })()\r\n }, [currency, getPrice, to, price]);\r\n\r\n useEffect(() => {\r\n if (currencyObj && isFiat(currency) && price) {\r\n const addressType: Currency = getCurrencyTypeFromAddress(to);\r\n const convertedObj = getCurrencyObject(\r\n currencyObj.float / price,\r\n addressType,\r\n randomSatoshis,\r\n );\r\n setCryptoAmount(convertedObj.string);\r\n } else if (!isFiat(currency)) {\r\n setCryptoAmount(amount?.toString());\r\n }\r\n }, [price, currencyObj, amount, currency, randomSatoshis, to]);\r\n\r\n const theme = useTheme(props.theme, isValidXecAddress(to ?? ''));\r\n\r\n const ButtonComponent: React.FC<ButtonProps> = (\r\n props: ButtonProps,\r\n ): React.ReactElement => <Button animation={animation} {...props} />;\r\n\r\n return (\r\n <ThemeProvider value={theme}>\r\n <ButtonComponent\r\n onClick={handleButtonClick}\r\n text={text}\r\n hoverText={hoverText}\r\n disabled={disabled}\r\n />\r\n <PaymentDialog\r\n disableEnforceFocus={disableEnforceFocus}\r\n disableScrollLock\r\n to={to ?? ''}\r\n amount={amount}\r\n opReturn={opReturn}\r\n paymentId={paymentId}\r\n disablePaymentId={disablePaymentId}\r\n setAmount={setAmount}\r\n currencyObj={currencyObj}\r\n setCurrencyObj={setCurrencyObj}\r\n cryptoAmount={cryptoAmount}\r\n price={price}\r\n currency={currency}\r\n animation={animation}\r\n randomSatoshis={randomSatoshis}\r\n hideToasts={hideToasts}\r\n onTransaction={onTransaction}\r\n onSuccess={onSuccess}\r\n successText={successText}\r\n disabled={disabled}\r\n editable={editable}\r\n goalAmount={goalAmount}\r\n dialogOpen={dialogOpen}\r\n onClose={handleCloseDialog}\r\n wsBaseUrl={wsBaseUrl}\r\n apiBaseUrl={apiBaseUrl}\r\n hoverText={hoverText}\r\n disableAltpayment={disableAltpayment}\r\n contributionOffset={contributionOffset}\r\n />\r\n {errorMsg && (\r\n <p\r\n style={{\r\n color: '#EB3B3B',\r\n fontSize: '14px',\r\n maxWidth: '190px',\r\n textAlign: 'center',\r\n }}\r\n >\r\n {errorMsg}\r\n </p>\r\n )}\r\n </ThemeProvider>\r\n );\r\n};\r\n\r\nconst payButtonDefaultProps: PayButtonProps = {\r\n to: '',\r\n animation: 'slide',\r\n hideToasts: false,\r\n randomSatoshis: false,\r\n successText: 'Thank you!',\r\n disableEnforceFocus: false,\r\n disabled: false,\r\n editable: false,\r\n};\r\n\r\nPayButton.defaultProps = payButtonDefaultProps;\r\n\r\nexport default PayButton;\r\n","import * as Components from './lib/components'\r\n\r\nexport const PayButton = Components.PayButton;\r\nexport type PayButtonProps = Components.PayButtonProps;\r\n\r\nexport const PaymentDialog = Components.PaymentDialog;\r\nexport type PaymentDialogProps = Components.PaymentDialogProps;\r\n\r\nexport const Widget = Components.Widget;\r\nexport type WidgetProps = Components.WidgetProps;\r\n"],"names":["theme","palette","secondary","tertiary","logo","themes","primary","paybutton","xec","ThemeName","DEFAULT_THEME","PAYBUTTON","ThemeContext","React","createContext","undefined","ThemeProvider","Provider","checkHash","name","startsWith","useTheme","defaultTheme","isXec","validated","XEC","validateColors","obj","regexp","RegExp","test","_useContext","useContext","getTheme","useStyles","makeStyles","container","fontSize","button","_ref","props","_objectWithoutPropertiesLoose","_excluded","_extends","background","transition","animation","backgroundSize","backgroundPosition","color","minWidth","padding","margin","boxShadow","border","borderRadius","textTransform","&:hover","& .MuiTouchRipple-root","&:disabled span","filter","Button","text","hoverText","disabled","Object","assign","defaultProps","hovering","setHovering","useState","transitioning","setTransitioning","timer","useRef","buttonRef","classes","useLayoutEffect","current","style","width","clientWidth","height","clientHeight","className","MuiButton","onClick","onMouseEnter","handleMouseEnter","clearTimeout","window","setTimeout","onMouseLeave","handleMouseLeave","ref","trim","isValidCashAddress","address","xecaddr","err","isValidXecAddress","getCurrencyTypeFromAddress","Error","FIAT_CURRENCIES","CRYPTO_CURRENCIES","DECIMALS","BCH","FIAT","CURRENCY_PREFIXES_MAP","bch","isFiat","unknownString","includes","isCrypto","getFiatPrice","async","currency","to","apiBaseUrl","rootUrl","data","axios","get","_","lowerCase","price","getBchFiatPrice","getXecFiatPrice","error","console","log","root","lib","version","settings","symbol","format","decimal","thousand","precision","grouping","number","nativeMap","Array","prototype","map","nativeIsArray","isArray","toString","isString","charCodeAt","substr","call","isObject","defaults","object","defs","key","hasOwnProperty","iterator","context","i","j","results","length","checkPrecision","val","base","Math","round","abs","isNaN","checkCurrencyFormat","match","pos","neg","replace","zero","unformat","parse","value","regex","unformatted","parseFloat","toFixed","power","pow","formatNumber","opts","usePrecision","negative","parseInt","mod","split","formatMoney","formats","formatColumn","list","padAfterSymbol","indexOf","maxLength","formatted","fVal","join","module","exports","getOwnPropertySymbols","propIsEnumerable","propertyIsEnumerable","toObject","TypeError","test1","String","getOwnPropertyNames","test2","fromCharCode","n","test3","forEach","letter","keys","shouldUseNative","target","source","from","symbols","s","arguments","AD","AE","AF","AG","AI","AL","AM","AN","AO","AR","AS","AT","AU","AW","AX","AZ","BA","BB","BD","BE","BF","BG","BH","BI","BJ","BL","BM","BN","BO","BQ","BR","BS","BT","BV","BW","BY","BZ","CA","CC","CD","CF","CG","CH","CI","CK","CL","CM","CN","CO","CR","CU","CV","CW","CX","CY","CZ","DE","DJ","DK","DM","DO","DZ","EC","EE","EG","EH","ER","ES","ET","FI","FJ","FK","FM","FO","FR","GA","GB","GD","GE","GF","GG","GH","GI","GL","GM","GN","GP","GQ","GR","GS","GT","GU","GW","GY","HK","HM","HN","HR","HT","HU","ID","IE","IL","IM","IN","IO","IQ","IR","IS","IT","JE","JM","JO","JP","KE","KG","KH","KI","KM","KN","KP","KR","KW","KY","KZ","LA","LB","LC","LI","LK","LR","LS","LT","LU","LV","LY","MA","MC","MD","ME","MF","MG","MH","MK","ML","MM","MN","MO","MP","MQ","MR","MS","MT","MU","MV","MW","MX","MY","MZ","NA","NC","NE","NF","NG","NI","NL","NO","NP","NR","NU","NZ","OM","PA","PE","PF","PG","PH","PK","PL","PM","PN","PR","PS","PT","PW","PY","QA","RE","RO","RS","RU","RW","SA","SB","SC","SD","SE","SG","SH","SI","SJ","SK","SL","SM","SN","SO","SR","ST","SV","SX","SY","SZ","TC","TD","TF","TG","TH","TJ","TK","TL","TM","TN","TO","TR","TT","TV","TW","TZ","UA","UG","UM","US","UY","UZ","VA","VC","VE","VG","VI","VN","VU","WF","WS","YE","YT","ZA","ZM","ZW","locale","localeString","components","countryCode","pop","toUpperCase","defaultCurrency","thousandsSeparator","decimalSeparator","symbolOnLeft","spaceBetweenAmountAndSymbol","decimalDigits","defaultLocaleFormat","formatMapping","findCurrency","currencyCode","currencies","isUndefined","options","code","localeCurrency","localeMatch","exec","language","localeFormat","localeFormats","f","accounting","formatPrice","currencyType","Intl","NumberFormat","currencyDisplay","minimumFractionDigits","maximumFractionDigits","isPropsTrue","generatePaymentId","bytesAmount","wordArray","WordArray","random","enc","Hex","stringify","getNSatoshis","amount","randomSatoshis","satsPrecision","amountDigits","min","BigNumber","resolveNumber","getCurrencyObject","string","float","newAmount","randomizeSatoshis","addressType","nSatoshis","randomizedAmount","ret","floor","max","multiplier","decimals","primaryUnit","c","currencyFormat","SideshiftClient","[object Object]","shiftId","res","fetch","Date","getTime","json","BarChart","barWidth","setBarWidth","blurCSS","bar","left","top","bottom","backgroundColor","position","useEffect","marginBottom","copyIcon","AltpaymentWidget","altpaymentSocket","setUseAltpayment","altpaymentShift","setAltpaymentShift","shiftCompleted","setShiftCompleted","altpaymentError","setAltpaymentError","coins","loadingPair","loadingShift","coinPair","setCoinPair","altpaymentEditable","thisAmount","updateAmount","setLoadingPair","setLoadingShift","pairAmountMaxLength","setPairAmountMaxLength","isAboveMinimumAltpaymentAmount","setIsAboveMinimumAltpaymentAmount","isBelowMaximumAltpaymentAmount","setIsBelowMaximumAltpaymentAmount","selectedCoin","setSelectedCoin","selectedCoinNetwork","setSelectedCoinNetwork","pairAmountFixedDecimals","setPairAmountFixedDecimals","pairAmount","setPairAmount","networks","bigNumber","rate","tokenDetails","amountString","floorAmount","nonDecimalCharCount","ceil","log10","resetTrade","copyToClipboard","elementId","contentElement","document","getElementById","copiedMessage","createElement","textContent","alignItems","zIndex","display","navigator","clipboard","writeText","appendChild","parentElement","removeChild","select_box","option_outer_ctn","option_ctn","flexDirection","list_icon","marginRight","coin","fontWeight","lineHeight","coin_name","spacer","sideshift_ctn","paddingTop","header","& img","marginTop","back_link","cursor","opacity","shift_ready","& h4","borderBottom","paddingBottom","textAlign","copy_ctn","& > div","editAmount","& span","marginLeft","amount_error","error_msg","shift_label","shift_input","wordBreak","flexGrow","copy_btn","alignSelf","shift_complete","flex","checkCoin","coinString","toLowerCase","Typography","component","errorMessage","id","depositAmount","depositCoin","src","alt","depositAddress","settleCoin","Grid","spacing","justifyContent","item","TextField","label","onChange","e","settleCoinAmount","inputProps","type","pattern","inputMode","handleCreateQuoteButtonClick","emit","depositNetwork","settleAddress","href","FormControl","InputLabel","Select","labelId","_selectedCoin$coin","coinName","find","handleCoinChange","MenuItem","handleNetworkChange","network","charAt","slice","handleGetRateButtonClick","requestPairRate","qrCode","success","loading","outline","maxWidth","maxHeight","userSelect","&:active","borderWidth","& path","& image","copyTextContainer","copyText","textShadow","spinner","footer","sideShiftLink","animate_sideshift","animationDelay","hide_sideshift","@global","@keyframes reveal-qr","clipPath","transform","@keyframes fade-scale","80%","@keyframes button-slide","@keyframes button-slide-out","@keyframes copy-qr","0%","50%","100%","@keyframes copy-svg","@keyframes copy-icon","@keyframes success-qr","@keyframes success-icon","20%","60%","qrAnimations","recentlyCopied","copied","& svg","transformOrigin","button_container","Widget","foot","paymentId","successText","disablePaymentId","goalAmount","ButtonComponent","editable","setNewTxs","newTxs","usdPrice","wsBaseUrl","useAltpayment","disableAltpayment","contributionOffset","setLoading","setCopied","setRecentlyCopied","totalReceived","setTotalReceived","setDisabled","errorMsg","setErrorMsg","goalText","setGoalText","goalPercent","setGoalPercent","socket","setSocket","setAddressType","_props$price","url","setUrl","userEditedAmount","setUserEditedAmount","setText","widgetButtonText","setWidgetButtonText","opReturn","setOpReturn","setAltpaymentSocket","setCoins","setAltpaymentEditable","isAboveMinimumAltpaymentUSDAmount","setIsAboveMinimumAltpaymentUSDAmount","setThisAmount","hasPrice","setHasPrice","thisCurrencyObject","setThisCurrencyObject","currencyObject","bchSvg","useMemo","_theme$palette$logo","encodeURIComponent","checkSvg","_theme$palette$logo2","getAddressDetails","disconnect","newSocket","io","forceNew","query","addresses","dummy","txsListener","on","broadcastedTxData","unconfirmedTxs","txs","tx","confirmed","messageType","setupTxsSocket","params","shift","pair","setupAltpaymentSocket","balance","getAddressBalance","invalidAmount","isNegativeNumber","cleanAmount","setCurrencyObject","convertedAmount","convertedObj","_url","resolveUrl","_url2","notZeroValue","dataPushdata","bytesQuantity","Blob","size","bytesLimit","rawPushdata","padStart","getDataPushdata","pushDataPrefixedPaymentId","hexString","prependPaymentIdWithPushdata","_paymentId","OP_RETURN_PREFIX_PUSHDATA","str","encoded","TextEncoder","encode","byte","stringToHex","encodeOpReturnProps","message","progress","goal","cleanGoalAmount","receivedVal","receivedRatio","receivedPercentage","progressFloat","Number","shouldDisplayGoal","handleQrCodeClick","useCallback","copy","prefix","thisUrl","separator","qrCodeProps","renderAs","level","fgColor","imageSettings","excavate","QRCode","setAmount","Box","pt","py","px","CircularProgress","thickness","Fade","in","Fragment","right","appear","timeout","enter","exit","userEdited","maxlength","placeholder","handleButtonClick","getCashtabProviderStatus","windowAny","bitcoinAbc","postMessage","txInfo","bip21","open","location","tradeWithAltpayment","snackbarOptions","variant","autoHideDuration","anchorOrigin","vertical","horizontal","WidgetContainer","Component","setCurrencyObj","currencyObj","cryptoAmount","hideToasts","sound","onSuccess","onTransaction","widgetProps","thisPaymentId","setThisPaymentId","thisPrice","setThisPrice","setUsdPrice","newPaymentId","setSuccess","enqueueSnackbar","useSnackbar","paymentClient","addrType","txSound","Audio","handlePayment","getPaymentStatus","status","play","catch","transaction","expectedAmount","receivedAmount","expectedPaymentId","expectedOpReturn","rawMessage","rawOpReturn","isAmountValid","transactionCurrency","isEqualTo","shouldTriggerOnSuccess","currencyTicker","getPrice","handleNewTransaction","isLessThan","SnackbarProvider","PaymentDialog","onClose","disableEnforceFocus","dialogOpen","handleWidgetClose","Dialog","disableScrollLock","TransitionComponent","Zoom","transitionDuration","active","PayButton","setDialogOpen","setCryptoAmount","setPrice","priceRef","cryptoAmountRef","onOpen","callback","intervalId","setInterval","clearInterval","waitPrice","handleCloseDialog","Components"],"mappings":"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I,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI,MACJC,GAAI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"}