koel/resources/assets/js/components/koel-plus/ActivateLicenseForm.vue

42 lines
1.2 KiB
Vue
Raw Normal View History

<template>
2024-04-04 22:20:42 +00:00
<form class="license-form flex items-stretch" @submit.prevent="validateLicenseKey">
<TextInput
2024-03-19 22:48:12 +00:00
v-model="licenseKey"
v-koel-focus
2024-04-04 22:20:42 +00:00
:disabled="loading"
class="!rounded-r-none"
name="license"
placeholder="Enter your license key"
required
2024-04-04 22:20:42 +00:00
/>
<Btn :disabled="loading" class="!rounded-l-none" type="submit">Activate</Btn>
</form>
</template>
2024-04-23 21:01:27 +00:00
<script lang="ts" setup>
import { ref } from 'vue'
import { plusService } from '@/services'
import { forceReloadWindow } from '@/utils'
import { useDialogBox, useErrorHandler } from '@/composables'
2024-04-04 22:20:42 +00:00
import Btn from '@/components/ui/form/Btn.vue'
import TextInput from '@/components/ui/form/TextInput.vue'
const { showSuccessDialog } = useDialogBox()
const licenseKey = ref('')
const loading = ref(false)
const validateLicenseKey = async () => {
try {
loading.value = true
await plusService.activateLicense(licenseKey.value)
await showSuccessDialog('Thanks for purchasing Koel Plus! Koel will now refresh to activate the changes.')
forceReloadWindow()
} catch (error: unknown) {
useErrorHandler('dialog').handleHttpError(error)
} finally {
loading.value = false
}
}
</script>