utils APIs
- calculateSlippageAmount
- calculateGasMargin
- getRouterContract
- getBscScanLink
- isAddress
- shortenAddress
- getEtherscanLink
- basisPointsToPercent
- getTokenAddress
- copyToClipboard
- deepMergeByKey
- decrypt
- encrypt
- emailErrorMsg
- reqErrorMsg
- debouncePromise
- callbackify
- isValidURL
- hasUserApiEditAccess
- loadThirdPartyScript
- getCurrentWindow
- hashVote
- toEthSignedMessageHash
- MAINNET_ID
- usePrevious
- bnum
- normalizeBalance
- isWalletScheme
- WalletSchemeProposalState
- VotingMachineProposalState
- calculateStakes
- formatBalance
- denormalizeBalance
- PendingAction
- isVoteNo
- isVoteYes
- parseSignedVoteMessage
- toPercentage
- verifySignedVote
- NETWORK_ASSET_SYMBOL
- ZERO_ADDRESS
- enumKeys
- DEFAULT_CHAIN_ID
- useInterval
- getBlockchainLink
- getERC20Token
- getDxVoteContract
- toAddressStub
- getNetworkById
- formatNumberValue
- encodeDxdVestingCreate
- encodeErc20Approval
- encodeErc20Transfer
- encodeRepMint
- TXEvents
- BigNumber
- ZERO_HASH
- ANY_ADDRESS
- ERC20_APPROVE_SIGNATURE
- ERC20_TRANSFER_SIGNATURE
- QUEUED_PRIORITY_THRESHOLD
- NETWORKS
- toCamelCaseString
- ALCHEMY_NETWORK_URLS
- DEFAULT_RPC_URLS
- appendEthAPIKey
- NETWORK_APIS
- INFURA_NETWORK_NAMES
- POKT_NETWORK_URLS
- constants
- session
- displayFromWei
- getBigNumber
- getSupplyCap
- getAllowance
- approve
- fromWei
- getFullDisplayBalance
- getLibrary
- maxAmountSpend
- addMaticToMetamask
- returnTokenFromKey
- isSupportedNetwork
- formatTokenAmount
- formatCompact
- formatNumber
- isTokensOnList
- getAPYWithFee
- getRewardRate
- getStakedAmountStakingInfo
- getTVLStaking
- getEarnedUSDLPFarm
- getEarnedUSDDualFarm
- formatAPY
- getUSDString
- formatMulDivTokenAmount
- getExactTokenAmount
- escapeRegExp
- currencyId
- getOneYearFee
- returnStakingInfo
- getAllTokensOnUniswap
- getAllPairsOnUniswap
- getSecondsOneDay
- getValueTokenDecimals
- getPartialTokenAmount
- confirmPriceImpactWithoutFee
- halfAmountSpend
- getTokenInfo
- getEthPrice
- getIntervalTokenData
- getTokenAPRSyrup
- getEarnedUSDSyrup
- getFormattedPrice
- getPriceColor
- getTopTokens
- shortenTx
- getContract
- isZero
- getChartData
- getChartDates
- getChartStartTime
- getLimitedData
- getTopPairs
- getGlobalData
- getBulkPairData
- formatDateFromTimeStamp
- getPairChartData
- getYAXISValuesAnalytics
- getPairTransactions
- getTokenChartData
- getTokenPairs2
- useLairDQUICKAPY
- getPageItemsToLoad
- returnFullWidthMobile
- returnDualStakingInfo
- getDaysCurrentYear
- getTokenPairs
- getBlockFromTimestamp
- getFarmLPToken
- getSyrupLPToken
- initTokenAmountFromCallResult
- returnSyrupInfo
- getCallStateResult
- notEmpty
- DEFAULT_TO_CHAIN_ID
- CHAINS
- UnsupportedChainIdError
- switchChain
- showMigrationBanner
- isValidAddress
- ChainId
- COLORS
- QUERIES
- onboard
- disableSendForm
- max
- parseUnits
- formatUnits
- ParsingError
- TOKENS_LIST
- Token
- blockLiquidity
- migrationPoolV2Warning
- formatEtherRaw
- numberFormatter
- estimateGasForAddEthLiquidity
- DEFAULT_ADD_LIQUIDITY_ETH_GAS_ESTIMATE
- UPDATE_GAS_INTERVAL_MS
- toWeiSafe
- addEtherscan
- receiveAmount
- getEstimatedDepositTime
- DEFAULT_FROM_CHAIN_ID
- formatEther
- PROVIDERS
- getRelayFees
- getLpFee
- isSupportedChainId
- getAddress
- getDepositBox
- TransactionError
- MAX_APPROVAL_AMOUNT
- optimismErc20Pairs
- bobaErc20Pairs
- tagAddress
- validateContractAndChain
- multicallTwoAddress
- IChainSelection
- CHAINS_SELECTION
- onboardBaseConfig
- getConfirmationDepositTime
- shortenAddressLong
- timeAgo
- textareaAutoResize
- initOAuthWindow
- parseURL
- scrollToBottom
- isUrl
- get_url_extension
- wait
- b64_to_utf8
- utf8_to_b64
- callDelayer
- useKeyboardDidShow
- capitalizedCase
- getCoinSymbol
- getCountryName
- getTransactionStatusColor
- useAlert
- scaleSpacing
- getActiveCase
- changeBodyTheme
- getPercentage
- metaGenerator
- useFetch
- visualize
- worldLegends
- dateFormat
- getPerDayStats
- API_BASEURL
- API_INDONESIA
- indonesiaLegends
- getActiveCaseID
- isWsAddress
- constructApiDescriptionObject
- encodeURI
- NOOP
- isLoggedIn
- getBalance
- getAccount
- isTokenOnList
- formatAddressShort
- requiresTypeSlug
- getNextOffchainPollEndingTime
- slugify
- slugifyPreserveDashes
- setupSwagger
- isBlindMode
- getExplorerLink
- isCountdown
- showVvsPrice
- getCookies
- iconFromMIME
- makeRangeArray
- exitIfMaintenance
- sanitizeHtmlString
- parseDate
- retryWrapper
- batchPromises
- arrayPartitions
- sleep
- checkKeyboardTrigger
- clampValue
- debounce
- normalize
- strToInt
- getFromLocalStorage
- saveToLocalStorage
- generateTagColors
- formatNumberWithCommas
- memoize
- calculateTotalInvestment
- throttle
- urlParametersState
- mmddyyyy2ddmmyyy
- sortStringDates
- gtag
- compactNumberFormatter
- getNumberSign
- getLastArrayElement
- fillArrayUntil
- capitalizeFirstLetter
- buildUrl
- XmlWrapper
- XmlTemplate
- setCookie
Other Related APIs
utils#encodeRepMint TypeScript Examples
The following examples show how to use
utils#encodeRepMint.
You can vote up the ones you like or vote down the ones you don't like,
and go to the original project or source file by following the links above each example. You may check out the related API usage on the sidebar.
Example #1
Source File: useSubmitProposal.ts From dxvote with GNU Affero General Public License v3.0 | 4 votes |
useSubmitProposal = (
stableAmount: BigNumber,
dxdAmount: BigNumber,
repReward: BigNumber,
dxdPrice: number,
startDate: moment.Moment,
setConfirm: any,
selectedLevel: any
): UsePaymentAmountsReturns => {
const {
context: {
ipfsService,
pinataService,
providerStore,
configStore,
daoStore,
daoService,
},
} = useContext();
const { library, account } = providerStore.getActiveWeb3React();
const contracts = configStore.getNetworkContracts();
const tokens = configStore.getTokensOfNetwork();
const [loading, setLoading] = useState(null);
const [proposalCreated, setProposalCreated] = useState(false);
const [errorMessage, setErrorMessage] = useState('');
const proposalType = configStore
.getProposalTypes()
.find(type => type.id === 'contributor');
const scheme = daoStore
.getAllSchemes()
.find(scheme => scheme.address === proposalType.scheme);
const submitProposal = async () => {
try {
setLoading(true);
const hash = await ipfsService.uploadProposalMetadata(
localStorage.getItem('dxvote-newProposal-title'),
localStorage.getItem('dxvote-newProposal-description') +
`${
'\n$' + normalizeBalance(stableAmount).toString()
} \n ${normalizeBalance(
dxdAmount
).toString()} DXD vested for 3 years and 1 year cliff @ $${dxdPrice}/DXD
\n ${normalizeBalance(repReward).toString()} REP \n `,
['Contributor Proposal', `Level ${selectedLevel.id}`],
pinataService
);
// Encode rep mint call
const repCallData = encodeRepMint(
library,
repReward.toString(),
account,
contracts.avatar
);
// Encode WXDAI transfer
const wxdaiTransferCallData = encodeErc20Transfer(
library,
account,
stableAmount.toString()
);
// Encode DXD approval
const dxdApprovalCallData = encodeErc20Approval(
library,
contracts.utils.dxdVestingFactory,
dxdAmount.toString()
);
// Encode vesting contract call
const vestingCallData = encodeDxdVestingCreate(
library,
account,
dxdAmount.toString(),
startDate
);
const proposalData = {
to: [
contracts.controller,
// Needs new stables coin value in config for other networks
tokens.find(token => token.symbol === 'WXDAI').address,
tokens.find(token => token.symbol === 'DXD').address,
contracts.utils.dxdVestingFactory,
],
data: [
repCallData,
wxdaiTransferCallData,
dxdApprovalCallData,
vestingCallData,
],
value: [0, 0, 0, 0],
titleText: localStorage.getItem('dxvote-newProposal-title'),
descriptionHash: contentHash.fromIpfs(hash),
};
console.debug('[PROPOSAL]', scheme.address, proposalData);
daoService
.createProposal(scheme.address, scheme.type, proposalData)
.on(TXEvents.TX_HASH, hash => {
console.debug('[TX_SUBMITTED]', hash);
setConfirm(false);
})
.on(TXEvents.RECEIPT, hash => {
console.debug('[TX_RECEIPT]', hash);
setLoading(false);
setProposalCreated(true);
})
.on(TXEvents.TX_ERROR, txerror => {
console.error('[TX_ERROR]', txerror);
setLoading(false);
setErrorMessage((txerror as Error).message);
})
.on(TXEvents.INVARIANT, error => {
console.error('[ERROR]', error);
setLoading(false);
setErrorMessage((error as Error).message);
})
.catch(error => {
console.error('[ERROR]', error);
setLoading(false);
setErrorMessage((error as Error).message);
});
} catch (error) {
console.error('[PROPOSAL_ERROR]', error);
}
};
return {
submitProposal,
loading,
proposalCreated,
errorMessage,
};
}