mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-19 07:37:25 +01:00
moved modal file from /groups into /group-plans
This commit is contained in:
@@ -0,0 +1,230 @@
|
|||||||
|
<template>
|
||||||
|
<div>
|
||||||
|
<b-modal
|
||||||
|
id="group-plan-modal"
|
||||||
|
:title="activePage === PAGES.CREATE_GROUP ? 'Create your Group' : 'Select Payment'"
|
||||||
|
size="md"
|
||||||
|
hide-footer="hide-footer"
|
||||||
|
>
|
||||||
|
<div
|
||||||
|
v-if="activePage === PAGES.CREATE_GROUP"
|
||||||
|
class="col-12"
|
||||||
|
>
|
||||||
|
<div class="form-group">
|
||||||
|
<label
|
||||||
|
class="control-label"
|
||||||
|
for="new-group-name"
|
||||||
|
>Name</label>
|
||||||
|
<input
|
||||||
|
id="new-group-name"
|
||||||
|
v-model="newGroup.name"
|
||||||
|
class="form-control input-medium option-content"
|
||||||
|
required="required"
|
||||||
|
type="text"
|
||||||
|
placeholder="Name"
|
||||||
|
>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<label for="new-group-description">{{ $t('description') }}</label>
|
||||||
|
<textarea
|
||||||
|
id="new-group-description"
|
||||||
|
v-model="newGroup.description"
|
||||||
|
class="form-control option-content"
|
||||||
|
cols="3"
|
||||||
|
:placeholder="$t('description')"
|
||||||
|
></textarea>
|
||||||
|
</div>
|
||||||
|
<div
|
||||||
|
v-if="type === 'guild'"
|
||||||
|
class="form-group"
|
||||||
|
>
|
||||||
|
<div class="custom-control custom-radio">
|
||||||
|
<input
|
||||||
|
v-model="newGroup.privacy"
|
||||||
|
class="custom-control-input"
|
||||||
|
type="radio"
|
||||||
|
name="new-group-privacy"
|
||||||
|
value="private"
|
||||||
|
>
|
||||||
|
<label class="custom-control-label">{{ $t('inviteOnly') }}</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<div class="custom-control custom-checkbox">
|
||||||
|
<input
|
||||||
|
id="create-group-leaderOnlyChallenges-checkbox"
|
||||||
|
v-model="newGroup.leaderOnly.challenges"
|
||||||
|
class="custom-control-input"
|
||||||
|
type="checkbox"
|
||||||
|
>
|
||||||
|
<label
|
||||||
|
class="custom-control-label"
|
||||||
|
for="create-group-leaderOnlyChallenges-checkbox"
|
||||||
|
>{{ $t('leaderOnlyChallenges') }}</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div
|
||||||
|
v-if="type === 'party'"
|
||||||
|
class="form-group"
|
||||||
|
>
|
||||||
|
<button
|
||||||
|
class="btn btn-secondary form-control"
|
||||||
|
:value="$t('create')"
|
||||||
|
@click="createGroup()"
|
||||||
|
></button>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<button
|
||||||
|
class="btn btn-primary btn-lg btn-block"
|
||||||
|
:disabled="!newGroupIsReady"
|
||||||
|
@click="createGroup()"
|
||||||
|
>
|
||||||
|
{{ $t('create') }}
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div
|
||||||
|
v-if="activePage === PAGES.PAY"
|
||||||
|
class="col-12"
|
||||||
|
>
|
||||||
|
<div class="text-center">
|
||||||
|
<payments-buttons
|
||||||
|
:stripe-fn="() => pay(PAYMENTS.STRIPE)"
|
||||||
|
:amazon-data="pay(PAYMENTS.AMAZON)"
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</b-modal>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<style lang="scss" scoped>
|
||||||
|
.payment-options {
|
||||||
|
margin-bottom: 4em;
|
||||||
|
|
||||||
|
.purple-box {
|
||||||
|
background-color: #4f2a93;
|
||||||
|
color: #fff;
|
||||||
|
padding: .5em;
|
||||||
|
border-radius: 8px;
|
||||||
|
width: 200px;
|
||||||
|
height: 215px;
|
||||||
|
|
||||||
|
.dollar {
|
||||||
|
}
|
||||||
|
|
||||||
|
.number {
|
||||||
|
font-size: 60px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.name {
|
||||||
|
width: 100px;
|
||||||
|
margin-left: .3em;
|
||||||
|
}
|
||||||
|
|
||||||
|
.plus {
|
||||||
|
width: 100%;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
div {
|
||||||
|
display: inline-block;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.box, .purple-box {
|
||||||
|
display: inline-block;
|
||||||
|
vertical-align: bottom;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
import paymentsMixin from '../../mixins/payments';
|
||||||
|
import { mapState } from '@/libs/store';
|
||||||
|
import positiveIcon from '@/assets/svg/positive.svg';
|
||||||
|
import paymentsButtons from '@/components/payments/buttons/list';
|
||||||
|
|
||||||
|
export default {
|
||||||
|
components: {
|
||||||
|
paymentsButtons,
|
||||||
|
},
|
||||||
|
mixins: [paymentsMixin],
|
||||||
|
data () {
|
||||||
|
return {
|
||||||
|
amazonPayments: {},
|
||||||
|
icons: Object.freeze({
|
||||||
|
positiveIcon,
|
||||||
|
}),
|
||||||
|
PAGES: {
|
||||||
|
CREATE_GROUP: 'create-group',
|
||||||
|
UPGRADE_GROUP: 'upgrade-group',
|
||||||
|
PAY: 'pay',
|
||||||
|
},
|
||||||
|
PAYMENTS: {
|
||||||
|
AMAZON: 'amazon',
|
||||||
|
STRIPE: 'stripe',
|
||||||
|
},
|
||||||
|
paymentMethod: '',
|
||||||
|
newGroup: {
|
||||||
|
type: 'guild',
|
||||||
|
privacy: 'private',
|
||||||
|
name: '',
|
||||||
|
leaderOnly: {
|
||||||
|
challenges: false,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
activePage: '',
|
||||||
|
type: 'guild', // Guild or Party @TODO enum this
|
||||||
|
};
|
||||||
|
},
|
||||||
|
computed: {
|
||||||
|
newGroupIsReady () {
|
||||||
|
return Boolean(this.newGroup.name);
|
||||||
|
},
|
||||||
|
upgradingGroup () {
|
||||||
|
return this.$store.state.upgradingGroup;
|
||||||
|
},
|
||||||
|
// @TODO: can we move this to payment mixin?
|
||||||
|
...mapState({ user: 'user.data' }),
|
||||||
|
},
|
||||||
|
mounted () {
|
||||||
|
this.activePage = this.PAGES.BENEFITS;
|
||||||
|
this.$store.dispatch('common:setTitle', {
|
||||||
|
section: this.$t('groupPlans'),
|
||||||
|
});
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
createGroup () {
|
||||||
|
this.changePage(this.PAGES.PAY);
|
||||||
|
},
|
||||||
|
pay (paymentMethod) {
|
||||||
|
const subscriptionKey = 'group_monthly'; // @TODO: Get from content API?
|
||||||
|
const paymentData = {
|
||||||
|
subscription: subscriptionKey,
|
||||||
|
coupon: null,
|
||||||
|
};
|
||||||
|
|
||||||
|
if (this.upgradingGroup && this.upgradingGroup._id) {
|
||||||
|
paymentData.groupId = this.upgradingGroup._id;
|
||||||
|
paymentData.group = this.upgradingGroup;
|
||||||
|
} else {
|
||||||
|
paymentData.groupToCreate = this.newGroup;
|
||||||
|
}
|
||||||
|
|
||||||
|
this.paymentMethod = paymentMethod;
|
||||||
|
|
||||||
|
if (this.paymentMethod === this.PAYMENTS.AMAZON) {
|
||||||
|
paymentData.type = 'subscription';
|
||||||
|
return paymentData;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this.paymentMethod === this.PAYMENTS.STRIPE) {
|
||||||
|
this.redirectToStripe(paymentData);
|
||||||
|
}
|
||||||
|
|
||||||
|
return null;
|
||||||
|
},
|
||||||
|
},
|
||||||
|
};
|
||||||
|
</script>
|
||||||
Reference in New Issue
Block a user