feat: completion certificate

This commit is contained in:
Jannat Patel
2024-07-11 18:12:15 +05:30
parent 63d613a88e
commit 6e1d62340f
2 changed files with 31 additions and 3 deletions

View File

@@ -63,6 +63,9 @@
{{ __('Start Learning') }}
</span>
</Button>
<Button v-if="canGetCertificate">
{{ __('Get Certificate') }}
</Button>
<router-link
v-if="user?.data?.is_moderator || is_instructor()"
:to="{
@@ -174,4 +177,8 @@ const is_instructor = () => {
})
return user_is_instructor
}
const canGetCertificate = computed(() => {
console.log(props.course)
})
</script>

View File

@@ -90,6 +90,17 @@
</span>
</Button>
</router-link>
<router-link
v-else
:to="{
name: 'CourseDetail',
params: { courseName: courseName },
}"
>
<Button>
{{ __('Back to Course') }}
</Button>
</router-link>
</div>
</div>
@@ -160,12 +171,12 @@
{{ lesson.data.course_title }}
</div>
<div v-if="user && lesson.data.membership" class="text-sm mt-3">
{{ Math.ceil(lesson.data.membership.progress) }}% completed
{{ Math.ceil(lessonProgress) }}% completed
</div>
<ProgressBar
v-if="user && lesson.data.membership"
:progress="lesson.data.membership.progress"
:progress="lessonProgress"
/>
</div>
<CourseOutline
@@ -196,6 +207,7 @@ const route = useRoute()
const allowDiscussions = ref(false)
const editor = ref(null)
const instructorEditor = ref(null)
const lessonProgress = ref(0)
const props = defineProps({
courseName: {
@@ -224,6 +236,7 @@ const lesson = createResource({
},
auto: true,
onSuccess(data) {
lessonProgress.value = data.membership?.progress
markProgress(data)
if (data.content) editor.value = renderEditor('editor', data.content)
if (data.instructor_content?.blocks?.length)
@@ -257,7 +270,11 @@ const renderEditor = (holder, content) => {
}
const markProgress = (data) => {
if (user.data && !data.progress) progress.submit()
if (user.data && !data.progress) {
setTimeout(() => {
progress.submit()
}, 30000)
}
}
const progress = createResource({
@@ -268,6 +285,10 @@ const progress = createResource({
course: props.courseName,
}
},
onSuccess(data) {
console.log(data)
lessonProgress.value = data
},
})
const breadcrumbs = computed(() => {