mirror of
https://github.com/lnbits/lnbits-legend.git
synced 2025-02-25 15:10:41 +01:00
* feat: add `Share PSBT` button with options * feat: add basic communication via the serial port * chore: code format * feat: send data to and from serial port * fix: port disconnect * feat: handle psbt extract * feat: show signed transaction details * fix: handle Connect/Disconnect failure state * feat:small UI improvements * feat: broadcast transaction (partial solution) * feat: integrate psbt response from HWW * feat: login and send commands to HWW * feat: ui improvements * feat: ui/ux improvements * feat: more small UI impreovemsnts * feat: simplify UI * feat: add `help` command * feat: add wipe command * feet: add `seed` command * feat: add `restore` command * feat: always show PSBT input text (for outside PSBTs) * feat: show spinner while signing tx * feat: hide panels after transaction is broadcast * feat: basic use of custom components * refactor: move components one folder up * refactor: extract wallet-config * refactor: extract `wallet-list` component * refactor: clean-up * chore: code format html component files * refactor: extract address-list component * refactor: extract `history` component * refactor: extract `utxo-list` component * feat: UI/UX improvements * feat: partial payment redesign * refactor: rename `fee` to `fee-rate` * refactor: rename component * refactor: extract `send-to` component * refactor: payment: first migration * fix: init `sendToList` * fix: change address * fix: change address and `Select All` coins * feat: show custom fees & two way binding for addresses * fix: scanAddressesWithAmount * fix: max amount * fix: coin selection mode * chore: code clean-up * feat: shuffle the UI * fix: change amount * feat: update tx size in real time * fix: coin selection * fix: show erro messages * fix: psbt generation * refactor: move serial port logic * refactor: payment component * refactor: code clean-up; use `slot` for `serial-signer` * feat: toggle serial port * feat: add Disconnect command * feat: prompt for `Connect` and `Login` before signing * refactor: send psbt to device * feat: extract signed transaction * refactor: code clean-up * feat: show auth green icon * chore: code clean-up * feat: show console * feat: allow `Connect` from dropdown menu * fix: stop if serial port cannot be open * feat: confirm outputs and fee * feat: add cancel command * fix: add `sats-denominated` for confirmations * feat: wait for HWW to authenticate, then open dialog * feat: share PSBT as text * refactor: extract `refreshAddresses` * feat: small UI improvements * feat: add default `Mainnet` network * feat: fix mempool endpint * feat: propagate config update only when explicitly updated * feat: add network for wallet accounts * fix: stop scanning when network changed * chore: code clean-up * chore: code clean-up * feat: show hardware device Xpub option * fix: handle failed to parse psbt * feat: add accounts using the HWW * fix: testnet is in the bip32 derivation path * feat: add spinner while wallet account is created * fix: check network and masterpub for duplicate accounts * feat: integrate transaction broadcast * feat: add password confirmation for `Wipe` and `Restore` * fix: fingerprint is not unique per account (it is the fingerprint of the master) * chore: code clean-up, remove `masterpub_fingerprint` * fix: account name diplay * chore: code format * fix: memppol links * fix: shortcut buttons * fix: note update * chore: code format * chore: clean-up rebase left overs * chore: clean-up * feat: less technical labels for addresses * feat: add serial port config params * fix: address type selection * chore: drop `mempool` table * fix: change & fee value * fix: handle no input signed scenario * fix: sat/btc unit * fix: small UI stuff * doc: update the readme * Update README.md
81 lines
2 KiB
JavaScript
81 lines
2 KiB
JavaScript
async function sendTo(path) {
|
|
const template = await loadTemplateAsync(path)
|
|
Vue.component('send-to', {
|
|
name: 'send-to',
|
|
template,
|
|
|
|
props: [
|
|
'data',
|
|
'tx-size',
|
|
'selected-amount',
|
|
'fee-rate',
|
|
'sats-denominated'
|
|
],
|
|
|
|
computed: {
|
|
dataLocal: {
|
|
get: function () {
|
|
return this.data
|
|
},
|
|
set: function (value) {
|
|
console.log('### computed update data', value)
|
|
this.$emit('update:data', value)
|
|
}
|
|
}
|
|
},
|
|
|
|
data: function () {
|
|
return {
|
|
DUST_LIMIT: 546,
|
|
paymentTable: {
|
|
columns: [
|
|
{
|
|
name: 'data',
|
|
align: 'left'
|
|
}
|
|
],
|
|
pagination: {
|
|
rowsPerPage: 10
|
|
},
|
|
filter: ''
|
|
}
|
|
}
|
|
},
|
|
|
|
methods: {
|
|
satBtc(val, showUnit = true) {
|
|
return satOrBtc(val, showUnit, this.satsDenominated)
|
|
},
|
|
addPaymentAddress: function () {
|
|
this.dataLocal.push({address: '', amount: undefined})
|
|
this.handleOutputsChange()
|
|
},
|
|
deletePaymentAddress: function (v) {
|
|
const index = this.dataLocal.indexOf(v)
|
|
if (index !== -1) {
|
|
this.dataLocal.splice(index, 1)
|
|
}
|
|
this.handleOutputsChange()
|
|
},
|
|
|
|
sendMaxToAddress: function (paymentAddress = {}) {
|
|
const feeValue = this.feeRate * this.txSize
|
|
const inputAmount = this.selectedAmount
|
|
const currentAmount = Math.max(0, paymentAddress.amount || 0)
|
|
const payedAmount = this.getTotalPaymentAmount() - currentAmount
|
|
paymentAddress.amount = Math.max(
|
|
0,
|
|
inputAmount - payedAmount - feeValue
|
|
)
|
|
},
|
|
handleOutputsChange: function () {
|
|
this.$emit('update:outputs')
|
|
},
|
|
getTotalPaymentAmount: function () {
|
|
return this.dataLocal.reduce((t, a) => t + (a.amount || 0), 0)
|
|
}
|
|
},
|
|
|
|
created: async function () {}
|
|
})
|
|
}
|