diff --git a/.storybook/locale.ts b/.storybook/locale.ts index 3ebb3da8ccca..20dd5535a22b 100644 --- a/.storybook/locale.ts +++ b/.storybook/locale.ts @@ -31,6 +31,8 @@ const locale: Record = { backupWalletTitle: 'Backup Wallet', balanceUnavailable: 'Unavailable', bat: 'BAT', + batPoints: 'BAT Points', + batPointsMessage: 'can be used in Brave Rewards to contribute to your favorite content creators. BAT Points cannot be exchanged for BAT.', braveAdsDesc: 'No action required. Just collect tokens. Your data is safe with our Shields.', braveAdsTitle: 'Brave Ads', braveAdsLaunchTitle: 'Brave Ads has arrived!', @@ -294,6 +296,7 @@ const locale: Record = { whyBraveRewardsDesc1: 'With conventional browsers, you pay to browse the web by viewing ads with your valuable attention, spending your valuable time downloading invasive ad technology, that transmits your valuable private data to advertisers — without your consent.', whyBraveRewardsDesc2: 'Well, you\'ve come to the right place. Brave welcomes you to the new internet. One where your time is valued, your personal data is kept private, and you actually get paid for your attention.', whyHow: 'Why & How', + yourBalance: 'Your Balance', yourWallet: 'Your wallet' } diff --git a/browser/ui/webui/brave_webui_source.cc b/browser/ui/webui/brave_webui_source.cc index c4f2984a069d..dc5b5d03c54c 100644 --- a/browser/ui/webui/brave_webui_source.cc +++ b/browser/ui/webui/brave_webui_source.cc @@ -234,6 +234,8 @@ void CustomizeWebUIHTMLSource(const std::string &name, { "adsTitle", IDS_BRAVE_REWARDS_LOCAL_ADS_TITLE }, { "bat", IDS_BRAVE_UI_BAT_REWARDS_TEXT }, + { "batPoints", IDS_BRAVE_UI_BAT_POINTS_TEXT }, + { "batPointsMessage", IDS_BRAVE_UI_POINTS_MESSAGE }, { "contributionTitle", IDS_BRAVE_REWARDS_LOCAL_CONTR_TITLE }, { "contributionDesc", IDS_BRAVE_REWARDS_LOCAL_CONTR_DESC }, { "contributionMonthly", IDS_BRAVE_REWARDS_LOCAL_CONTR_MONTHLY }, @@ -535,6 +537,7 @@ void CustomizeWebUIHTMLSource(const std::string &name, { "whyBraveRewards", IDS_BRAVE_UI_WHY_BRAVE_REWARDS }, { "whyBraveRewardsDesc1", IDS_BRAVE_UI_WHY_BRAVE_REWARDS_DESC_1 }, { "whyBraveRewardsDesc2", IDS_BRAVE_UI_WHY_BRAVE_REWARDS_DESC_2 }, + { "yourBalance", IDS_BRAVE_UI_YOUR_BALANCE }, { "yourWallet", IDS_BRAVE_UI_YOUR_WALLET }, { "and", IDS_BRAVE_UI_AND }, diff --git a/components/brave_rewards/resources/extension/brave_rewards/_locales/en_US/messages.json b/components/brave_rewards/resources/extension/brave_rewards/_locales/en_US/messages.json index 1920159b131a..da119d4a1323 100644 --- a/components/brave_rewards/resources/extension/brave_rewards/_locales/en_US/messages.json +++ b/components/brave_rewards/resources/extension/brave_rewards/_locales/en_US/messages.json @@ -43,6 +43,22 @@ "message": "Grants", "description": "Title for grant section in wallet summary" }, + "details": { + "message": "Details", + "description": "Title for grant section in wallet panel summary" + }, + "yourBalance": { + "message": "Your Balance", + "description": "Wallet panel title for anon wallets" + }, + "batPoints": { + "message": "BAT Points", + "description": "BAT Points text" + }, + "batPointsMessage": { + "message": "can be used in Brave Rewards to contribute to your favorite content creators. BAT Points cannot be exchanged for BAT.", + "description": "Text for BAT Point helper message" + }, "on": { "message": "on", "description": "The whole string is 'Enable tips on YouTube for like.'" @@ -306,7 +322,7 @@ "description": "Text for the link that explains more about reserved amount" }, "reservedAmountText": { - "message": "You’ve designated {{reservedAmount}} BAT for creators who haven’t yet signed up to receive contributions. Your browser will keep trying to contribute until they verify, or until 90 days have passed.", + "message": "You’ve designated {{reservedAmount}} {{currency}} for creators who haven’t yet signed up to receive contributions. Your browser will keep trying to contribute until they verify, or until 90 days have passed.", "description": "Notification about how much BAT do you have reserved" }, "reservedMoreLink": { diff --git a/components/brave_rewards/resources/extension/brave_rewards/background/api/locale_api.ts b/components/brave_rewards/resources/extension/brave_rewards/background/api/locale_api.ts index e7e50da0ce20..29833300f30e 100644 --- a/components/brave_rewards/resources/extension/brave_rewards/background/api/locale_api.ts +++ b/components/brave_rewards/resources/extension/brave_rewards/background/api/locale_api.ts @@ -28,6 +28,8 @@ export const getUIMessages = (): Record => { 'backupWalletNotification', 'backupWalletTitle', 'bat', + 'batPoints', + 'batPointsMessage', 'braveAdsLaunchTitle', 'braveAdsLaunchMsg', 'braveAdsTitle', @@ -133,7 +135,8 @@ export const getUIMessages = (): Record => { 'walletVerificationListHeader', 'walletVerificationTitle1', 'walletVerificationTitle2', - 'walletVerified' + 'walletVerified', + 'yourBalance' ] let translations = {} diff --git a/components/brave_rewards/resources/extension/brave_rewards/components/app.tsx b/components/brave_rewards/resources/extension/brave_rewards/components/app.tsx index b78359acd872..9f0b7b3affe9 100644 --- a/components/brave_rewards/resources/extension/brave_rewards/components/app.tsx +++ b/components/brave_rewards/resources/extension/brave_rewards/components/app.tsx @@ -298,6 +298,7 @@ export class RewardsPanel extends React.Component { balance={total.toFixed(1)} showSecActions={false} showCopy={false} + onlyAnonWallet={this.state.onlyAnonWallet} grants={utils.getGrants(walletProperties.grants)} converted={utils.formatConverted(converted)} convertProbiToFixed={utils.convertProbiToFixed} diff --git a/components/brave_rewards/resources/extension/brave_rewards/components/panel.tsx b/components/brave_rewards/resources/extension/brave_rewards/components/panel.tsx index acff84120088..efad1a90c900 100644 --- a/components/brave_rewards/resources/extension/brave_rewards/components/panel.tsx +++ b/components/brave_rewards/resources/extension/brave_rewards/components/panel.tsx @@ -673,6 +673,7 @@ export class Panel extends React.Component { onDisconnectClick={this.onDisconnectClick} goToUphold={this.goToUphold} userName={utils.getUserName(externalWallet)} + onlyAnonWallet={this.props.onlyAnonWallet} {...notification} > { diff --git a/components/brave_rewards/resources/page/components/grant.tsx b/components/brave_rewards/resources/page/components/grant.tsx index b9be2c57fde8..7011bc8c4a65 100644 --- a/components/brave_rewards/resources/page/components/grant.tsx +++ b/components/brave_rewards/resources/page/components/grant.tsx @@ -26,6 +26,7 @@ interface State { interface Props extends Rewards.ComponentProps { grant: Rewards.Grant + onlyAnonWallet?: boolean } // TODO add local when we know what we will get from the server @@ -139,6 +140,7 @@ class Grant extends React.Component { let title = getLocale('grantFinishTitleUGP') let text = getLocale('grantFinishTextUGP') let tokenTitle = getLocale('grantFinishTokenUGP') + const { onlyAnonWallet } = this.props if (type === 'ads') { title = getLocale('grantFinishTitleAds') @@ -159,6 +161,7 @@ class Grant extends React.Component { date={date} testId={'newTokenGrant'} tokenTitle={tokenTitle} + onlyAnonWallet={onlyAnonWallet} /> ) diff --git a/components/brave_rewards/resources/page/components/pageWallet.tsx b/components/brave_rewards/resources/page/components/pageWallet.tsx index 15e0f9a0cc05..dfc3bbde06c0 100644 --- a/components/brave_rewards/resources/page/components/pageWallet.tsx +++ b/components/brave_rewards/resources/page/components/pageWallet.tsx @@ -224,7 +224,8 @@ class PageWallet extends React.Component { const { walletRecoverySuccess, walletServerProblem, - walletCorrupted + walletCorrupted, + onlyAnonWallet } = this.props.rewardsData.ui if (walletServerProblem) { @@ -235,8 +236,10 @@ class PageWallet extends React.Component { } if (walletRecoverySuccess) { + const batFormatString = onlyAnonWallet ? getLocale('batPoints') : getLocale('bat') + return { - node: <>{getLocale('walletRestored')} {getLocale('walletRecoverySuccess', { balance: total.toString() })}, + node: <>{getLocale('walletRestored')} {getLocale('walletRecoverySuccess', { balance: total.toString(), currency: batFormatString })}, type: 'success', onAlertClose: () => { this.actions.onClearAlert('walletRecoverySuccess') @@ -506,6 +509,7 @@ class PageWallet extends React.Component { onDisconnectClick={this.onDisconnectClick} goToUphold={this.goToUphold} userName={this.getUserName()} + onlyAnonWallet={onlyAnonWallet} > { enabledMain @@ -513,6 +517,7 @@ class PageWallet extends React.Component { ? : diff --git a/components/brave_rewards/resources/page/components/settingsPage.tsx b/components/brave_rewards/resources/page/components/settingsPage.tsx index e1ea8149438f..e30050e64323 100644 --- a/components/brave_rewards/resources/page/components/settingsPage.tsx +++ b/components/brave_rewards/resources/page/components/settingsPage.tsx @@ -142,7 +142,7 @@ class SettingsPage extends React.Component { } getGrantClaims = () => { - const { grants } = this.props.rewardsData + const { grants, ui } = this.props.rewardsData if (!grants) { return null @@ -157,7 +157,7 @@ class SettingsPage extends React.Component { return (
- +
) })} diff --git a/components/brave_rewards/resources/ui/components/grantComplete/index.tsx b/components/brave_rewards/resources/ui/components/grantComplete/index.tsx index b3731728d674..41fc822ac015 100644 --- a/components/brave_rewards/resources/ui/components/grantComplete/index.tsx +++ b/components/brave_rewards/resources/ui/components/grantComplete/index.tsx @@ -22,17 +22,19 @@ export interface Props { date: string isMobile?: boolean tokenTitle?: string + onlyAnonWallet?: boolean } export default class GrantComplete extends React.PureComponent { render () { - const { id, testId, onClose, amount, date, isMobile, tokenTitle } = this.props + const { id, testId, onClose, amount, date, isMobile, tokenTitle, onlyAnonWallet } = this.props + const batFormatString = onlyAnonWallet ? getLocale('batPoints') : getLocale('bat') return ( {tokenTitle} - {amount} BAT + {amount} {batFormatString} { date && date.length > 0 ? <> diff --git a/components/brave_rewards/resources/ui/components/listToken/index.tsx b/components/brave_rewards/resources/ui/components/listToken/index.tsx index 039323fb114f..0bc86481aca4 100644 --- a/components/brave_rewards/resources/ui/components/listToken/index.tsx +++ b/components/brave_rewards/resources/ui/components/listToken/index.tsx @@ -16,6 +16,7 @@ export interface Props { color?: Type border?: 'first' | 'last' | 'default' testId?: string + onlyAnonWallet?: boolean } export default class ListToken extends React.PureComponent { @@ -24,7 +25,7 @@ export default class ListToken extends React.PureComponent { } render () { - const { id, title, value, converted, isNegative, size, color, border, testId } = this.props + const { id, title, value, converted, isNegative, size, color, border, testId, onlyAnonWallet } = this.props return ( @@ -36,6 +37,7 @@ export default class ListToken extends React.PureComponent { isNegative={isNegative} size={size} color={color} + onlyAnonWallet={onlyAnonWallet} /> diff --git a/components/brave_rewards/resources/ui/components/listToken/style.ts b/components/brave_rewards/resources/ui/components/listToken/style.ts index 34e756dac13e..5ac459a826a2 100644 --- a/components/brave_rewards/resources/ui/components/listToken/style.ts +++ b/components/brave_rewards/resources/ui/components/listToken/style.ts @@ -23,13 +23,13 @@ export const StyledTitle = styled<{}, 'div'>('div')` color: #4b4c5c; flex-grow: 1; flex-shrink: 1; - flex-basis: 60%; + flex-basis: 40%; ` export const StyledContentWrapper = styled<{}, 'div'>('div')` flex-grow: 1; flex-shrink: 1; - flex-basis: 40%; + flex-basis: 50%; text-align: right; @media (max-width: 385px) { diff --git a/components/brave_rewards/resources/ui/components/tokens/index.tsx b/components/brave_rewards/resources/ui/components/tokens/index.tsx index 161cf26aa2cb..c280d342d561 100644 --- a/components/brave_rewards/resources/ui/components/tokens/index.tsx +++ b/components/brave_rewards/resources/ui/components/tokens/index.tsx @@ -3,6 +3,7 @@ * You can obtain one at http://mozilla.org/MPL/2.0/. */ import * as React from 'react' +import { getLocale } from 'brave-ui/helpers' import { StyledWrapper, StyledTokens, StyledContent, StyledTokenValue, StyledTokenCurrency } from './style' export type Size = 'mini' | 'small' | 'normal' @@ -17,6 +18,7 @@ export interface Props { isNegative?: boolean size?: Size color?: Type + onlyAnonWallet?: boolean } export default class Tokens extends React.PureComponent { @@ -28,7 +30,8 @@ export default class Tokens extends React.PureComponent { } render () { - const { id, converted, value, hideText, isNegative, size, color, currency } = this.props + const { id, converted, value, hideText, isNegative, size, color, currency, onlyAnonWallet } = this.props + const batFormatString = onlyAnonWallet ? getLocale('batPoints') : getLocale('bat') return ( @@ -38,7 +41,9 @@ export default class Tokens extends React.PureComponent { { !hideText - ? BAT + ? + {batFormatString} + : null } diff --git a/components/brave_rewards/resources/ui/components/tokens/style.ts b/components/brave_rewards/resources/ui/components/tokens/style.ts index f88f859e62ca..312eda0cf810 100644 --- a/components/brave_rewards/resources/ui/components/tokens/style.ts +++ b/components/brave_rewards/resources/ui/components/tokens/style.ts @@ -5,6 +5,10 @@ import styled, { css } from 'styled-components' import { Props, Size, Type } from './index' +interface StyleProps { + isAnon?: boolean +} + const sizes: Record = { mini: { text: '14px', @@ -63,8 +67,15 @@ export const StyledContent = styled<{}, 'span'>('span')` margin-left: 8px; ` -export const StyledTokenCurrency = styled<{}, 'span'>('span')` +export const StyledTokenCurrency = styled('span')` font-size: var(--tokens-token-size); display: inline-block; margin-left: 4px; + ${(p) => { + if (!p.isAnon) { + return 'text-transform: uppercase;' + } + + return null + }} ` diff --git a/components/brave_rewards/resources/ui/components/walletSummary/index.tsx b/components/brave_rewards/resources/ui/components/walletSummary/index.tsx index 5de61e44ce76..b39a809d7881 100644 --- a/components/brave_rewards/resources/ui/components/walletSummary/index.tsx +++ b/components/brave_rewards/resources/ui/components/walletSummary/index.tsx @@ -14,7 +14,8 @@ import { StyledNoActivityWrapper, StyledReservedWrapper, StyledReservedLink, - StyledAllReserved + StyledAllReserved, + StyledBatPoints } from './style' import ListToken from '../listToken' import { Type } from '../tokens' @@ -41,11 +42,13 @@ export interface Props { compact?: boolean reservedAmount?: number reservedMoreLink?: string + onlyAnonWallet?: boolean onSeeAllReserved?: () => void } export default class WalletSummary extends React.PureComponent { generateList = () => { + const { onlyAnonWallet } = this.props const tokenSize = this.props.compact ? 'small' : 'normal' const list = [ { @@ -101,6 +104,7 @@ export default class WalletSummary extends React.PureComponent { color={item.color as Type} title={getLocale(item.translation)} isNegative={item.negative} + onlyAnonWallet={onlyAnonWallet} border={all === current ? 'last' : undefined} /> )) @@ -120,14 +124,56 @@ export default class WalletSummary extends React.PureComponent { return result } + generateInfo = () => { + const { + reservedAmount, + onlyAnonWallet, + onSeeAllReserved, + reservedMoreLink + } = this.props + const showReserved = reservedAmount && reservedAmount > 0 + + if (!onlyAnonWallet && !showReserved) { + return null + } + + const amount = (reservedAmount && reservedAmount.toFixed(1)) || '0.0' + const batFormatString = onlyAnonWallet ? getLocale('batPoints') : getLocale('bat') + + return ( + + { + onlyAnonWallet + ?

+ {getLocale('batPoints')} {getLocale('batPointsMessage')} +

+ : null + } + { + showReserved + ? <> + {getLocale('reservedAmountText', { reservedAmount: amount, currency: batFormatString })} + {getLocale('reservedMoreLink')} + + { + onSeeAllReserved + ? + {getLocale('reservedAllLink')} + + : null + } + + : null + } +
+ ) + } + render () { const { id, onActivity, - compact, - reservedAmount, - reservedMoreLink, - onSeeAllReserved + compact } = this.props const date = new Date() const month = getLocale(`month${date.toLocaleString('en-us', { month: 'short' })}`) @@ -143,22 +189,7 @@ export default class WalletSummary extends React.PureComponent { {month} {year}
{this.generateList()} - { - reservedAmount && reservedAmount > 0 - ? - {getLocale('reservedAmountText', { reservedAmount: reservedAmount.toFixed(1) })} - {getLocale('reservedMoreLink')} - - { - onSeeAllReserved - ? - {getLocale('reservedAllLink')} - - : null - } - - : null - } + {this.generateInfo()}
{ onActivity diff --git a/components/brave_rewards/resources/ui/components/walletSummary/style.ts b/components/brave_rewards/resources/ui/components/walletSummary/style.ts index cb4c46c1e570..c8927088a8c8 100644 --- a/components/brave_rewards/resources/ui/components/walletSummary/style.ts +++ b/components/brave_rewards/resources/ui/components/walletSummary/style.ts @@ -104,3 +104,7 @@ export const StyledAllReserved = styled('button')` color: ${palette.blue400}; cursor: pointer; ` + +export const StyledBatPoints = styled<{}, 'span'>('span')` + font-weight: 600; +` diff --git a/components/brave_rewards/resources/ui/components/walletWrapper/index.tsx b/components/brave_rewards/resources/ui/components/walletWrapper/index.tsx index c1abf9c80775..bcdf78744d37 100644 --- a/components/brave_rewards/resources/ui/components/walletWrapper/index.tsx +++ b/components/brave_rewards/resources/ui/components/walletWrapper/index.tsx @@ -148,6 +148,7 @@ export interface Props { onDisconnectClick?: () => void goToUphold?: () => void userName?: string + onlyAnonWallet?: boolean } export type Step = '' | 'captcha' | 'complete' @@ -579,7 +580,8 @@ export default class WalletWrapper extends React.PureComponent { isMobile, convertProbiToFixed, onVerifyClick, - onDisconnectClick + onDisconnectClick, + onlyAnonWallet } = this.props const hasGrants = this.hasGrants(grants) @@ -596,6 +598,7 @@ export default class WalletWrapper extends React.PureComponent { const walletVerified = walletState === 'verified' || walletState === 'disconnected_verified' const connectedVerified = walletState === 'verified' + const batFormatString = onlyAnonWallet ? getLocale('batPoints') : getLocale('bat') return ( <> @@ -618,7 +621,7 @@ export default class WalletWrapper extends React.PureComponent { title={grant.finishTitle || ''} text={grant.finishText} > - + : null } @@ -648,9 +651,9 @@ export default class WalletWrapper extends React.PureComponent { : null } { - walletState + walletState && !onlyAnonWallet ? this.generateWalletButton(walletState) - : {getLocale('yourWallet')} + : {getLocale('yourBalance')} } { showSecActions @@ -661,7 +664,7 @@ export default class WalletWrapper extends React.PureComponent { } - {balance} BAT + {balance} {batFormatString} { converted @@ -689,7 +692,7 @@ export default class WalletWrapper extends React.PureComponent { { grants && grants.map((grant: Grant, i: number) => { return - {grant.tokens} BAT + {grant.tokens} {batFormatString} { grant.type === 'ads' ? {getLocale('adsEarnings')} @@ -715,7 +718,7 @@ export default class WalletWrapper extends React.PureComponent { {children} { - showCopy + showCopy && !onlyAnonWallet ? { walletVerified @@ -748,7 +751,7 @@ export default class WalletWrapper extends React.PureComponent { }
{ - showCopy + showCopy && !onlyAnonWallet ? {getLocale('rewardsPanelText3')} {getLocale('rewardsPanelText4')} diff --git a/components/brave_rewards/resources/ui/components/walletWrapper/style.ts b/components/brave_rewards/resources/ui/components/walletWrapper/style.ts index 76c47405969d..5f911ee15910 100644 --- a/components/brave_rewards/resources/ui/components/walletWrapper/style.ts +++ b/components/brave_rewards/resources/ui/components/walletWrapper/style.ts @@ -56,10 +56,11 @@ export const StyledHeader = styled<{}, 'div'>('div')` export const StyledTitle = styled<{}, 'div'>('div')` font-size: 16px; - font-weight: 500; + font-weight: bold; line-height: 1.38; - letter-spacing: -0.2px; + letter-spacing: 0.5px; color: rgba(255, 255, 255, 0.65); + margin-bottom: 30px; ` export const StyledBalance = styled<{}, 'div'>('div')` diff --git a/components/brave_rewards/resources/ui/stories/concepts.tsx b/components/brave_rewards/resources/ui/stories/concepts.tsx index 0bd45d11e2ae..9e4ccf88f81e 100644 --- a/components/brave_rewards/resources/ui/stories/concepts.tsx +++ b/components/brave_rewards/resources/ui/stories/concepts.tsx @@ -493,6 +493,7 @@ storiesOf('Rewards/Concepts/Desktop', module) onVerifyClick={onVerifyClick} onDisconnectClick={onDisconnectClick} userName={text('user name', 'jennrhim')} + onlyAnonWallet={boolean('Anon Wallet Only', false)} > diff --git a/components/brave_rewards/resources/ui/stories/settings/pageWallet.tsx b/components/brave_rewards/resources/ui/stories/settings/pageWallet.tsx index f62e51a24571..233dbcf69f50 100644 --- a/components/brave_rewards/resources/ui/stories/settings/pageWallet.tsx +++ b/components/brave_rewards/resources/ui/stories/settings/pageWallet.tsx @@ -268,6 +268,7 @@ class PageWallet extends React.Component { onSettingsClick={this.onBackupModalOpen} onActivityClick={doNothing} showCopy={true} + onlyAnonWallet={false} showSecActions={true} grants={grants} walletState={walletState} @@ -287,6 +288,7 @@ class PageWallet extends React.Component { tips: { tokens: '19.0', converted: '5.25' } }} onActivity={this.onActivity} + onlyAnonWallet={false} /> : null } diff --git a/components/brave_rewards/resources/ui/stories/wallet.tsx b/components/brave_rewards/resources/ui/stories/wallet.tsx index d4efa51800de..047da865d82d 100644 --- a/components/brave_rewards/resources/ui/stories/wallet.tsx +++ b/components/brave_rewards/resources/ui/stories/wallet.tsx @@ -54,6 +54,7 @@ storiesOf('Rewards/Wallet/Desktop', module) onNotificationClick={onEnableAds} notification={boolean('Show notification', true) ? adsLaunchNotification : undefined} showCopy={boolean('Show Uphold', false)} + onlyAnonWallet={boolean('Anon Wallet Only', false)} showSecActions={boolean('Show secondary actions', true)} balance={text('Balance', '25.0')} converted={text('Converted', '163230.50 USD')} @@ -118,6 +119,7 @@ storiesOf('Rewards/Wallet/Desktop', module) reservedAmount={number('Reserved amount', 52)} reservedMoreLink={'https://brave.com'} onSeeAllReserved={doNothing} + onlyAnonWallet={boolean('Anon Wallet Only', false)} /> ) diff --git a/components/resources/brave_components_strings.grd b/components/resources/brave_components_strings.grd index 25d8dbfb6859..bb20b341e3c6 100644 --- a/components/resources/brave_components_strings.grd +++ b/components/resources/brave_components_strings.grd @@ -221,6 +221,8 @@ 4 ads per hour 5 ads per hour BAT + BAT Points + can be used in Brave Rewards to contribute to your favorite content creators. BAT Points cannot be exchanged for BAT. The device is offline, please try again later. Monthly Payment Next contribution date @@ -256,7 +258,7 @@ Twitter Tip on the spot as you find gems. Support your favorite sites with recurring monthly tips. - {{balance}} BAT was recovered. Your wallet key has been verified and loaded successfully. + {{balance}} {{currency}} was recovered. Your wallet key has been verified and loaded successfully. Wallet restored! Please re-enter keys or try different keys. Almost there… @@ -457,7 +459,7 @@ Tip {{ user }} remove Remove From Saved - You’ve designated {{reservedAmount}} BAT for creators who haven’t yet signed up to receive contributions. Your browser will keep trying to contribute until they verify, or until 90 days have passed. + You’ve designated {{reservedAmount}} {{currency}} for creators who haven’t yet signed up to receive contributions. Your browser will keep trying to contribute until they verify, or until 90 days have passed. Learn more. Restore Restore All @@ -539,6 +541,7 @@ Why Brave Rewards? With your old browser, you paid to browse the web by viewing ads with your valuable attention. You spent your valuable time downloading invasive ad technology that transmitted your valuable private data to advertisers — without your consent. Today, Brave welcomes you to the new Internet. One where your time is valued, your personal data is kept private, and you actually get paid for your attention. + Your Balance Your wallet View Details Creating wallet