mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-16 06:07:21 +01:00
* start to refactor analytics and some mixins * wip * wip * wip * more analytics * more analytics * more anlytics * fix analytics module * finish analytics * fix env * vue casing
227 lines
5.5 KiB
Vue
227 lines
5.5 KiB
Vue
<template lang="pug">
|
||
b-modal#start-quest-modal(title="Empty", size='md', :hide-footer="true", :hide-header="true")
|
||
.left-panel.content
|
||
h3.text-center Quests
|
||
.row
|
||
.col-4.quest-col(v-for='(value, key, index) in user.items.quests', @click='selectQuest(key)', :class="{selected: key === selectedQuest}")
|
||
.quest-wrapper
|
||
.quest(:class="'inventory_quest_scroll_' + key")
|
||
.row
|
||
.col-10.offset-1.text-center
|
||
span.description Can’t find a quest to start? Try checking out the Quest Shop in the Market for new releases!
|
||
div(v-if='questData')
|
||
.quest-image(:class="'quest_' + questData.key")
|
||
h2.text-center {{questData.text()}}
|
||
//- span by: Keith Holliday @TODO: Add author
|
||
p(v-html="questData.notes()")
|
||
div.quest-details
|
||
div(v-if=' questData.collect')
|
||
Strong {{$t('collect')}}:
|
||
span(v-for="(value, key, index) in questData.collect")
|
||
| {{$t('collectionItems', { number: questData.collect[key].count, items: questData.collect[key].text() })}}
|
||
div
|
||
Strong {{$t('difficulty')}}:
|
||
span
|
||
.svg-icon.difficulty-star(v-html="icons.difficultyStarIcon")
|
||
div.text-center
|
||
button.btn.btn-primary(@click='questInit()') {{$t('inviteToPartyOrQuest')}}
|
||
div.text-center
|
||
p {{$t('inviteInformation')}}
|
||
.side-panel(v-if='questData')
|
||
h4.text-center {{$t('rewards')}}
|
||
.box
|
||
.svg-icon.rewards-icon(v-html="icons.starIcon")
|
||
strong {{questData.drop.exp}} {{$t('experience')}}
|
||
.box
|
||
.svg-icon.rewards-icon(v-html="icons.goldIcon")
|
||
strong {{questData.drop.gp}} {{$t('gold')}}
|
||
h4.text-center(v-if='questData.drop.items') {{$t('questOwnerRewards')}}
|
||
.box(v-for='item in questData.drop.items')
|
||
.rewards-icon(v-if='item.type === "quest"', :class="'quest_' + item.key")
|
||
.drop-rewards-icon(v-if='item.type === "gear"', :class="'shop_' + item.key")
|
||
strong.quest-reward-text {{item.text()}}
|
||
</template>
|
||
|
||
<style lang='scss' scoped>
|
||
@import '~client/assets/scss/colors.scss';
|
||
|
||
header {
|
||
background-color: $white !important;
|
||
border: none !important;
|
||
|
||
h5 {
|
||
text-indent: -99999px;
|
||
}
|
||
}
|
||
|
||
.quest-image {
|
||
margin: 0 auto;
|
||
margin-bottom: 1em;
|
||
margin-top: 1.5em;
|
||
}
|
||
|
||
.quest-details {
|
||
margin: 0 auto;
|
||
text-align: left;
|
||
width: 180px;
|
||
}
|
||
|
||
.btn-primary {
|
||
margin: 1em 0;
|
||
}
|
||
|
||
.left-panel {
|
||
background: #4e4a57;
|
||
color: $white;
|
||
position: absolute;
|
||
height: 460px;
|
||
width: 320px;
|
||
top: 2.5em;
|
||
left: -22em;
|
||
z-index: -1;
|
||
padding: 2em;
|
||
|
||
h3 {
|
||
color: $white;
|
||
}
|
||
|
||
.selected .quest-wrapper {
|
||
border: solid 1.5px #9a62ff;
|
||
}
|
||
|
||
.quest-wrapper:hover {
|
||
cursor: pointer;
|
||
}
|
||
|
||
.quest-col .quest-wrapper {
|
||
background: $white;
|
||
padding: .7em;
|
||
margin-bottom: 1em;
|
||
border-radius: 3px;
|
||
}
|
||
|
||
.description {
|
||
text-align: center;
|
||
color: #a5a1ac;
|
||
font-size: 12px;
|
||
}
|
||
}
|
||
|
||
.side-panel {
|
||
background: #edecee;
|
||
position: absolute;
|
||
height: 460px;
|
||
width: 320px;
|
||
top: 2.5em;
|
||
left: 35em;
|
||
z-index: -1;
|
||
padding-top: 1em;
|
||
border-radius: 4px;
|
||
|
||
.drop-rewards-icon {
|
||
width: 35px;
|
||
height: 35px;
|
||
float: left;
|
||
}
|
||
|
||
.rewards-icon {
|
||
float: left;
|
||
width: 30px;
|
||
height: 30px;
|
||
|
||
svg {
|
||
width: 30px;
|
||
height: 30px;
|
||
}
|
||
}
|
||
|
||
.quest-reward-text {
|
||
font-size: 12px;
|
||
}
|
||
|
||
.box {
|
||
width: 220px;
|
||
height: 64px;
|
||
border-radius: 2px;
|
||
background-color: #ffffff;
|
||
margin: 0 auto;
|
||
margin-bottom: 1em;
|
||
padding: 1em;
|
||
}
|
||
}
|
||
|
||
.difficulty-star {
|
||
width: 20px;
|
||
display: inline-block;
|
||
vertical-align: bottom;
|
||
}
|
||
</style>
|
||
|
||
<script>
|
||
import { mapState } from 'client/libs/store';
|
||
import * as Analytics from 'client/libs/analytics';
|
||
import bModal from 'bootstrap-vue/lib/components/modal';
|
||
|
||
import quests from 'common/script/content/quests';
|
||
|
||
import copyIcon from 'assets/svg/copy.svg';
|
||
import greyBadgeIcon from 'assets/svg/grey-badge.svg';
|
||
import qrCodeIcon from 'assets/svg/qrCode.svg';
|
||
import facebookIcon from 'assets/svg/facebook.svg';
|
||
import twitterIcon from 'assets/svg/twitter.svg';
|
||
import starIcon from 'assets/svg/star.svg';
|
||
import goldIcon from 'assets/svg/gold.svg';
|
||
import difficultyStarIcon from 'assets/svg/difficulty-star.svg';
|
||
|
||
export default {
|
||
props: ['group'],
|
||
components: {
|
||
bModal,
|
||
},
|
||
data () {
|
||
return {
|
||
selectedQuest: {},
|
||
icons: Object.freeze({
|
||
copy: copyIcon,
|
||
greyBadge: greyBadgeIcon,
|
||
qrCode: qrCodeIcon,
|
||
facebook: facebookIcon,
|
||
twitter: twitterIcon,
|
||
starIcon,
|
||
goldIcon,
|
||
difficultyStarIcon,
|
||
}),
|
||
shareUserIdShown: false,
|
||
};
|
||
},
|
||
mounted () {
|
||
let questKeys = Object.keys(this.user.items.quests);
|
||
this.selectedQuest = questKeys[0];
|
||
},
|
||
computed: {
|
||
...mapState({user: 'user.data'}),
|
||
questData () {
|
||
return quests.quests[this.selectedQuest];
|
||
},
|
||
},
|
||
methods: {
|
||
selectQuest (quest) {
|
||
this.selectedQuest = quest;
|
||
},
|
||
async questInit () {
|
||
Analytics.updateUser({
|
||
partyID: this.group._id,
|
||
partySize: this.group.memberCount,
|
||
});
|
||
|
||
const key = this.selectedQuest;
|
||
const response = await this.$store.dispatch('guilds:inviteToQuest', {groupId: this.group._id, key});
|
||
const quest = response.data.data;
|
||
|
||
this.$store.party.quest = quest;
|
||
this.$root.$emit('hide::modal', 'start-quest-modal');
|
||
},
|
||
},
|
||
};
|
||
</script>
|