mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-14 21:27:23 +01:00
* Footer style fixes * Limited string display * Fixed background reload * Began adding more avatar items * Fixed challenge updated cats and official to be seen by admins * Fixed min prize * Fixed required fields * Added my challenges and find challenges to menu * Removed nav to party page when have no party * Updated user and notifications icon * Added accept, reject and messages * Added selfcare * Underline links * Added forgot password * Fixed task adding * Disabled habit options that should be * Added markdown to tags * Added confirm to delete * Fixed cancel/delete style * Fixed rounding * Added gold icon * Fixed task icon styles * Fixed margin botton * Fixed some repeat styles * Fixed custom reward style * Hide like count 0 * Added new tavern images * Redirect to party page after create * Hid leader options from non leaders * Removed manager options from non group plan * Fixed some nav styles * Fixed overlay color * Prevented edit data from being transfered to create * Added hover state for spells * Add performance fixes for chat avatars * Fixed merge conflicts * Updated fron navigation * Fixed reg gryphon logo * Began adding gem modal functionality * Added purchase gems with gold * Fixed restore * Replaced description with summary * Spells that target tasks fix * Added initial challenge task load * Fixed lint issue
140 lines
3.3 KiB
Vue
140 lines
3.3 KiB
Vue
<template lang="pug">
|
|
#app-header.row
|
|
create-party-modal
|
|
members-modal(:hide-badge="true")
|
|
member-details(:member="user")
|
|
.view-party(v-if="user.party && user.party._id && partyMembers && partyMembers.length > 1")
|
|
// TODO button should open the party members modal
|
|
button.btn.btn-primary(@click='openPartyModal()') {{ $t('viewParty') }}
|
|
.col-6.party-members.d-flex.flex-row(v-if="partyMembers && partyMembers.length > 1")
|
|
member-details(
|
|
v-for="(member, $index) in partyMembers",
|
|
:key="member._id",
|
|
v-if="member._id !== user._id && $index < 10",
|
|
:member="member",
|
|
condensed=true,
|
|
@onHover="expandMember(member._id)",
|
|
:expanded="member._id === expandedMember",
|
|
)
|
|
.no-party.d-flex.justify-content-center.text-center(v-else)
|
|
.align-self-center(v-once)
|
|
h3 {{ $t('battleWithFriends') }}
|
|
span.small-text(v-html="$t('inviteFriendsParty')")
|
|
br
|
|
// TODO link to party creation or party page if partying solo
|
|
a.btn.btn-primary(@click='openPartyModal()') {{ $t('startAParty') }}
|
|
</template>
|
|
|
|
<style lang="scss" scoped>
|
|
@import '~client/assets/scss/colors.scss';
|
|
|
|
#app-header {
|
|
padding-left: 14px;
|
|
margin-top: 56px;
|
|
background: $purple-50;
|
|
height: 204px;
|
|
color: $header-color;
|
|
flex-wrap: nowrap;
|
|
position: relative;
|
|
}
|
|
|
|
.sticky {
|
|
position: fixed !important;
|
|
width: 100%;
|
|
z-index: 1;
|
|
}
|
|
|
|
.no-party, .party-members {
|
|
flex-grow: 1;
|
|
}
|
|
|
|
.party-members {
|
|
max-width: 100%;
|
|
overflow: scroll;
|
|
}
|
|
|
|
.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 {
|
|
.small-text {
|
|
color: $header-color;
|
|
flex-wrap: nowrap;
|
|
}
|
|
|
|
h3 {
|
|
color: $white;
|
|
margin-bottom: 4px;
|
|
}
|
|
|
|
.btn {
|
|
margin-top: 16px;
|
|
}
|
|
}
|
|
</style>
|
|
|
|
<script>
|
|
import { mapGetters, mapActions } from 'client/libs/store';
|
|
import MemberDetails from './memberDetails';
|
|
import createPartyModal from './groups/createPartyModal';
|
|
import membersModal from './groups/membersModal';
|
|
|
|
export default {
|
|
components: {
|
|
MemberDetails,
|
|
createPartyModal,
|
|
membersModal,
|
|
},
|
|
data () {
|
|
return {
|
|
expandedMember: null,
|
|
};
|
|
},
|
|
computed: {
|
|
...mapGetters({
|
|
user: 'user:data',
|
|
partyMembers: 'party:members',
|
|
}),
|
|
showHeader () {
|
|
if (this.$store.state.hideHeader) return false;
|
|
return true;
|
|
},
|
|
},
|
|
methods: {
|
|
...mapActions({
|
|
getPartyMembers: 'party:getMembers',
|
|
}),
|
|
expandMember (memberId) {
|
|
if (this.expandedMember === memberId) {
|
|
this.expandedMember = null;
|
|
} else {
|
|
this.expandedMember = memberId;
|
|
}
|
|
},
|
|
openPartyModal () {
|
|
if (this.user.party._id) {
|
|
this.$store.state.groupId = this.user.party._id;
|
|
// @TODO: do we need to fetch party?
|
|
this.$store.state.memberModalOptions.group = this.$store.state.party;
|
|
this.$root.$emit('show::modal', 'members-modal');
|
|
return;
|
|
}
|
|
this.$root.$emit('show::modal', 'create-party-modal');
|
|
},
|
|
},
|
|
created () {
|
|
if (this.user.party && this.user.party._id) this.getPartyMembers();
|
|
},
|
|
};
|
|
</script>
|