Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fabo/1294 undelegation modal #1367

Merged
merged 36 commits into from
Oct 5, 2018
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
36 commits
Select commit Hold shift + click to select a range
b22ee0a
copied staking modal
Sep 26, 2018
defec9f
unstaking working
Sep 26, 2018
3a72ac8
copied unstake modal spec
Sep 26, 2018
f06915c
Copy ModalUnstake tests in PageValidator.spec.js and start adapting t…
Sep 26, 2018
fdc3f5d
Merge branch 'develop' into fabo/1294-undelegation-modal
faboweb Sep 26, 2018
4e47112
Merge branch 'develop' into fabo/1294-undelegation-modal
jbibla Sep 27, 2018
4bff2d2
Make all unit tests pass for unstaking.
Sep 27, 2018
f38db9f
fix status color missing
Sep 28, 2018
5a5df5d
Merge remote-tracking branch 'origin/develop' into fabo/1294-undelega…
Sep 28, 2018
05a4324
added ux updates to modal unstake
Sep 28, 2018
2740908
changelog
Sep 28, 2018
0a55983
linted
Sep 28, 2018
885ed25
fixed tests
Sep 28, 2018
2e55de3
fixed snapshots
Sep 28, 2018
7bea969
Add E2E test for unstaking.
Oct 1, 2018
47d6078
fix less then 0.01 displaying
Oct 1, 2018
d52ea53
reverted disabling of unstake button
Oct 1, 2018
2abd961
fixed snapshot
Oct 1, 2018
c274d74
Merge remote-tracking branch 'refs/remotes/origin/develop'
Oct 1, 2018
82e31fa
Merge remote-tracking branch 'refs/remotes/origin/develop'Conflicts: …
Oct 1, 2018
9c1b694
linted
Oct 1, 2018
4a96733
fixed e2e tests
Oct 1, 2018
43f5d88
fix e2e tests
Oct 1, 2018
86a9fe0
fix snapshot
Oct 1, 2018
f157c9e
fix naming
Oct 1, 2018
d7693f7
uncommented console error file
Oct 1, 2018
e9e5517
Merge branch 'develop' into fabo/1294-undelegation-modal
faboweb Oct 2, 2018
685c886
merged develop
Oct 2, 2018
39a96dc
Merge remote-tracking branch 'origin/develop' into fabo/1294-undelega…
Oct 2, 2018
0374842
fixed
Oct 4, 2018
40fdadd
add a delegation to the validator page snapshot
Oct 4, 2018
6f30319
fixed merge conflicts
Oct 4, 2018
99032b0
Merge branch 'develop' into fabo/1294-undelegation-modal
faboweb Oct 4, 2018
6fe71a6
close signal, disable button, denom and tests
Oct 5, 2018
ca2a054
fix unit tests
Oct 5, 2018
aed26e5
Merge branch 'develop' into fabo/1294-undelegation-modal
fedekunze Oct 5, 2018
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 2 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,8 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0.
* Add commission and uptime to LiValidator @fedekunze
* Delete old bonding page @fedekunze
* `watch` script for running unit tests @faboweb @NodeGuy
* added unstake modal @faboweb
* `watch` script for running unit tests @faboweb @NodeGuy

### Changed

Expand Down
1 change: 1 addition & 0 deletions app/src/renderer/components/common/TmModal.vue
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ div(:class='cssClass' @click.self="close()")

<script>
export default {
name: `tm-modal`,
computed: {
cssClass() {
let value = `tm-modal`
Expand Down
14 changes: 6 additions & 8 deletions app/src/renderer/components/staking/DelegationModal.vue
Original file line number Diff line number Diff line change
Expand Up @@ -12,8 +12,7 @@
tm-field#denom(
type="number"
:placeholder="bondingDenom"
readonly
)
readonly)

tm-field#amount(
type="number"
Expand All @@ -37,11 +36,6 @@
)

.delegation-modal-footer
tm-btn(
@click.native="close"
size="lg"
value="Cancel"
)
tm-btn(
@click.native="onDelegation"
:disabled="$v.amount.$invalid"
Expand All @@ -51,14 +45,18 @@
</template>

<script>
import { mapGetters } from "vuex"
import ClickOutside from "vue-click-outside"
import { required, between } from "vuelidate/lib/validators"
import Modal from "common/TmModal"
import { TmBtn, TmField, TmFormGroup, TmFormMsg } from "@tendermint/ui"

export default {
name: `delegation-modal`,
props: [`bondingDenom`, `fromOptions`, `to`],
props: [`fromOptions`, `to`],
computed: {
...mapGetters([`bondingDenom`])
},
components: {
Modal,
TmBtn,
Expand Down
42 changes: 20 additions & 22 deletions app/src/renderer/components/staking/LiValidator.vue
Original file line number Diff line number Diff line change
Expand Up @@ -2,14 +2,14 @@
li.li-validator(:class='styles')
router-link(:to="{ name: 'validator', params: { validator: validator.id }}")
.li-validator__value.name
span.validator-profile__status(v-tooltip.top="status")
span.validator-profile__status(v-bind:class="statusColor" v-tooltip.top="status")
img.avatar(v-if="validator.keybase" :src="validator.keybase.avatarUrl" width="48" height="48")
img.avatar(v-else src="~assets/images/validator-icon.svg" width="48" height="48")
.vert
.top {{ validator.description.moniker }}
.bottom {{ shortAddress(validator.id)}}
.li-validator__value.your-votes
span {{ yourVotes }}
span {{ yourVotes.isLessThan(0.01) && yourVotes.isGreaterThan(0) ? '< ' + num.pretty(0.01) : num.pretty(yourVotes) }}
.li-validator__value.your-rewards
span n/a
.li-validator__break: span
Expand All @@ -29,6 +29,7 @@ li.li-validator(:class='styles')
import { mapGetters } from "vuex"
import num from "scripts/num"
import { shortAddress, calculateTokens, ratToBigNumber } from "scripts/common"
import BigNumber from "bignumber.js"
export default {
name: `li-validator`,
props: [`validator`, `disabled`],
Expand Down Expand Up @@ -77,14 +78,12 @@ export default {
// } else return "0"
// },
yourVotes() {
return this.num.pretty(
this.committedDelegations[this.validator.id]
? calculateTokens(
this.validator,
this.committedDelegations[this.validator.id]
).toString()
: `0`
)
return this.committedDelegations[this.validator.id]
? calculateTokens(
this.validator,
this.committedDelegations[this.validator.id]
)
: BigNumber(0)
},
styles() {
let value = ``
Expand Down Expand Up @@ -124,18 +123,17 @@ export default {

// status: validator
return `This validator is actively validating`
},
faboweb marked this conversation as resolved.
Show resolved Hide resolved
statusColor() {
// status: jailed
if (this.validator.revoked) return `red`

// status: candidate
if (parseFloat(this.validator.voting_power) === 0) return `yellow`

// status: validator
return `green`
}
// TODO enable once we decide on limits
// statusColor() {
// // status: jailed
// if (this.validator.revoked) return "red"
//
// // status: candidate
// if (parseFloat(this.validator.voting_power) === 0) return "yellow"
//
// // status: validator
// return "green"
// }
},
data: () => ({ num, shortAddress })
}
Expand Down Expand Up @@ -279,7 +277,7 @@ ol li
height 82px

ol li:before
content counter(counter) ""
content counter(counter) ''
color var(--dim)
font-size sm
position absolute
Expand Down
106 changes: 89 additions & 17 deletions app/src/renderer/components/staking/PageValidator.vue
Original file line number Diff line number Diff line change
Expand Up @@ -21,12 +21,18 @@ tm-page
//- TODO replace with address component when ready
anchor-copy.validator-profile__header__name__address(:value="validator.owner" :label="shortAddress(validator.owner)")
.column.validator-profile__header__actions
tm-btn(value="Delegate" color="primary" @click.native="onDelegation()")#delegation-btn
tm-btn(v-if="config.devMode" value="Undelegate" color="secondary")#undelegation-btn
tm-btn#delegation-btn(value="Delegate" color="primary" @click.native="onDelegation")

tm-btn#undelegation-btn(
value="Undelegate"
color="secondary"
@click.native="onUndelegation"
)

.row.validator-profile__header__data
dl.colored_dl
dt Bonded {{bondingDenom}}
dd {{ myBond < 0.01 ? '< ' + 0.01 : pretty(myBond)}}
dd {{myBond.isLessThan(0.01) && myBond.isGreaterThan(0) ? '< ' + 0.01 : pretty(myBond)}}
dl.colored_dl(v-if="config.devMode")
dt My Rewards
dd n/a
Expand Down Expand Up @@ -85,25 +91,38 @@ tm-page
delegation-modal(
v-if="showDelegationModal"
v-on:submitDelegation="submitDelegation"
:bondingDenom="bondingDenom"
:showDelegationModal.sync="showDelegationModal"
:fromOptions="modalOptions()"
:fromOptions="delegationTargetOptions()"
:to="validator.owner"
)

tm-modal(:close="closeCannotDelegate" icon="warning" v-if="showCannotDelegate")
div(slot='title') Cannot Complete Delegation
p You have no {{ bondingDenom }}s to delegate.
undelegation-modal(
v-if="showUndelegationModal"
v-on:submitUndelegation="submitUndelegation"
:showUndelegationModal.sync="showUndelegationModal"
:maximum="myBond"
:to="this.wallet.address"
)
tm-modal(:close="closeCannotModal" icon="warning" v-if="showCannotModal")
div(slot='title') Cannot Complete {{ action == `delegate`? `Delegation` : `Undelegation` }}
p You have no {{ bondingDenom }}s {{ action == `undelegate` ? `delegated `: `` }}to {{ action == `delegate` ? `delegate.` : `this validator.` }}
div(slot='footer')
tmBtn(id="no-atoms-modal__btn" @click.native="closeCannotDelegate()" value="OK")
tmBtn(
id="no-atoms-modal__btn"
@click.native="closeCannotModal"
value="OK"
)
</template>

<script>
import { calculateTokens } from "scripts/common"
import { mapGetters } from "vuex"
import { TmBtn, TmListItem, TmPage, TmPart, TmToolBar } from "@tendermint/ui"
import TmModal from "common/TmModal"
import { TmDataError } from "common/TmDataError"
import { shortAddress, ratToBigNumber } from "scripts/common"
import DelegationModal from "staking/DelegationModal"
import UndelegationModal from "staking/UndelegationModal"
import numeral from "numeral"
import AnchorCopy from "common/AnchorCopy"
import TmBalance from "common/TmBalance"
Expand All @@ -113,20 +132,23 @@ export default {
components: {
AnchorCopy,
DelegationModal,
UndelegationModal,
TmBtn,
TmListItem,
TmBalance,
TmModal,
TmPage,
TmPart,
TmToolBar,
TmDataError,
TmBalance
},
data: () => ({
showCannotDelegate: false,
showCannotModal: false,
showDelegationModal: false,
showUndelegationModal: false,
shortAddress,
tabIndex: 1
tabIndex: 1,
action: ``
}),
computed: {
...mapGetters([
Expand Down Expand Up @@ -154,7 +176,10 @@ export default {
: 0
},
myBond() {
return this.delegation.committedDelegates[this.validator.owner] || 0
return calculateTokens(
this.validator,
this.committedDelegations[this.validator.owner] || 0
)
},
powerRatio() {
return ratToBigNumber(this.validator.tokens)
Expand Down Expand Up @@ -200,14 +225,23 @@ export default {
}
},
methods: {
closeCannotDelegate() {
this.showCannotDelegate = false
closeCannotModal() {
this.showCannotModal = false
},
onDelegation() {
this.action = `delegate`
if (this.availableAtoms > 0) {
this.showDelegationModal = true
} else {
this.showCannotDelegate = true
this.showCannotModal = true
}
},
onUndelegation() {
this.action = `undelegate`
if (this.myBond.isGreaterThan(0)) {
this.showUndelegationModal = true
} else {
this.showCannotModal = true
}
},
async submitDelegation({ amount, from }) {
Expand Down Expand Up @@ -272,7 +306,45 @@ export default {
}
}
},
modalOptions() {
async submitUndelegation({ amount }) {
try {
await this.$store.dispatch(`submitDelegation`, {
stakingTransactions: {
unbondings: [
{
atoms: -amount,
validator: this.validator
}
]
}
})

this.$store.commit(`notify`, {
title: `Successful Undelegation!`,
body: `You have successfully undelegated ${amount} ${
this.bondingDenom
}s.`
})
} catch (exception) {
const { message } = exception
let errData = message.split(`\n`)[5]

if (errData) {
let parsedErr = errData.split(`"`)[1]

this.$store.commit(`notifyError`, {
title: `Error while undelegating ${this.bondingDenom}s`,
body: parsedErr[0].toUpperCase() + parsedErr.slice(1)
})
} else {
this.$store.commit(`notifyError`, {
title: `Error while undelegating ${this.bondingDenom}s`,
body: message
})
}
}
},
delegationTargetOptions() {
//- First option should always be your wallet (i.e normal delegation)
let myWallet = [
{
Expand Down
Loading