diff --git a/content/tutorials/quickstart/transfer-nftokens.md b/content/tutorials/quickstart/transfer-nftokens.md index 561b907930..4710f82bb1 100644 --- a/content/tutorials/quickstart/transfer-nftokens.md +++ b/content/tutorials/quickstart/transfer-nftokens.md @@ -38,22 +38,14 @@ You can download the [Quickstart Samples](https://github.com/XRPLF/xrpl-dev-port 1. Open `4.transfer-nftokens.html` in a browser. -2. Get test accounts. +2. Choose **XLS20-NFT** as your ledger instance. +3. Get test accounts. 1. If you have existing NFT-Devnet account seeds 1. Paste account seeds in the **Seeds** field. 2. Click **Get Accounts from Seeds**. 2. If you do not have NFT-Devnet account seeds: - 3. Visit the [XRP Testnet Faucet](https://xrpl.org/xrp-testnet-faucet.html) page. - 4. Click **Generate NFT-Devnet credentials**. - 5. Copy the account **Secret**. - 6. Paste the secret in a persistent location, such as a notepad, and press return. - 7. Click **Generate NFT-Devnet credentials** to create a second account. - 8. Copy the account **Secret**. - 9. Paste the secret in the persistent location. - 10. Copy both secrets, separated by a return. - 11. Paste them in the **Account** **Seeds** field. - 12. Click **Get Accounts from Seeds**. - + 1. Click **Get New Standby Account**. + 2. Click **Get New Operational Account**.  @@ -65,13 +57,13 @@ You can download the [Quickstart Samples](https://github.com/XRPLF/xrpl-dev-port To create a NFToken sell offer: - 1. Enter the **Amount** of the sell offer in drops (millionths of an XRP). 2. Set the **Flags** field to _1_. 3. Enter the **Token ID** of the NFToken you want to sell. -4. Click **Create Sell Offer**. +4. Optionally, enter a number of days until **Expiration**. +5. Click **Create Sell Offer**. -The important piece of information in the response is the Token Offer Index, labeled as _Index,_ which is used to accept the sell offer. +The important piece of information in the response is the Token Offer Index, labeled as _nft_offer_index,_ which is used to accept the sell offer. @@ -87,7 +79,7 @@ To accept an available sell offer: -1. Enter the **Token Offer Index** (labeled as _Index_ in the token offer results. This is not the same as the Token ID). +1. Enter the **Token Offer Index** (labeled as _nft_offer_index_ in the token offer results. This is not the same as the _nft_id_). 2. Click **Accept Sell Offer**. @@ -107,7 +99,8 @@ To create an offer to buy a NFToken: 1. Enter the **Amount** of your offer. 2. Enter the **Token ID**. 3. Enter the owner’s account string in the **Owner** field. -4. Click **Create Buy Offer**. +4. Optionally enter the number of days until **Expiration**. +5. Click **Create Buy Offer**. @@ -121,8 +114,7 @@ To accept an offer to buy a NFToken: -1. Enter the **Token Offer ID** (the **Index** of the token offer). -2. Enter the buyer’s account string in the **Owner** field (the buyer is the owner of the token offer). +1. Enter the **Token Offer ID** (the _nft_offer_index_ of the token buy offer). 3. Click **Accept Buy Offer**. @@ -133,7 +125,9 @@ To accept an offer to buy a NFToken: ## Get Offers -Click **Get Offers** to get the buy and sell offers associated with a particular account. +To list the buy and sell offers associated with a NFToken: +1. Enter the **NFToken ID**. +2. Click **Get Offers**. @@ -175,34 +169,59 @@ Connect to the ledger and get the wallet accounts. ``` - async function createSellOffer() { - const standby_wallet = xrpl.Wallet.fromSeed(standbySeedField.value) - const operational_wallet = xrpl.Wallet.fromSeed(operationalSeedField.value) - let net = getNet() - const client = new xrpl.Client(net) - results = 'Connecting to ' + getNet() + '...' - document.getElementById('standbyResultField').value = results - await client.connect() - results += '\nConnected. Creating sell offer...' - document.getElementById('standbyResultField').value = results - - +async function createSellOffer() { + const standby_wallet = xrpl.Wallet.fromSeed(standbySeedField.value) + const operational_wallet = xrpl.Wallet.fromSeed(operationalSeedField.value) + let net = getNet() + const client = new xrpl.Client(net) + results = 'Connecting to ' + getNet() + '...' + document.getElementById('standbyResultField').value = results + await client.connect() + results += '\nConnected. Creating sell offer...' + document.getElementById('standbyResultField').value = results ``` - -Define the transaction. The _Flags_ value of 1 indicates that this transaction is a sell offer. - +Compute the Expiration Date, if present. The expiration date represents the number of seconds after the Ripple Epoch that the offer should expire. Subtract the Ripple Epoch from the current system date divided by 1,000, and add the number of days (or fractions of a day) multiplied by 86400 to get the correct expiration date. ``` - const transactionBlob = { - "TransactionType": "NFTokenCreateOffer", - "Account": standby_wallet.classicAddress, - "TokenID": standbyTokenIdField.value, - "Amount": standbyAmountField.value, - "Flags": parseInt(standbyFlagsField.value) - } + //------------------------------------- Prepare Expiration Date + var expirationDate = null + if (standbyExpirationField.value !="") { + var days = document.getElementById('standbyExpirationField').value + var secondsInDay = 86400 + var rippleEpoch = 946684800 + var currentTimestamp = (new Date() / 1000) - rippleEpoch + expirationDate = parseInt(Math.floor(currentTimestamp + (days*secondsInDay))) + } +``` +Define the transaction. A _Flags_ value of 1 indicates that this transaction is a sell offer. +``` + let transactionBlob = { + "TransactionType": "NFTokenCreateOffer", + "Account": standby_wallet.classicAddress, + "NFTokenID": standbyTokenIdField.value, + "Amount": standbyAmountField.value, + "Flags": parseInt(standbyFlagsField.value), + } +``` + +If the Expiration Date is present, append it to the transaction. + +``` + if (expirationDate != null) { + transactionBlob.Expiration = expirationDate + } + +``` + +If the Destination field is not empty, append it to the transaction. When the destination is set, only the destination account can purchase the NFToken. + +``` + if(standbyDestinationField.value !== '') { + transactionBlob.Destination = standbyDestinationField.value + } ``` @@ -212,7 +231,7 @@ Submit the transaction and wait for the results. ``` - const tx = await client.submitAndWait(transactionBlob,{wallet: standby_wallet}) + const tx = await client.submitAndWait(transactionBlob,{wallet: standby_wallet}) ``` @@ -220,7 +239,7 @@ Submit the transaction and wait for the results. ``` - results += '\n\n***Sell Offers***\n' + results += '\n\n***Sell Offers***\n' ``` @@ -228,19 +247,15 @@ Request the list of sell offers for the token. ``` - - - let nftSellOffers - try { - nftSellOffers = await client.request({ - method: "nft_sell_offers", - tokenid: standbyTokenIdField.value - }) - } catch (err) { - nftSellOffers = "No sell offers." - } - results += JSON.stringify(nftSellOffers,null,2) - results += '\n\n***Buy Offers***\n' + let nftSellOffers + try { + nftSellOffers = await client.request({ + method: "nft_sell_offers", + nft_id: standbyTokenIdField.value}) + } catch (err) { + nftSellOffers = "No sell offers." + } + results += JSON.stringify(nftSellOffers,null,2) ``` @@ -248,17 +263,16 @@ Request the list of buy offers for the token. ``` - let nftBuyOffers - try { - nftBuyOffers = await client.request({ - method: "nft_buy_offers", - tokenid: standbyTokenIdField.value }) - } catch (err) { - results += 'No buy offers.' - } - results += JSON.stringify(nftBuyOffers,null,2) - - + results += '\n\n***Buy Offers***\n' + let nftBuyOffers + try { + nftBuyOffers = await client.request({ + method: "nft_buy_offers", + nft_id: standbyTokenIdField.value }) + } catch (err) { + results += 'No buy offers.' + } + results += JSON.stringify(nftBuyOffers,null,2) ``` @@ -266,10 +280,10 @@ Report the results of the transaction. ``` - results += '\n\nTransaction result:\n' + - JSON.stringify(tx.result.meta.TransactionResult, null, 2) - results += '\n\nBalance changes:\n' + - JSON.stringify(xrpl.getBalanceChanges(tx.result.meta), null, 2) + results += '\n\nTransaction result:\n' + + JSON.stringify(tx.result.meta.TransactionResult, null, 2) + results += '\n\nBalance changes:\n' + + JSON.stringify(xrpl.getBalanceChanges(tx.result.meta), null, 2) ``` @@ -277,11 +291,11 @@ Get the current XRP balances for the operational and standby accounts. ``` - document.getElementById('operationalBalanceField').value = - (await client.getXrpBalance(operational_wallet.address)) - document.getElementById('standbyBalanceField').value = - (await client.getXrpBalance(standby_wallet.address)) - document.getElementById('standbyResultField').value = results + document.getElementById('operationalBalanceField').value = + (await client.getXrpBalance(operational_wallet.address)) + document.getElementById('standbyBalanceField').value = + (await client.getXrpBalance(standby_wallet.address)) + document.getElementById('standbyResultField').value = results ``` @@ -289,11 +303,8 @@ Disconnect from the ledger. ``` - - - client.disconnect() - // End of createSellOffer() - } + client.disconnect() +}// End of createSellOffer() ``` @@ -307,7 +318,7 @@ Disconnect from the ledger. // ******************************************************* - async function createBuyOffer() { +async function createBuyOffer() { ``` @@ -315,42 +326,56 @@ Get the account wallets and connect to the ledger. ``` - const standby_wallet = xrpl.Wallet.fromSeed(standbySeedField.value) - const operational_wallet = xrpl.Wallet.fromSeed(operationalSeedField.value) - let net = getNet() - const client = new xrpl.Client(net) - let results = 'Connecting to ' + getNet() + '...' - document.getElementById('standbyResultField').value = results - await client.connect() - results = '\nConnected. Creating buy offer...' - document.getElementById('standbyResultField').value = results - + const standby_wallet = xrpl.Wallet.fromSeed(standbySeedField.value) + const operational_wallet = xrpl.Wallet.fromSeed(operationalSeedField.value) + let net = getNet() + const client = new xrpl.Client(net) + let results = 'Connecting to ' + getNet() + '...' + document.getElementById('standbyResultField').value = results + await client.connect() + results = '\nConnected. Creating buy offer...' + document.getElementById('standbyResultField').value = results +``` +Prepare the expiration date, if present. ``` - + var expirationDate = null + if (standbyExpirationField.value !="") { + var days = document.getElementById('standbyExpirationField').value + var secondsInDay = 86400 + var rippleEpoch = 946684800 + var currentTimestamp = (new Date() / 1000) - rippleEpoch + expirationDate = parseInt(Math.floor(currentTimestamp + (days*secondsInDay))) + } +``` Define the transaction. Setting the _Flags_ value to _null_ indicates that this is a buy offer. ``` - const transactionBlob = { - "TransactionType": "NFTokenCreateOffer", - "Account": standby_wallet.classicAddress, - "Owner": standbyOwnerField.value, - "TokenID": standbyTokenIdField.value, - "Amount": standbyAmountField.value, - "Flags": null - } - + const transactionBlob = { + "TransactionType": "NFTokenCreateOffer", + "Account": standby_wallet.classicAddress, + "Owner": standbyOwnerField.value, + "NFTokenID": standbyTokenIdField.value, + "Amount": standbyAmountField.value, + "Flags": null + } +``` +If the expiration date is present, append that to the transaction. ``` + if (expirationDate != null) { + transactionBlob.Expiration = expirationDate + } +``` Submit the transaction and wait for the results. ``` - const tx = await client.submitAndWait(transactionBlob,{wallet: standby_wallet}) + const tx = await client.submitAndWait(transactionBlob,{wallet: standby_wallet}) ``` @@ -358,19 +383,16 @@ Request the list of sell offers for the token. ``` - - - results += "\n\n***Sell Offers***\n" - let nftSellOffers - try { - nftSellOffers = await client.request({ - method: "nft_sell_offers", - tokenid: standbyTokenIdField.value - }) - } catch (err) { - nftSellOffers = "No sell offers." - } - results += JSON.stringify(nftSellOffers,null,2) + results += "\n\n***Sell Offers***\n" + let nftSellOffers + try { + nftSellOffers = await client.request({ + method: "nft_sell_offers", + nft_id: standbyTokenIdField.value }) + } catch (err) { + nftSellOffers = "No sell offers." + } + results += JSON.stringify(nftSellOffers,null,2) ``` @@ -378,18 +400,16 @@ Request the list of buy offers for the token. ``` - results += "\n\n***Buy Offers***\n" - let nftBuyOffers - try { - nftBuyOffers = await client.request({ - method: "nft_buy_offers", - tokenid: standbyTokenIdField.value }) - } catch (err) { - results += "No buy offers." - } - results += JSON.stringify(nftBuyOffers,null,2) - - + results += "\n\n***Buy Offers***\n" + let nftBuyOffers + try { + nftBuyOffers = await client.request({ + method: "nft_buy_offers", + nft_id: standbyTokenIdField.value }) + } catch (err) { + results += "No buy offers." + } + results += JSON.stringify(nftBuyOffers,null,2) ``` @@ -397,13 +417,12 @@ Report the results of the transaction. - ``` - results += "\n\nTransaction result:\n" + - JSON.stringify(tx.result.meta.TransactionResult, null, 2) - results += "\n\nBalance changes:\n" + - JSON.stringify(xrpl.getBalanceChanges(tx.result.meta), null, 2) - document.getElementById('standbyResultField').value = results + results += "\n\nTransaction result:\n" + + JSON.stringify(tx.result.meta.TransactionResult, null, 2) + results += "\n\nBalance changes:\n" + + JSON.stringify(xrpl.getBalanceChanges(tx.result.meta), null, 2) + document.getElementById('standbyResultField').value = results ``` @@ -411,9 +430,8 @@ Disconnect from the ledger. ``` - client.disconnect() - // End of operationalCreateBuyOffer() - } + client.disconnect() +}// End of createBuyOffer() ``` @@ -426,7 +444,7 @@ Disconnect from the ledger. // ******************** Cancel Offer ********************* // ******************************************************* - async function cancelOffer() { +async function cancelOffer() { ``` @@ -434,13 +452,13 @@ Get the standby wallet and connect to the ledger. ``` - const wallet = xrpl.Wallet.fromSeed(standbySeedField.value) - const client = new xrpl.Client("wss://xls20-sandbox.rippletest.net:51233") - results = 'Connecting to ' + getNet() + '...' - document.getElementById('standbyResultField').value = results - await client.connect() - results += "\nConnected. Cancelling offer..." - document.getElementById('standbyResultField').value = results + const wallet = xrpl.Wallet.fromSeed(standbySeedField.value) + const client = new xrpl.Client("wss://xls20-sandbox.rippletest.net:51233") + results = 'Connecting to ' + getNet() + '...' + document.getElementById('standbyResultField').value = results + await client.connect() + results += "\nConnected. Cancelling offer..." + document.getElementById('standbyResultField').value = results ``` @@ -448,7 +466,7 @@ Insert the token offer index as a new array. This example destroys one offer at ``` - const tokenOfferIDs = [standbyTokenOfferIndexField.value] + const tokenOfferIDs = [standbyTokenOfferIndexField.value] ``` @@ -458,11 +476,11 @@ Define the transaction. ``` - const transactionBlob = { - "TransactionType": "NFTokenCancelOffer", - "Account": wallet.classicAddress, - "TokenOffers": tokenOfferIDs - } + const transactionBlob = { + "TransactionType": "NFTokenCancelOffer", + "Account": wallet.classicAddress, + "NFTokenOffers": tokenOfferIDs + } ``` @@ -470,7 +488,7 @@ Submit the transaction and wait for the results. ``` - const tx = await client.submitAndWait(transactionBlob,{wallet}) + const tx = await client.submitAndWait(transactionBlob,{wallet}) ``` @@ -478,17 +496,17 @@ Request the list of sell offers for the token. ``` - results += "\n\n***Sell Offers***\n" - let nftSellOffers - try { - nftSellOffers = await client.request({ - method: "nft_sell_offers", - tokenid: standbyTokenIdField.value - }) - } catch (err) { - nftSellOffers = "No sell offers." - } - results += JSON.stringify(nftSellOffers,null,2) + results += "\n\n***Sell Offers***\n" + let nftSellOffers + try { + nftSellOffers = await client.request({ + method: "nft_sell_offers", + nft_id: standbyTokenIdField.value + }) + } catch (err) { + nftSellOffers = "No sell offers." + } + results += JSON.stringify(nftSellOffers,null,2) ``` @@ -496,16 +514,16 @@ Request the list of buy offers for the token. ``` - results += "\n\n***Buy Offers***\n" - let nftBuyOffers - try { - nftBuyOffers = await client.request({ - method: "nft_buy_offers", - tokenid: standbyTokenIdField.value }) - } catch (err) { - nftBuyOffers = "No buy offers." - } - results += JSON.stringify(nftBuyOffers,null,2) + results += "\n\n***Buy Offers***\n" + let nftBuyOffers + try { + nftBuyOffers = await client.request({ + method: "nft_buy_offers", + nft_id: standbyTokenIdField.value }) + } catch (err) { + nftBuyOffers = "No buy offers." + } + results += JSON.stringify(nftBuyOffers,null,2) ``` @@ -513,13 +531,11 @@ Report the transaction results. ``` - - - results += "\nTransaction result:\n" + - JSON.stringify(tx.result.meta.TransactionResult, null, 2) - results += "\nBalance changes:\n" + - JSON.stringify(xrpl.getBalanceChanges(tx.result.meta), null, 2) - document.getElementById('standbyResultField').value = results + results += "\nTransaction result:\n" + + JSON.stringify(tx.result.meta.TransactionResult, null, 2) + results += "\nBalance changes:\n" + + JSON.stringify(xrpl.getBalanceChanges(tx.result.meta), null, 2) + document.getElementById('standbyResultField').value = results ``` @@ -527,9 +543,8 @@ Disconnect from the ledger. ``` - client.disconnect() - // End of cancelOffer() - } + client.disconnect() // End of cancelOffer() +} ``` @@ -543,22 +558,21 @@ Disconnect from the ledger. // ******************************************************* - async function getOffers() { +async function getOffers() { ``` - Get the standby account wallet and connect to the ledger. ``` - const standby_wallet = xrpl.Wallet.fromSeed(standbySeedField.value) - let net = getNet() - const client = new xrpl.Client(net) - results = 'Connecting to ' + getNet() + '...' - document.getElementById('standbyResultField').value = results - await client.connect() - results += '\nConnected. Getting offers...' - document.getElementById('standbyResultField').value = results + const standby_wallet = xrpl.Wallet.fromSeed(standbySeedField.value) + let net = getNet() + const client = new xrpl.Client(net) + results = 'Connecting to ' + getNet() + '...' + document.getElementById('standbyResultField').value = results + await client.connect() + results += '\nConnected. Getting offers...' + document.getElementById('standbyResultField').value = results ``` @@ -566,18 +580,17 @@ Request the list of sell offers for the token. ``` - results += '\n\n***Sell Offers***\n' - let nftSellOffers - try { - nftSellOffers = await client.request({ - method: "nft_sell_offers", - tokenid: standbyTokenIdField.value - }) - } catch (err) { - nftSellOffers = 'No sell offers.' - } - results += JSON.stringify(nftSellOffers,null,2) - document.getElementById('standbyResultField').value = results + results += '\n\n***Sell Offers***\n' + let nftSellOffers + try { + nftSellOffers = await client.request({ + method: "nft_sell_offers", + nft_id: standbyTokenIdField.value }) + } catch (err) { + nftSellOffers = 'No sell offers.' + } + results += JSON.stringify(nftSellOffers,null,2) + document.getElementById('standbyResultField').value = results ``` @@ -585,17 +598,17 @@ Request the list of buy offers for the token. ``` - results += '\n\n***Buy Offers***\n' - let nftBuyOffers - try { - nftBuyOffers = await client.request({ - method: "nft_buy_offers", - tokenid: standbyTokenIdField.value }) - } catch (err) { - nftBuyOffers = 'No buy offers.' - } - results += JSON.stringify(nftBuyOffers,null,2) - document.getElementById('standbyResultField').value = results + results += '\n\n***Buy Offers***\n' + let nftBuyOffers + try { + nftBuyOffers = await client.request({ + method: "nft_buy_offers", + nft_id: standbyTokenIdField.value }) + } catch (err) { + nftBuyOffers = 'No buy offers.' + } + results += JSON.stringify(nftBuyOffers,null,2) + document.getElementById('standbyResultField').value = results ``` @@ -603,11 +616,8 @@ Disconnect from the ledger. ``` - client.disconnect() - // End of getOffers() - } - - + client.disconnect() +}// End of getOffers() ``` @@ -621,7 +631,7 @@ Disconnect from the ledger. // ******************************************************* - async function acceptSellOffer() { +async function acceptSellOffer() { ``` @@ -629,17 +639,15 @@ Get the account wallets and connect to the ledger. ``` - const standby_wallet = xrpl.Wallet.fromSeed(standbySeedField.value) - const operational_wallet = xrpl.Wallet.fromSeed(operationalSeedField.value) - let net = getNet() - const client = new xrpl.Client(net) - results = 'Connecting to ' + getNet() + '...' - document.getElementById('standbyResultField').value = results - await client.connect() - results += '\nConnected. Accepting sell offer...\n\n' - document.getElementById('standbyResultField').value = results - - + const standby_wallet = xrpl.Wallet.fromSeed(standbySeedField.value) + const operational_wallet = xrpl.Wallet.fromSeed(operationalSeedField.value) + let net = getNet() + const client = new xrpl.Client(net) + results = 'Connecting to ' + getNet() + '...' + document.getElementById('standbyResultField').value = results + await client.connect() + results += '\nConnected. Accepting sell offer...\n\n' + document.getElementById('standbyResultField').value = results ``` @@ -647,11 +655,11 @@ Define the transaction. ``` - const transactionBlob = { - "TransactionType": "NFTokenAcceptOffer", - "Account": standby_wallet.classicAddress, - "SellOffer": standbyTokenOfferIndexField.value, - } + const transactionBlob = { + "TransactionType": "NFTokenAcceptOffer", + "Account": standby_wallet.classicAddress, + "NFTokenSellOffer": standbyTokenOfferIndexField.value, + } ``` @@ -659,7 +667,7 @@ Submit the transaction and wait for the results. ``` - const tx = await client.submitAndWait(transactionBlob,{wallet: standby_wallet}) + const tx = await client.submitAndWait(transactionBlob,{wallet: standby_wallet}) ``` @@ -667,12 +675,9 @@ Request the list of NFTs for the standby account. ``` - const nfts = await client.request({ - method: "account_nfts", - account: standby_wallet.classicAddress - }) - - + const nfts = await client.request({ + method: "account_nfts", + account: standby_wallet.classicAddress }) ``` @@ -680,10 +685,10 @@ Get the balances for both accounts. ``` - document.getElementById('standbyBalanceField').value = - (await client.getXrpBalance(standby_wallet.address)) - document.getElementById('operationalBalanceField').value = - (await client.getXrpBalance(operational_wallet.address)) + document.getElementById('standbyBalanceField').value = + (await client.getXrpBalance(standby_wallet.address)) + document.getElementById('operationalBalanceField').value = + (await client.getXrpBalance(operational_wallet.address)) ``` @@ -691,16 +696,12 @@ Report the transaction results. ``` - - - results += 'Transaction result:\n' - results += JSON.stringify(tx.result.meta.TransactionResult, null, 2) - results += '\nBalance changes:' - results += JSON.stringify(xrpl.getBalanceChanges(tx.result.meta), null, 2) - results += JSON.stringify(nfts,null,2) - - - document.getElementById('standbyResultField').value = results + results += 'Transaction result:\n' + results += JSON.stringify(tx.result.meta.TransactionResult, null, 2) + results += '\nBalance changes:' + results += JSON.stringify(xrpl.getBalanceChanges(tx.result.meta), null, 2) + results += JSON.stringify(nfts,null,2) + document.getElementById('standbyResultField').value = results ``` @@ -708,9 +709,8 @@ Disconnect from the ledger. ``` - client.disconnect() - // End of acceptSellOffer() - } + client.disconnect() +}// End of acceptSellOffer() ``` @@ -724,7 +724,7 @@ Disconnect from the ledger. // ******************************************************* - async function acceptBuyOffer() { +async function acceptBuyOffer() { ``` @@ -732,15 +732,15 @@ Get the account wallets and connect to the ledger. ``` - const standby_wallet = xrpl.Wallet.fromSeed(standbySeedField.value) - const operational_wallet = xrpl.Wallet.fromSeed(operationalSeedField.value) - let net = getNet() - const client = new xrpl.Client(net) - results = 'Connecting to ' + getNet() + '...' - document.getElementById('standbyResultField').value = results - await client.connect() - results += '\nConnected. Accepting buy offer...' - document.getElementById('standbyResultField').value = results + const standby_wallet = xrpl.Wallet.fromSeed(standbySeedField.value) + const operational_wallet = xrpl.Wallet.fromSeed(operationalSeedField.value) + let net = getNet() + const client = new xrpl.Client(net) + results = 'Connecting to ' + getNet() + '...' + document.getElementById('standbyResultField').value = results + await client.connect() + results += '\nConnected. Accepting buy offer...' + document.getElementById('standbyResultField').value = results ``` @@ -748,11 +748,10 @@ Prepare the transaction. ``` - const transactionBlob = { - "TransactionType": "NFTokenAcceptOffer", - "Account": standby_wallet.classicAddress, - "BuyOffer": standbyTokenOfferIndexField.value - } + "TransactionType": "NFTokenAcceptOffer", + "Account": standby_wallet.classicAddress, + "NFTokenBuyOffer": standbyTokenOfferIndexField.value + } ``` @@ -760,7 +759,7 @@ Submit the transaction and wait for the results. ``` - const tx = await client.submitAndWait(transactionBlob,{wallet: standby_wallet}) + const tx = await client.submitAndWait(transactionBlob,{wallet: standby_wallet}) ``` @@ -768,12 +767,12 @@ Request the current list of NFTs for the standby account. ``` - const nfts = await client.request({ - method: "account_nfts", - account: standby_wallet.classicAddress - }) - results += JSON.stringify(nfts,null,2) - document.getElementById('standbyResultField').value = results + const nfts = await client.request({ + method: "account_nfts", + account: standby_wallet.classicAddress + }) + results += JSON.stringify(nfts,null,2) + document.getElementById('standbyResultField').value = results ``` @@ -781,10 +780,10 @@ Report the transaction result. ``` - result += "\n\nTransaction result:\n" + - JSON.stringify(tx.result.meta.TransactionResult, null, 2) - result += "\nBalance changes:\n" + - JSON.stringify(xrpl.getBalanceChanges(tx.result.meta), null, 2) + results += "\n\nTransaction result:\n" + + JSON.stringify(tx.result.meta.TransactionResult, null, 2) + results += "\nBalance changes:\n" + + JSON.stringify(xrpl.getBalanceChanges(tx.result.meta), null, 2) ``` @@ -792,11 +791,11 @@ Request the XRP balance for both accounts. ``` - document.getElementById('operationalBalanceField').value = - (await client.getXrpBalance(operational_wallet.address)) - document.getElementById('standbyBalanceField').value = - (await client.getXrpBalance(standby_wallet.address)) - document.getElementById('standbyResultField').value = results + document.getElementById('operationalBalanceField').value = + (await client.getXrpBalance(operational_wallet.address)) + document.getElementById('standbyBalanceField').value = + (await client.getXrpBalance(standby_wallet.address)) + document.getElementById('standbyResultField').value = results ``` @@ -804,9 +803,8 @@ Disconnect from the ledger. ``` - client.disconnect() - // End of acceptBuyOffer() - } + client.disconnect() +}// End of acceptBuyOffer() ``` @@ -820,363 +818,340 @@ These functions duplicate the functions of the standby account for the operation // *********** Operational Create Sell Offer ************* // ******************************************************* +async function oPcreateSellOffer() { + const standby_wallet = xrpl.Wallet.fromSeed(standbySeedField.value) + const operational_wallet = xrpl.Wallet.fromSeed(operationalSeedField.value) + let net = getNet() + const client = new xrpl.Client(net) + results = 'Connecting to ' + getNet() + '...' + document.getElementById('operationalResultField').value = results + await client.connect() + results += '\nConnected. Creating sell offer...' + document.getElementById('operationalResultField').value = results - async function oPcreateSellOffer() { - const standby_wallet = xrpl.Wallet.fromSeed(standbySeedField.value) - const operational_wallet = xrpl.Wallet.fromSeed(operationalSeedField.value) - let net = getNet() - const client = new xrpl.Client(net) - results = 'Connecting to ' + getNet() + '...' - document.getElementById('operationalResultField').value = results - await client.connect() - results += '\nConnected. Creating sell offer...' - document.getElementById('operationalResultField').value = results + //------------------------------------- Prepare Expiration Date + var expirationDate = null + if (operationalExpirationField.value !="") { + var days = document.getElementById('operationalExpirationField').value + var secondsInDay = 86400 + var rippleEpoch = 946684800 + var currentTimestamp = (new Date() / 1000) - rippleEpoch + expirationDate = parseInt(Math.floor(currentTimestamp + (days*secondsInDay))) + } + // Prepare transaction ------------------------------------------------------- + let transactionBlob = { + "TransactionType": "NFTokenCreateOffer", + "Account": operational_wallet.classicAddress, + "NFTokenID": operationalTokenIdField.value, + "Amount": operationalAmountField.value, + "Flags": parseInt(operationalFlagsField.value), + } + if (expirationDate != null) { + transactionBlob.Expiration = expirationDate + } + if(standbyDestinationField.value !== '') { + transactionBlob.Destination = operationalDestinationField.value + } + // Submit transaction -------------------------------------------------------- - // Prepare transaction ------------------------------------------------------- - const transactionBlob = { - "TransactionType": "NFTokenCreateOffer", - "Account": operational_wallet.classicAddress, - "TokenID": operationalTokenIdField.value, - "Amount": operationalAmountField.value, - "Flags": parseInt(operationalFlagsField.value) - } + const tx = await client.submitAndWait(transactionBlob,{wallet: operational_wallet}) + results += '\n\n***Sell Offers***\n' - // Submit transaction -------------------------------------------------------- + let nftSellOffers + try { + nftSellOffers = await client.request({ + method: "nft_sell_offers", + nft_id: operationalTokenIdField.value + }) + } catch (err) { + nftSellOffers = "No sell offers." + } + results += JSON.stringify(nftSellOffers,null,2) + results += '\n\n***Buy Offers***\n' + let nftBuyOffers + try { + nftBuyOffers = await client.request({ + method: "nft_buy_offers", + nft_id: operationalTokenIdField.value }) + } catch (err) { + results += 'No buy offers.' + } + results += JSON.stringify(nftBuyOffers,null,2) + // Check transaction results ------------------------------------------------- + results += '\n\nTransaction result:\n' + + JSON.stringify(tx.result.meta.TransactionResult, null, 2) + results += '\n\nBalance changes:\n' + + JSON.stringify(xrpl.getBalanceChanges(tx.result.meta), null, 2) + document.getElementById('operationalBalanceField').value = + (await client.getXrpBalance(operational_wallet.address)) + document.getElementById('standbyBalanceField').value = + (await client.getXrpBalance(standby_wallet.address)) + document.getElementById('operationalResultField').value = results - const tx = await client.submitAndWait(transactionBlob,{wallet: operational_wallet}) - - - results += '\n\n***Sell Offers***\n' - - - let nftSellOffers - try { - nftSellOffers = await client.request({ - method: "nft_sell_offers", - tokenid: operationalTokenIdField.value - }) - } catch (err) { - nftSellOffers = "No sell offers." - } - results += JSON.stringify(nftSellOffers,null,2) - results += '\n\n***Buy Offers***\n' - let nftBuyOffers - try { - nftBuyOffers = await client.request({ - method: "nft_buy_offers", - tokenid: operationalTokenIdField.value }) - } catch (err) { - results += 'No buy offers.' - } - results += JSON.stringify(nftBuyOffers,null,2) - - - // Check transaction results ------------------------------------------------- - results += '\n\nTransaction result:\n' + - JSON.stringify(tx.result.meta.TransactionResult, null, 2) - results += '\n\nBalance changes:\n' + - JSON.stringify(xrpl.getBalanceChanges(tx.result.meta), null, 2) - document.getElementById('operationalBalanceField').value = - (await client.getXrpBalance(operational_wallet.address)) - document.getElementById('standbyBalanceField').value = - (await client.getXrpBalance(standby_wallet.address)) - document.getElementById('operationalResultField').value = results - - - client.disconnect() - } // End of oPcreateSellOffer() - + client.disconnect() +} // End of oPcreateSellOffer() // ******************************************************* // ************** Operational Create Buy Offer *********** // ******************************************************* +async function oPcreateBuyOffer() { - async function oPcreateBuyOffer() { + const standby_wallet = xrpl.Wallet.fromSeed(standbySeedField.value) + const operational_wallet = xrpl.Wallet.fromSeed(operationalSeedField.value) + let net = getNet() + const client = new xrpl.Client(net) + let results = 'Connecting to ' + getNet() + '...' + document.getElementById('operationalResultField').value = results + await client.connect() + results = '\nConnected. Creating buy offer...' + document.getElementById('operationalResultField').value = results + //------------------------------------- Prepare Expiration Date + var expirationDate = null + if (standbyExpirationField.value !="") { + var days = document.getElementById('operationalExpirationField').value + var secondsInDay = 86400 + var rippleEpoch = 946684800 + var currentTimestamp = (new Date() / 1000) - rippleEpoch + expirationDate = parseInt(Math.floor(currentTimestamp + (days*secondsInDay))) + } - const standby_wallet = xrpl.Wallet.fromSeed(standbySeedField.value) - const operational_wallet = xrpl.Wallet.fromSeed(operationalSeedField.value) - let net = getNet() - const client = new xrpl.Client(net) - let results = 'Connecting to ' + net + '...' - document.getElementById('operationalResultField').value = results - await client.connect() - results += '\nConnected. Creating buy offer...' - document.getElementById('operationalResultField').value = results + // Prepare transaction ------------------------------------------------------- + const transactionBlob = { + "TransactionType": "NFTokenCreateOffer", + "Account": operational_wallet.classicAddress, + "Owner": operationalOwnerField.value, + "NFTokenID": operationalTokenIdField.value, + "Amount": operationalAmountField.value, + "Flags": null, + } + if (expirationDate != null) { + transactionBlob.Expiration = expirationDate + } + // Submit transaction -------------------------------------------------------- + const tx = await client.submitAndWait(transactionBlob,{wallet: operational_wallet}) + results += "\n\n***Sell Offers***\n" + let nftSellOffers + try { + nftSellOffers = await client.request({ + method: "nft_sell_offers", + nft_id: operationalTokenIdField.value + }) + } catch (err) { + nftSellOffers = "No sell offers." + } + results += JSON.stringify(nftSellOffers,null,2) + results += "\n\n***Buy Offers***\n" + let nftBuyOffers + try { + nftBuyOffers = await client.request({ + method: "nft_buy_offers", + nft_id: operationalTokenIdField.value + }) + } catch (err) { + results += "No buy offers." + } + results += JSON.stringify(nftBuyOffers,null,2) - // Prepare transaction ------------------------------------------------------- - const transactionBlob = { - "TransactionType": "NFTokenCreateOffer", - "Account": operational_wallet.classicAddress, - "Owner": operationalOwnerField.value, - "TokenID": operationalTokenIdField.value, - "Amount": operationalAmountField.value, - "Flags": null - } - - - // Submit transaction -------------------------------------------------------- - const tx = await client.submitAndWait(transactionBlob,{wallet: operational_wallet}) - - - results +="\n\n***Sell Offers***\n" - let nftSellOffers - try { - nftSellOffers = await client.request({ - method: "nft_sell_offers", - tokenid: operationalTokenIdField.value - }) - } catch (err) { - nftSellOffers = "No sell offers." - } - results += JSON.stringify(nftSellOffers,null,2) - - - results += "\n\n***Buy Offers***\n" - let nftBuyOffers - try { - nftBuyOffers = await client.request({ - method: "nft_buy_offers", - tokenid: operationalTokenIdField.value }) - } catch (err) { - nftBuyOffers = "No buy offers." - } - results += JSON.stringify(nftBuyOffers,null,2) - - - // Check transaction results ------------------------------------------------- - results +="\n\nTransaction result:\n" + - JSON.stringify(tx.result.meta.TransactionResult, null, 2) - results += "\n\nBalance changes:\n" + - JSON.stringify(xrpl.getBalanceChanges(tx.result.meta), null, 2) - client.disconnect() - // End of oPcreateBuyOffer() - } + // Check transaction results ------------------------------------------------- + results += "\n\nTransaction result:\n" + + JSON.stringify(tx.result.meta.TransactionResult, null, 2) + results += "\n\nBalance changes:\n" + + JSON.stringify(xrpl.getBalanceChanges(tx.result.meta), null, 2) + document.getElementById('operationalResultField').value = results + client.disconnect() +}// End of oPcreateBuyOffer() // ******************************************************* // ************* Operational Cancel Offer **************** // ******************************************************* +async function oPcancelOffer() { - async function oPcancelOffer() { + const wallet = xrpl.Wallet.fromSeed(operationalSeedField.value) + const client = new xrpl.Client("wss://xls20-sandbox.rippletest.net:51233") + results = 'Connecting to ' + getNet() + '...' + document.getElementById('operationalResultField').value = results + await client.connect() + results += "\nConnected. Cancelling offer..." + document.getElementById('operationalResultField').value = results + const tokenOfferIDs = [operationalTokenOfferIndexField.value] - const wallet = xrpl.Wallet.fromSeed(operationalSeedField.value) - const client = new xrpl.Client("wss://xls20-sandbox.rippletest.net:51233") - results = 'Connecting to ' + getNet() + '...' - document.getElementById('operationalResultField').value = results - await client.connect() - results += "\nConnected. Cancelling offer..." - document.getElementById('operationalResultField').value = results + // Prepare transaction ------------------------------------------------------- + const transactionBlob = { + "TransactionType": "NFTokenCancelOffer", + "Account": wallet.classicAddress, + "NFTokenOffers": tokenOfferIDs + } + // Submit transaction -------------------------------------------------------- + const tx = await client.submitAndWait(transactionBlob,{wallet}) + results += "\n\n***Sell Offers***\n" + let nftSellOffers + try { + nftSellOffers = await client.request({ + method: "nft_sell_offers", + nft_id: operationalTokenIdField.value + }) + } catch (err) { + nftSellOffers = "No sell offers." + } + results += JSON.stringify(nftSellOffers,null,2) + results += "\n\n***Buy Offers***\n" + let nftBuyOffers + try { + nftBuyOffers = await client.request({ + method: "nft_buy_offers", + nft_id: operationalTokenIdField.value }) + } catch (err) { + nftBuyOffers = "No buy offers." + } + results += JSON.stringify(nftBuyOffers,null,2) - const tokenOfferIDs = [operationalTokenOfferIndexField.value] + // Check transaction results ------------------------------------------------- + results += "\nTransaction result:\n" + + JSON.stringify(tx.result.meta.TransactionResult, null, 2) + results += "\nBalance changes:\n" + + JSON.stringify(xrpl.getBalanceChanges(tx.result.meta), null, 2) + document.getElementById('operationalResultField').value = results - // Prepare transaction ------------------------------------------------------- - const transactionBlob = { - "TransactionType": "NFTokenCancelOffer", - "Account": wallet.classicAddress, - "TokenOffers": tokenOfferIDs - } - // Submit transaction -------------------------------------------------------- - const tx = await client.submitAndWait(transactionBlob,{wallet}) - - - results += "\n\n***Sell Offers***\n" - let nftSellOffers - try { - nftSellOffers = await client.request({ - method: "nft_sell_offers", - tokenid: operationalTokenIdField.value - }) - } catch (err) { - nftSellOffers = "No sell offers." - } - results += JSON.stringify(nftSellOffers,null,2) - results += "\n\n***Buy Offers***\n" - let nftBuyOffers - try { - nftBuyOffers = await client.request({ - method: "nft_buy_offers", - tokenid: operationalTokenIdField.value }) - } catch (err) { - nftBuyOffers = "No buy offers." - } - results += JSON.stringify(nftBuyOffers,null,2) - - - // Check transaction results ------------------------------------------------- - - - results += "\nTransaction result:\n" + - JSON.stringify(tx.result.meta.TransactionResult, null, 2) - results += "\nBalance changes:\n" + - JSON.stringify(xrpl.getBalanceChanges(tx.result.meta), null, 2) - document.getElementById('operationalResultField').value = results - - - client.disconnect() - // End of oPcancelOffer() - } - + client.disconnect() +}// End of oPcancelOffer() // ******************************************************* // **************** Operational Get Offers *************** // ******************************************************* +async function oPgetOffers() { + const standby_wallet = xrpl.Wallet.fromSeed(operationalSeedField.value) + let net = getNet() + const client = new xrpl.Client(net) + results = 'Connecting to ' + getNet() + '...' + document.getElementById('operationalResultField').value = results + await client.connect() + results += '\nConnected. Getting offers...' - async function oPgetOffers() { - const standby_wallet = xrpl.Wallet.fromSeed(operationalSeedField.value) - let net = getNet() - const client = new xrpl.Client(net) - results = 'Connecting to ' + getNet() + '...' - document.getElementById('operationalResultField').value = results - await client.connect() - results += '\nConnected. Getting offers...' + results += '\n\n***Sell Offers***\n' + let nftSellOffers + try { + nftSellOffers = await client.request({ + method: "nft_sell_offers", + nft_id: operationalTokenIdField.value}) + } catch (err) { + nftSellOffers = 'No sell offers.' + } + results += JSON.stringify(nftSellOffers,null,2) - results += '\n\n***Sell Offers***\n' + document.getElementById('standbyResultField').value = results + results += '\n\n***Buy Offers***\n' + let nftBuyOffers + try { + nftBuyOffers = await client.request({ + method: "nft_buy_offers", + nft_id: operationalTokenIdField.value }) + } catch (err) { + nftBuyOffers = 'No buy offers.' + } + results += JSON.stringify(nftBuyOffers,null,2) + document.getElementById('operationalResultField').value = results - let nftSellOffers - try { - nftSellOffers = await client.request({ - method: "nft_sell_offers", - tokenid: operationalTokenIdField.value - }) - } catch (err) { - nftSellOffers = 'No sell offers.' - } - results += JSON.stringify(nftSellOffers,null,2) - - - results += '\n\n***Buy Offers***\n' - let nftBuyOffers - try { - nftBuyOffers = await client.request({ - method: "nft_buy_offers", - tokenid: operationalTokenIdField.value }) - } catch (err) { - nftBuyOffers = 'No buy offers.' - } - results += JSON.stringify(nftBuyOffers,null,2) - - - document.getElementById('operationalResultField').value = results - - - client.disconnect() - // End of oPgetOffers() - } - + client.disconnect() +}// End of oPgetOffers() // ******************************************************* // *************** Operational Accept Sell Offer ********* // ******************************************************* +async function oPacceptSellOffer() { + const standby_wallet = xrpl.Wallet.fromSeed(standbySeedField.value) + const operational_wallet = xrpl.Wallet.fromSeed(operationalSeedField.value) + let net = getNet() + const client = new xrpl.Client(net) + results = 'Connecting to ' + getNet() + '...' + document.getElementById('operationalResultField').value = results + await client.connect() + results += '\nConnected. Accepting sell offer...\n\n' + document.getElementById('operationalResultField').value = results - async function oPacceptSellOffer() { - const standby_wallet = xrpl.Wallet.fromSeed(standbySeedField.value) - const operational_wallet = xrpl.Wallet.fromSeed(operationalSeedField.value) - let net = getNet() - const client = new xrpl.Client(net) - results = 'Connecting to ' + getNet() + '...' - document.getElementById('operationalResultField').value = results - await client.connect() - results = '\nConnected. Accepting sell offer...\n\n' - document.getElementById('operationalResultField').value = results + // Prepare transaction ------------------------------------------------------- + const transactionBlob = { + "TransactionType": "NFTokenAcceptOffer", + "Account": operational_wallet.classicAddress, + "NFTokenSellOffer": operationalTokenOfferIndexField.value, + } + // Submit transaction -------------------------------------------------------- + const tx = await client.submitAndWait(transactionBlob,{wallet: operational_wallet}) + const nfts = await client.request({ + method: "account_nfts", + account: operational_wallet.classicAddress }) + // Check transaction results ------------------------------------------------- - // Prepare transaction ------------------------------------------------------- - const transactionBlob = { - "TransactionType": "NFTokenAcceptOffer", - "Account": operational_wallet.classicAddress, - "SellOffer": operationalTokenOfferIndexField.value, - } - // Submit transaction -------------------------------------------------------- - const tx = await client.submitAndWait(transactionBlob,{wallet: operational_wallet}) - const nfts = await client.request({ - method: "account_nfts", - account: operational_wallet.classicAddress - }) + document.getElementById('standbyBalanceField').value = + (await client.getXrpBalance(standby_wallet.address)) + document.getElementById('operationalBalanceField').value = + (await client.getXrpBalance(operational_wallet.address)) - - // Check transaction results ------------------------------------------------- - - - - - document.getElementById('standbyBalanceField').value = - (await client.getXrpBalance(standby_wallet.address)) - document.getElementById('operationalBalanceField').value = - (await client.getXrpBalance(operational_wallet.address)) - - - results += 'Transaction result:\n' - results += JSON.stringify(tx.result.meta.TransactionResult, null, 2) - results += '\nBalance changes:' - results += JSON.stringify(xrpl.getBalanceChanges(tx.result.meta), null, 2) - results += JSON.stringify(nfts,null,2) - - - document.getElementById('operationalResultField').value = results - - - client.disconnect() - // End of acceptSellOffer() - } + results += 'Transaction result:\n' + results += JSON.stringify(tx.result.meta.TransactionResult, null, 2) + results += '\nBalance changes:' + results += JSON.stringify(xrpl.getBalanceChanges(tx.result.meta), null, 2) + results += JSON.stringify(nfts,null,2) + document.getElementById('operationalResultField').value = results + client.disconnect() +}// End of acceptSellOffer() // ******************************************************* // ********* Operational Accept Buy Offer **************** // ******************************************************* +async function oPacceptBuyOffer() { + const standby_wallet = xrpl.Wallet.fromSeed(standbySeedField.value) + const operational_wallet = xrpl.Wallet.fromSeed(operationalSeedField.value) + let net = getNet() + const client = new xrpl.Client(net) + results = 'Connecting to ' + getNet() + '...' + document.getElementById('operationalResultField').value = results + await client.connect() + results += '\nConnected. Accepting buy offer...' + document.getElementById('operationalResultField').value = results - async function oPacceptBuyOffer() { - const standby_wallet = xrpl.Wallet.fromSeed(standbySeedField.value) - const operational_wallet = xrpl.Wallet.fromSeed(operationalSeedField.value) - let net = getNet() - const client = new xrpl.Client(net) - results = 'Connecting to ' + getNet() + '...' - document.getElementById('operationalResultField').value = results - await client.connect() - results += '\nConnected. Accepting buy offer...' - document.getElementById('operationalResultField').value = results + // Prepare transaction ------------------------------------------------------- + const transactionBlob = { + "TransactionType": "NFTokenAcceptOffer", + "Account": operational_wallet.classicAddress, + "NFTokenBuyOffer": operationalTokenOfferIndexField.value + } + // Submit transaction -------------------------------------------------------- + const tx = await client.submitAndWait(transactionBlob,{wallet: operational_wallet}) + const nfts = await client.request({ + method: "account_nfts", + account: operational_wallet.classicAddress }) + results += JSON.stringify(nfts,null,2) + document.getElementById('operationalResultField').value = results - // Prepare transaction ------------------------------------------------------- - const transactionBlob = { - "TransactionType": "NFTokenAcceptOffer", - "Account": operational_wallet.classicAddress, - "BuyOffer": operationalTokenOfferIndexField.value - } - // Submit transaction -------------------------------------------------------- - const tx = await client.submitAndWait(transactionBlob,{wallet: operational_wallet}) - const nfts = await client.request({ - method: "account_nfts", - account: operational_wallet.classicAddress - }) - results += JSON.stringify(nfts,null,2) - document.getElementById('operationalResultField').value = results - - // Check transaction results ------------------------------------------------- - result += "\n\nTransaction result:\n" + - JSON.stringify(tx.result.meta.TransactionResult, null, 2) - result += "\nBalance changes:\n" + - JSON.stringify(xrpl.getBalanceChanges(tx.result.meta), null, 2) - document.getElementById('operationalBalanceField').value = - (await client.getXrpBalance(operational_wallet.address)) - document.getElementById('operationalBalanceField').value = - (await client.getXrpBalance(standby_wallet.address)) - document.getElementById('operationalResultField').value = results - client.disconnect() - // End of acceptBuyOffer() - } + // Check transaction results ------------------------------------------------- + results += "\n\nTransaction result:\n" + + JSON.stringify(tx.result.meta.TransactionResult, null, 2) + results += "\nBalance changes:\n" + + JSON.stringify(xrpl.getBalanceChanges(tx.result.meta), null, 2) + document.getElementById('operationalBalanceField').value = + (await client.getXrpBalance(operational_wallet.address)) + document.getElementById('operationalBalanceField').value = + (await client.getXrpBalance(standby_wallet.address)) + document.getElementById('operationalResultField').value = results + client.disconnect() +}// End of acceptBuyOffer() ``` @@ -1187,6 +1162,26 @@ Update the form with fields and buttons to support the new functions. ``` + + + + + +
+@@ -1463,7 +1471,7 @@ Update the form with fields and buttons to support the new functions.