mirror of
https://github.com/VueFileManager/vuefilemanager.git
synced 2026-04-19 00:22:15 +00:00
125 lines
4.4 KiB
Vue
125 lines
4.4 KiB
Vue
<template>
|
||
<AuthContentWrapper ref="auth">
|
||
<!--Licence Verify-->
|
||
<AuthContent name="licence-verify" :visible="true">
|
||
<Headline class="container mx-auto max-w-screen-sm" title="Setup Wizard" description="Please set your purchase code before continue to set up your application.">
|
||
<settings-icon size="40" class="title-icon text-theme mx-auto" />
|
||
</Headline>
|
||
|
||
<ValidationObserver @submit.prevent="verifyPurchaseCode" ref="verifyPurchaseCode" v-slot="{ invalid }" tag="form" class="form inline-form">
|
||
<ValidationProvider tag="div" mode="passive" class="input-wrapper" name="Purchase Code" rules="required" v-slot="{ errors }">
|
||
<input v-model="purchaseCode" placeholder="Paste your purchase code" type="text" :class="{ 'border-red': errors[0] }" />
|
||
<span class="error-message" v-if="errors[0]">{{ errors[0] }}</span>
|
||
</ValidationProvider>
|
||
<AuthButton icon="chevron-right" text="Verify" :loading="isLoading" :disabled="isLoading" />
|
||
</ValidationObserver>
|
||
|
||
<p class="additional-link">
|
||
<a href="https://help.market.envato.com/hc/en-us/articles/202822600-Where-Is-My-Purchase-Code-" target="_blank"> Where I can find purchase code? </a>
|
||
<a class="black-link" href="https://codecanyon.net/item/vue-file-manager-with-laravel-backend/25815986" target="_blank"> Don’t have purchase code? </a>
|
||
</p>
|
||
</AuthContent>
|
||
</AuthContentWrapper>
|
||
</template>
|
||
|
||
<script>
|
||
import AuthContentWrapper from '../../components/Auth/AuthContentWrapper'
|
||
import { ValidationProvider, ValidationObserver } from 'vee-validate/dist/vee-validate.full'
|
||
import InfoBox from '../../components/Others/Forms/InfoBox'
|
||
import AuthContent from '../../components/Auth/AuthContent'
|
||
import AuthButton from '../../components/Auth/AuthButton'
|
||
import { SettingsIcon } from 'vue-feather-icons'
|
||
import { required } from 'vee-validate/dist/rules'
|
||
import Headline from '../Auth/Headline'
|
||
import { mapGetters } from 'vuex'
|
||
import axios from 'axios'
|
||
|
||
export default {
|
||
name: 'PurchaseCode',
|
||
components: {
|
||
AuthContentWrapper,
|
||
ValidationProvider,
|
||
ValidationObserver,
|
||
SettingsIcon,
|
||
AuthContent,
|
||
AuthButton,
|
||
required,
|
||
InfoBox,
|
||
Headline,
|
||
},
|
||
data() {
|
||
return {
|
||
isLoading: false,
|
||
purchaseCode: '',
|
||
}
|
||
},
|
||
methods: {
|
||
async verifyPurchaseCode() {
|
||
// Validate fields
|
||
const isValid = await this.$refs.verifyPurchaseCode.validate()
|
||
|
||
if (!isValid) return
|
||
|
||
// Start loading
|
||
this.isLoading = true
|
||
|
||
// Send request to get verify account
|
||
axios
|
||
.post('/api/setup/purchase-code', {
|
||
purchaseCode: this.purchaseCode,
|
||
})
|
||
.then((response) => {
|
||
// End loading
|
||
this.isLoading = false
|
||
|
||
localStorage.setItem('purchase_code', this.purchaseCode)
|
||
|
||
// Redirect to next step
|
||
this.$router.push({ name: 'Database' })
|
||
})
|
||
.catch((error) => {
|
||
// End loading
|
||
this.isLoading = false
|
||
|
||
if (error.response.status == 400) {
|
||
this.$refs.verifyPurchaseCode.setErrors({
|
||
'Purchase Code': ['Purchase code is invalid.'],
|
||
})
|
||
} else if (error.response.status == 404) {
|
||
this.$refs.verifyPurchaseCode.setErrors({
|
||
'Purchase Code': ['You may have misconfigured the app, please read the readme file and try it again.'],
|
||
})
|
||
} else {
|
||
this.$refs.verifyPurchaseCode.setErrors({
|
||
'Purchase Code': ['Something is wrong. Please try again.'],
|
||
})
|
||
}
|
||
})
|
||
},
|
||
},
|
||
}
|
||
</script>
|
||
|
||
<style scoped lang="scss">
|
||
@import '../../../sass/vuefilemanager/auth';
|
||
@import '../../../sass/vuefilemanager/setup_wizard';
|
||
|
||
.additional-link {
|
||
.black-link {
|
||
color: $text;
|
||
}
|
||
}
|
||
|
||
.auth-form input {
|
||
min-width: 380px;
|
||
}
|
||
|
||
.dark {
|
||
.additional-link {
|
||
.black-link {
|
||
color: $dark_mode_text_primary;
|
||
}
|
||
}
|
||
}
|
||
</style>
|