Party members in header v2 (#8815)

* update comemnt

* flyout on hover

* fix hasClass and isBuffed

* polish members in party header
This commit is contained in:
Matteo Pagliazzi
2017-06-13 20:55:45 +02:00
committed by GitHub
parent 292b2acb1e
commit 592345e22c
4 changed files with 63 additions and 28 deletions

View File

@@ -25,7 +25,7 @@
border-color: transparent; border-color: transparent;
} }
&:active { &:active, &.active {
box-shadow: none; box-shadow: none;
border: 1px solid transparent; border: 1px solid transparent;
} }
@@ -44,8 +44,9 @@
background: $purple-200; background: $purple-200;
} }
&:hover:not(:disabled), &:active { &:hover:not(:disabled), &:active, &.active, &:focus {
background: #5d3b9c; background: #5d3b9c;
color: $white;
} }
} }
@@ -53,11 +54,11 @@
color: $gray-50; color: $gray-50;
background: $white !important; background: $white !important;
&:hover:not(:disabled):not(.disabled), &:active, &:focus { &:hover:not(:disabled):not(.disabled), &:active, &.active, &:focus {
color: $purple-200 !important; color: $purple-200 !important;
} }
&:active, &:focus { &:active, &:focus, &.active {
border-color: $purple-500 !important; border-color: $purple-500 !important;
} }
@@ -74,7 +75,7 @@
background: $green-10; background: $green-10;
} }
&:hover:not(:disabled), &:active { &:hover:not(:disabled), &:active, &.active {
background: $green-50; background: $green-50;
} }
} }
@@ -86,7 +87,7 @@
background: $blue-50; background: $blue-50;
} }
&:hover:not(:disabled), &:active { &:hover:not(:disabled), &:active, &.active {
background: $blue-100; background: $blue-100;
} }
} }
@@ -98,7 +99,7 @@
background: $red-50; background: $red-50;
} }
&:hover:not(:disabled), &:active { &:hover:not(:disabled), &:active, &.active {
background: $red-100; background: $red-100;
} }
} }

View File

@@ -1,3 +1,7 @@
html {
overflow-x: hidden;
}
html, body { html, body {
height: 100%; height: 100%;
background: $gray-700; background: $gray-700;

View File

@@ -1,24 +1,26 @@
<template lang="pug"> <template lang="pug">
#app-header.row #app-header.row
member-details(:member="user", @click="$router.push({name: 'avatar'})") member-details(:member="user", @click="$router.push({name: 'avatar'})")
.view-party
// TODO button should open the party members modal
router-link.btn.btn-primary(:active-class="''", :to="{name: 'party'}") {{ $t('viewParty') }}
.party-members.d-flex(v-if="partyMembers && partyMembers.length > 1") .party-members.d-flex(v-if="partyMembers && partyMembers.length > 1")
member-details( member-details(
v-for="member in partyMembers", v-for="(member, $index) in partyMembers",
:key="member._id", :key="member._id",
v-if="member._id !== user._id", v-if="member._id !== user._id && $index < 10",
:member="member", :member="member",
condensed=true, condensed=true,
@click="expandMember(member._id)" @onHover="expandMember(member._id)",
:expanded="member._id === expandedMember", :expanded="member._id === expandedMember",
) )
button.btn.btn-primary {{ $t('viewParty') }}
.no-party.d-flex.justify-content-center.text-center(v-else) .no-party.d-flex.justify-content-center.text-center(v-else)
.align-self-center(v-once) .align-self-center(v-once)
h3 {{ $t('battleWithFriends') }} h3 {{ $t('battleWithFriends') }}
span.small-text(v-html="$t('inviteFriendsParty')") span.small-text(v-html="$t('inviteFriendsParty')")
br br
// TODO link to party creation // TODO link to party creation or party page if partying solo
button.btn.btn-primary {{ $t('startAParty') }} router-link.btn.btn-primary(:active-class="''", :to="{name: 'party'}") {{ $t('startAParty') }}
</template> </template>
<style lang="scss" scoped> <style lang="scss" scoped>
@@ -31,6 +33,7 @@
height: 204px; height: 204px;
color: $header-color; color: $header-color;
flex-wrap: nowrap; flex-wrap: nowrap;
position: relative;
} }
.no-party, .party-members { .no-party, .party-members {
@@ -38,7 +41,19 @@
} }
.party-members { .party-members {
overflow-x: auto; }
.view-party {
position: absolute;
z-index: 10;
right: 0;
padding-right: 40px;
height: 100%;
background-image: linear-gradient(to right, rgba($purple-50, 0), $purple-50);
.btn {
margin-top: 75%;
}
} }
.no-party { .no-party {

View File

@@ -1,6 +1,10 @@
<template lang="pug"> <template lang="pug">
.d-flex.member-details(:class="{ condensed, expanded }") .d-flex.member-details(:class="{ condensed, expanded }")
avatar(:member="member", @click.native="$emit('click')",) avatar(:member="member",
@click.native="$emit('click')",
@mouseover.native="$emit('onHover')",
@mouseout.native="$emit('onHover')",
)
.member-stats .member-stats
h3.character-name h3.character-name
| {{member.profile.name}} | {{member.profile.name}}
@@ -31,7 +35,7 @@
white-space: nowrap; white-space: nowrap;
margin-top: 24px; margin-top: 24px;
margin-bottom: 24px; margin-bottom: 24px;
transition: all .15s ease; transition: all 0.15s ease-out;
} }
.member-stats { .member-stats {
@@ -39,7 +43,7 @@
padding-right: 24px; padding-right: 24px;
height: auto; height: auto;
opacity: 1; opacity: 1;
transition: all 0.15s ease-out; transition: opacity 0.15s ease-out;
} }
.member-details.condensed:not(.expanded) .member-stats { .member-details.condensed:not(.expanded) .member-stats {
@@ -52,18 +56,28 @@
// Condensed version // Condensed version
.member-details.condensed.expanded { .member-details.condensed.expanded {
background: $header-dark-background; background: $header-dark-background;
padding-top: 9px; box-shadow: 0 0 0px 9px $header-dark-background;
margin-top: 15px; position: relative;
border-radius: 4px; margin-bottom: 33px;
padding-left: 9px; z-index: 8;
box-shadow: 0 2px 2px 0 rgba($black, 0.16), 0 1px 4px 0 rgba($black, 0.12);
.is-buffed { .is-buffed {
background-color: $purple-50; background-color: $purple-50;
} }
.member-stats { .member-stats {
background: $header-dark-background;
position: absolute;
right: 100%;
height: calc(100% + 18px);
margin-top: -9px;
padding-top: 9px;
padding-bottom: 24px;
padding-right: 16px; padding-right: 16px;
padding-bottom: 14px;
border-top-left-radius: 4px;
border-bottom-left-radius: 4px;
z-index: 9;
} }
.progress-container > .svg-icon { .progress-container > .svg-icon {
@@ -77,6 +91,7 @@
border-radius: 0px; border-radius: 0px;
height: 10px; height: 10px;
margin-top: 2px; margin-top: 2px;
background: $purple-100;
} }
.progress-container > .progress > .progress-bar { .progress-container > .progress > .progress-bar {
@@ -195,12 +210,6 @@ export default {
}, },
methods: { methods: {
percent, percent,
hasClass () {
return this.$store.getters['members:hasClass'](this.member);
},
isBuffed () {
return this.$store.getters['members:isBuffed'](this.member);
},
}, },
computed: { computed: {
...mapState({ ...mapState({
@@ -217,6 +226,12 @@ export default {
this.member.stats.class ? this.$t(this.member.stats.class) : '' this.member.stats.class ? this.$t(this.member.stats.class) : ''
}`; }`;
}, },
isBuffed () {
return this.$store.getters['members:isBuffed'](this.member);
},
hasClass () {
return this.$store.getters['members:hasClass'](this.member);
},
}, },
}; };
</script> </script>