- {{ __('Lesson Details') }}
+
+
+
+
+
+
+
+
+
+ {{ __('Lesson Details') }}
+
+
+
+
+
+
+
+
+
+
+
+
-
-
-
-
-
-
-
-
-
-
+
+
+ {{ __('Components') }}
+
+
@@ -43,18 +70,16 @@ import {
Button,
createDocumentResource,
} from 'frappe-ui'
-import { computed, reactive, onMounted, inject } from 'vue'
+import { computed, reactive, onMounted, inject, ref } from 'vue'
import EditorJS from '@editorjs/editorjs'
-import Header from '@editorjs/header'
-import Paragraph from '@editorjs/paragraph'
-import List from '@editorjs/list'
-import Embed from '@editorjs/embed'
-import YouTubeVideo from '../utils/youtube.js'
import { createToast } from '../utils'
+import Link from '@/components/Controls/Link.vue'
+import { Plus } from 'lucide-vue-next'
+import { getEditorTools } from '../utils'
let editor
-let editLessonResource
const user = inject('$user')
+const quiz = ref(null)
const props = defineProps({
courseName: {
@@ -85,38 +110,6 @@ const renderEditor = (holder) => {
})
}
-const getEditorTools = () => {
- return {
- header: Header,
- youtube: YouTubeVideo,
- paragraph: {
- class: Paragraph,
- inlineToolbar: true,
- config: {
- preserveBlank: true,
- },
- },
- list: List,
- embed: {
- class: Embed,
- config: {
- services: {
- youtube: true,
- vimeo: true,
- codepen: true,
- slides: {
- regex:
- /https:\/\/docs\.google\.com\/presentation\/d\/e\/([A-Za-z0-9_-]+)\/pub/,
- embedUrl:
- 'https://docs.google.com/presentation/d/e/<%= remote_id %>/embed',
- html: "
",
- },
- },
- },
- },
- }
-}
-
const lesson = reactive({
title: '',
include_in_preview: false,
@@ -135,7 +128,13 @@ const lessonDetails = createResource({
auto: true,
onSuccess(data) {
if (data.lesson) {
- createEditResource(data)
+ Object.keys(data.lesson).forEach((key) => {
+ lesson[key] = data.lesson[key]
+ })
+ lesson.include_in_preview = data.include_in_preview ? true : false
+ editor.isReady.then(() => {
+ editor.render(JSON.parse(data.lesson.content))
+ })
}
},
})
@@ -154,24 +153,16 @@ const newLessonResource = createResource({
},
})
-const createEditResource = (data) => {
- editLessonResource = createDocumentResource({
- doctype: 'Course Lesson',
- name: data.lesson,
- auto: true,
- onSuccess(data) {
- Object.keys(data).forEach((key) => {
- lesson[key] = data[key]
- })
- lesson.include_in_preview = data.include_in_preview ? true : false
- console.log(editor)
- console.log(editor.isReady)
- editor.isReady.then(() => {
- editor.render(JSON.parse(data.content))
- })
- },
- })
-}
+const editLesson = createResource({
+ url: 'frappe.client.set_value',
+ makeParams(values) {
+ return {
+ doctype: 'Course Lesson',
+ name: values.lesson,
+ fieldname: lesson,
+ }
+ },
+})
const lessonReference = createResource({
url: 'frappe.client.insert',
@@ -192,11 +183,10 @@ const lessonReference = createResource({
const saveLesson = () => {
editor.save().then((outputData) => {
lesson.content = JSON.stringify(outputData)
- console.log(editLessonResource?.doc?.modified)
- if (editLessonResource?.doc) {
- editLessonResource.setValue.submit(
+ if (lessonDetails.data?.lesson) {
+ editLesson.submit(
{
- ...lesson,
+ lesson: lessonDetails.data.lesson.name,
},
{
validate() {
@@ -249,6 +239,20 @@ const validateLesson = () => {
}
}
+const addQuiz = () => {
+ if (quiz.value) {
+ editor.blocks.insert(
+ 'quiz',
+ {
+ quiz: quiz.value,
+ },
+ {},
+ editor.blocks.getBlocksCount()
+ )
+ quiz.value = null
+ }
+}
+
const showToast = (title, text, icon) => {
createToast({
title: title,
@@ -275,9 +279,9 @@ const breadcrumbs = computed(() => {
},
]
- if (editLessonResource?.doc) {
+ if (lessonDetails?.data?.lesson) {
crumbs.push({
- label: editLessonResource.doc.title,
+ label: lessonDetails.data.lesson.title,
route: {
name: 'Lesson',
params: {
@@ -289,7 +293,7 @@ const breadcrumbs = computed(() => {
})
}
crumbs.push({
- label: editLessonResource?.doc ? 'Edit Lesson' : 'Create Lesson',
+ label: lessonDetails?.data?.lesson ? 'Edit Lesson' : 'Create Lesson',
route: {
name: 'CreateLesson',
params: {
diff --git a/frontend/src/pages/Lesson.vue b/frontend/src/pages/Lesson.vue
index a3d86aac..e81ed823 100644
--- a/frontend/src/pages/Lesson.vue
+++ b/frontend/src/pages/Lesson.vue
@@ -115,11 +115,7 @@
v-for="content in JSON.parse(lesson.data.content).blocks"
class="ProseMirror prose prose-table:table-fixed prose-td:p-2 prose-th:p-2 prose-td:border prose-th:border prose-td:border-gray-300 prose-th:border-gray-300 prose-td:relative prose-th:relative prose-th:bg-gray-100 prose-sm max-w-none !whitespace-normal mt-6"
>
-
-
- {{ content.data.text }}
-
-
+