import { useMutation, useQuery, gql } from '@apollo/client' import classnames from 'classnames' import React, { useState } from 'react' import { HelpTooltip } from '../../../components/Tooltip' import { H1, H4, Label1, P } from '../../../components/typography' import FormRenderer from '../../Services/FormRenderer' import WarningIcon from '../../../styling/icons/warning-icon/comet.svg?react' import { Button, SupportLinkButton } from '../../../components/buttons' import { RadioGroup } from '../../../components/inputs' import twilio from '../../Services/schemas/twilio' import sharedClasses from './Wallet/Shared.module.css' import classes from './Twilio.module.css' const GET_CONFIG = gql` { config accounts } ` const SAVE_ACCOUNTS = gql` mutation Save($accounts: JSONObject) { saveAccounts(accounts: $accounts) } ` const options = [ { code: 'enable', display: 'Yes, I will', }, { code: 'disable', display: 'No, not for now', }, ] function Twilio({ doContinue }) { const [selected, setSelected] = useState(null) const [error, setError] = useState(false) const { data, refetch } = useQuery(GET_CONFIG) const [saveAccounts] = useMutation(SAVE_ACCOUNTS, { onCompleted: doContinue, }) const accounts = data?.accounts ?? [] const onSelect = e => { setSelected(e.target.value) setError(false) } const clickContinue = () => { if (!selected) return setError(true) doContinue() } const save = twilio => { const accounts = { twilio } return saveAccounts({ variables: { accounts } }).then(() => refetch()) } const titleClasses = { 'ml-2 mb-2': true, [sharedClasses.error]: error, } return (

Twilio (SMS service)

Will you setup a two way machine or compliance?

Two-way machines allow your customers not only to buy (cash-in) but also sell cryptocurrencies (cash-out).

You’ll need an SMS service for cash-out transactions and for any compliance triggers

To set up Twilio please read the instructions from our support portal.
{selected === 'enable' && ( <>

Enter credentials

)} {selected !== 'enable' && ( )}
) } export default Twilio