@ledgerhq/coin-multiversx
Version:
Ledger MultiversX Coin integration
39 lines • 1.6 kB
JavaScript
;
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