UNPKG

@ledgerhq/coin-multiversx

Version:
39 lines 1.6 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.MultiversXEncodeTransaction = void 0; const account_1 = require("@ledgerhq/coin-framework/account"); const logic_1 = require("./logic"); class MultiversXEncodeTransaction { static async ESDTTransfer(t, ta) { const { token } = await (0, account_1.decodeTokenAccountId)(ta.id); const tokenIdentifierHex = token && (0, logic_1.extractTokenId)(token.id); let amountHex = t.useAllAmount ? ta.balance.toString(16) : t.amount.toString(16); //hex amount length must be even so protocol would treat it as an ESDT transfer if (amountHex.length % 2 !== 0) { amountHex = "0" + amountHex; } return Buffer.from(`ESDTTransfer@${tokenIdentifierHex}@${amountHex}`).toString("base64"); } static delegate() { return Buffer.from(`delegate`).toString("base64"); } static claimRewards() { return Buffer.from(`claimRewards`).toString("base64"); } static withdraw() { return Buffer.from(`withdraw`).toString("base64"); } static reDelegateRewards() { return Buffer.from(`reDelegateRewards`).toString("base64"); } static unDelegate(t) { let amountHex = t.amount.toString(16); //hex amount length must be even if (amountHex.length % 2 !== 0) { amountHex = "0" + amountHex; } return Buffer.from(`unDelegate@${amountHex}`).toString("base64"); } } exports.MultiversXEncodeTransaction = MultiversXEncodeTransaction; //# sourceMappingURL=encode.js.map