Your IP : 3.17.175.191


Current Path : /proc/self/root/home/lentoinv/lentoria.com/resources/views/instructor/
Upload File :
Current File : //proc/self/root/home/lentoinv/lentoria.com/resources/views/instructor/curriculum.blade.php

@extends('layouts.instructor')
@section('page_title', "Course | $slug")

@section('page_content')
    <div class="pt-5 pb-5">
        <div class="container">
            @include('instructor.course_name')
            <div class="row mt-0 mt-md-4">
                <div class="col-lg-3 col-md-4 col-12">
                    @include('instructor.side')
                </div>

                <div class="col-lg-9 col-md-8 col-12">
                    <!-- Card -->
                    <div class="card mb-4" id="cur_card">
                        <div class="card-header border-bottom px-4 py-3">
                            <div class="d-flex justify-content-between">
                                <h4 class="mb-0 pt-3">Curriculum</h4>
                                <a href="javascript:void(0)" class="btn btn-outline-primary btn-sm" id="addsec1">Add
                                    Topic</a>
                            </div>
                        </div>
                        <!-- Card body -->
                        <div class="card-body ">
                            <input type="hidden" id="course_id"/>
                            <x-add-section-card id="addseccard" type="add"/>

                            <div class="main">

                            </div>
                            <x-add-section-card id="addseccard2" type="add"/>
                        </div>
                        <div class="card-footer">
                            <div class="d-flex justify-content-between">
                                <a href="javascript:void(0)" class="btn btn-sm btn-outline-primary" id="addsec2">Add
                                    Topic</a>
                                <a href="{{ url("/instructor/pricing/$type/$slug") }}"
                                   class="btn btn-sm btn-primary">Next</a>
                            </div>
                        </div>
                    </div>
                </div>
            </div>
        </div>

    </div>
    <!-- Modal -->
    <div class="modal fade" id="editSectionModal" tabindex="-1" role="dialog" aria-labelledby="editSectionModalLabel"
         aria-hidden="true">
        <div class="modal-dialog modal-dialog-centered">
            <div class="modal-content">
                <div class="modal-header">
                    <h4 class="modal-title" id="editSectionModalLabel">
                        Edit Topic
                    </h4>
                    <button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close">
                        <span aria-hidden="true"><i class="fe fe-x-circle"></i></span>
                    </button>
                </div>
                <div class="modal-body">
                    <form method="post">
                        <input type="hidden" name="section_id">
                        <div class="row mb-3">
                            <div class="col-lg-12 col-md-8 col-12">
                                <label for="" class="text-bold fw-semi-bold text-dark">Course Title</label>
                                <input type="text" name="title" class="form-control mb-1" placeholder="Enter a title">
                            </div>
                        </div>
                        <div class="row mb-1">
                            <div class="col-lg-12 col-md-8 col-12">
                                <label for="cgain" class="text-bold fw-semi-bold text-dark">What will
                                    Students Learn in this course</label>
                                <input type="text" id="cgain" name="gain" class="form-control mb-2"
                                       placeholder="Enter a learning objective">
                            </div>
                        </div>
                        <div class="d-flex justify-content-between">
                            <button class="btn btn-primary btn-sm" type="submit">
                                Edit Section
                            </button>
                            <button class="btn btn-outline-white btn-sm" data-bs-dismiss="modal" aria-label="Close">
                                Close
                            </button>
                        </div>
                    </form>
                </div>
            </div>
        </div>
    </div>

    <!--Modal -->
    <div class="modal fade" id="addLectureModal" tabindex="-1" role="dialog" aria-labelledby="addLectureModalLabel"
         aria-hidden="true">
        <div class="modal-dialog modal-dialog-centered">
            <div class="modal-content">
                <div class="modal-header">
                    <h4 class="modal-title" id="addLectureModalLabel">
                        Add Lecture
                    </h4>
                    <button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close">
                        <span aria-hidden="true"><i class="fe fe-x-circle"></i></span>
                    </button>
                </div>
                <div class="modal-body">

                    <form class="row text-start g-3">
                        <input type="hidden" name="section_id">
                        <div class="col-md-12">
                            <label for="" class="text-bold fw-semi-bold text-dark">Lecture Title</label>
                            <input class="form-control" name="title" type="text" placeholder="Enter Lecture Title">
                        </div>
                        <div class="col-12 mt-3">
                            <label for="c_desc" class="text-bold fw-semi-bold text-dark">Lecture Description</label>
                            <x-textarea id="c_desc" name="c_desc"/>
                        </div>
                        <div class="d-flex justify-content-between">
                            <button class="btn btn-primary btn-sm" type="submit">
                                Add Lecture
                            </button>
                            <button class="btn btn-outline-white btn-sm" data-bs-dismiss="modal" aria-label="Close">
                                Close
                            </button>
                        </div>
                    </form>

                </div>
            </div>
        </div>
    </div>

    <!--Modal -->
    <div class="modal fade" id="editLectureModal" tabindex="-1" role="dialog" aria-labelledby="editLectureModalLabel"
         aria-hidden="true">
        <div class="modal-dialog modal-dialog-centered">
            <div class="modal-content">
                <div class="modal-header">
                    <h4 class="modal-title" id="editLectureModalLabel">
                        Edit Lecture
                    </h4>
                    <button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close">
                        <span aria-hidden="true"><i class="fe fe-x-circle"></i></span>
                    </button>
                </div>
                <div class="modal-body">

                    <form class="row text-start g-3" id="editLectureForm">
                        <input type="hidden" name="lecture_id">
                        <input type="hidden" name="section_id">
                        <div class="col-md-12">
                            <label for="" class="text-bold fw-semi-bold text-dark">Lecture Title</label>
                            <input class="form-control" name="title" type="text" placeholder="Enter Lecture Title">
                        </div>
                        <div class="col-12 mt-3">
                            <label for="edit_desc" class="text-bold fw-semi-bold text-dark">Lecture Description</label>
                            <x-textarea id="edit_desc" name="edit_desc"/>
                        </div>
                        <div class="d-flex justify-content-between">
                            <button class="btn btn-primary btn-sm" type="submit">
                                Submit
                            </button>
                            <button class="btn btn-outline-white btn-sm" data-bs-dismiss="modal" aria-label="Close">
                                Close
                            </button>
                        </div>
                    </form>

                </div>
            </div>
        </div>
    </div>

    <!--Modal -->
    <div class="modal fade" id="addVideoModal" tabindex="-1" role="dialog" aria-labelledby="addVideoModalLabel"
         aria-hidden="true">
        <div class="modal-dialog modal-dialog-centered">
            <div class="modal-content">
                <div class="modal-header">
                    <h4 class="modal-title" id="addVideoModalLabel">
                        Add Video Content
                    </h4>
                    <button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close">
                        <span aria-hidden="true"><i class="fe fe-x-circle"></i></span>
                    </button>
                </div>
                <div class="modal-body">

                    <form hidden id="video_info">
                        <input type="hidden" name="lecture_id" id="lecu_id"/>
                        <input type="hidden" name="section_id"/>
                        <input type="hidden" name="lecture_title" id="lecu_title"/>
                        <input type="hidden" name="lecture_description" id="lecu_desc"/>
                        <input type="hidden" name="video_length" id="video_length"/>
                    </form>
                    <form class="row text-start g-3" id="addVideoForm" enctype="multipart/form-data">
                        <div class="col-md-12">
                            <input name="video" type="file" id="file_upload"/>
                        </div>

                        <div class="d-flex justify-content-end">
                            <button class="btn btn-outline-white btn-sm" data-bs-dismiss="modal" aria-label="Close">
                                Close
                            </button>
                        </div>
                    </form>

                </div>
            </div>
        </div>
    </div>

    <!--Modal -->
    <div class="modal fade" id="addImageModal" tabindex="-1" role="dialog" aria-labelledby="addImageModalLabel"
         aria-hidden="true">
        <div class="modal-dialog modal-dialog-centered">
            <div class="modal-content">
                <div class="modal-header">
                    <h4 class="modal-title" id="addImageModalLabel">
                        Add Image Content
                    </h4>
                    <button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close">
                        <span aria-hidden="true"><i class="fe fe-x-circle"></i></span>
                    </button>
                </div>
                <div class="modal-body">

                    <form hidden id="image_info">
                        <input type="hidden" name="lecture_id"/>
                    </form>
                    <form class="row text-start g-3" id="addImageForm" enctype="multipart/form-data">
                        <div class="col-md-12">
                            <input name="image" type="file" id="image_upload"/>
                        </div>

                        <div class="d-flex justify-content-end">
                            <button class="btn btn-outline-white btn-sm" data-bs-dismiss="modal" aria-label="Close">
                                Close
                            </button>
                        </div>
                    </form>

                </div>
            </div>
        </div>
    </div>

    <!--Modal -->
    <div class="modal fade" id="addTextModal" tabindex="-1" role="dialog" aria-labelledby="addTextModalLabel"
         aria-hidden="true">
        <div class="modal-dialog modal-lg modal-dialog-centered">
            <div class="modal-content">
                <div class="modal-header">
                    <h3 class="modal-title" id="addTextModalLabel">
                        Add Text Content
                    </h3>
                    <button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close">
                        <span aria-hidden="true"><i class="fe fe-x-circle"></i></span>
                    </button>
                </div>
                <div class="modal-body">
                    <form class="row text-start g-3" id="addTextForm">
                        <input type="hidden" name="lecture_id"/>
                        <div class="col-md-12">
                            <x-textarea id="textcontent" name="textcontent" type="2"/>
                        </div>

                        <div class="d-flex justify-content-between">
                            <button class="btn btn-primary btn-sm" type="submit">
                                Submit
                            </button>
                            <button class="btn btn-outline-white btn-sm" data-bs-dismiss="modal" aria-label="Close">
                                Close
                            </button>
                        </div>
                    </form>

                </div>
            </div>
        </div>
    </div>

    <!--Modal -->
    <div class="modal fade" id="addTextModal2" tabindex="-1" role="dialog" aria-labelledby="addTextModal2Label"
         aria-hidden="true">
        <div class="modal-dialog modal-lg modal-dialog-centered">
            <div class="modal-content">
                <div class="modal-header">
                    <h3 class="modal-title" id="addTextModal2Label">
                        Add Text Content
                    </h3>
                    <button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close">
                        <span aria-hidden="true"><i class="fe fe-x-circle"></i></span>
                    </button>
                </div>
                <div class="modal-body">
                    <form class="row text-start g-3" id="addTextForm2">
                        <input type="hidden" name="lecture_id"/>
                        <div class="col-md-12">
                            <x-textarea id="textcontent2" name="textcontent2" type="2"/>
                        </div>

                        <div class="d-flex justify-content-between">
                            <button class="btn btn-primary btn-sm" type="submit">
                                Submit
                            </button>
                            <button class="btn btn-outline-white btn-sm" data-bs-dismiss="modal" aria-label="Close">
                                Close
                            </button>
                        </div>
                    </form>

                </div>
            </div>
        </div>
    </div>
    <div class="modal fade" id="addCodeModal" tabindex="-1" role="dialog" aria-labelledby="addCodeModalLabel"
         aria-hidden="true">
        <div class="modal-dialog modal-lg modal-dialog-centered">
            <div class="modal-content">
                <div class="modal-header">
                    <h3 class="modal-title" id="addCodeModalLabel">
                        Add Code
                    </h3>
                    <button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close">
                        <span aria-hidden="true"><i class="fe fe-x-circle"></i></span>
                    </button>
                </div>
                <div class="modal-body">
                    <form class="row text-start g-3" id="addCodeForm">
                        <input type="hidden" name="lecture_id"/>
                        <div class="col-md-12 mb-3">
                            <label for="lang">Select a language</label>
                            <div id="select2" x-data>
                                <select name="lang" id="lang" class="form-control" required>
                                    <option value="" selected disabled>...Select a language</option>
                                    <template x-for="(language,index) in languages" :key="index">
                                        <option :value="language.value" x-html="language.html"></option>
                                    </template>
                                </select>
                            </div>
                        </div>
                        <div class="col-md-12">
                            <label for="codearea" class="d-none"></label><textarea id="codearea" name="codearea"
                                                                                   class="form-control border-2"
                                                                                   rows="3"></textarea>
                        </div>

                        <div class="d-flex justify-content-between">
                            <button class="btn btn-primary btn-sm" type="submit">
                                Submit
                            </button>
                            <button class="btn btn-outline-white btn-sm" data-bs-dismiss="modal" aria-label="Close">
                                Close
                            </button>
                        </div>
                    </form>

                </div>
            </div>
        </div>
    </div>
    <script>
        const languages = [{
            value: "css",
            html: "CSS"
        }, {
            value: "html",
            html: "HTML"
        }, {
            value: "js",
            html: "Javascript"
        },
            {
                value: "aspnet",
                html: "ASP.NET"
            }, {
                value: "c",
                html: "C"
            }, {
                value: "csharp",
                html: "C#"
            },
            {
                value: "cpp",
                html: "C++"
            }, {
                value: "django",
                html: "Django"
            }, {
                value: "dart",
                html: "Dart"
            },
            {
                value: "git",
                html: "Git"
            }, {
                value: "java",
                html: "Java"
            }, {
                value: "lisp",
                html: "Lisp"
            },
            {
                value: "Markdown",
                html: "Markdown"
            }, {
                value: "matlab",
                html: "MATLAB"
            },
            {
                value: "mongodb",
                html: "MongoDB"
            }, {
                value: "php",
                html: "PHP"
            },
            {
                value: "py",
                html: "Python"
            }, {
                value: "r",
                html: "R"
            }, {
                value: "razor",
                html: "Razor C#"
            },
            {
                value: "jsx",
                html: "Ruby"
            }, {
                value: "ts",
                html: "Typescript"
            }
        ]
    </script>
    <script>
        $(function () {
            let type;
            let interval = setInterval(() => {
                cid = $("#course_id").val();
                type = $("#ctype").val();
                if (cid != "" && type != "") {
                    clearInterval(interval);
                    getAllSections(cid, type)
                }
            }, 200);

            function contentType(type) {

                const buttons = {
                    1: `<a href="javascript:void(0)" data-bs-toggle="modal" data-bs-target="#addVideoModal" class="btn btn-secondary btn-sm vidmodal my-1">Add Video Content +</a>&nbsp;&nbsp;
                        <a href="javascript:void(0)" class="btn btn-secondary btn-sm textmodal2 my-1" data-bs-target="#addTextModal2" data-bs-toggle="modal">Add Text Content +</a>&nbsp;&nbsp;
                        <a href="javascript:void(0)" class="btn btn-secondary btn-sm imgmodal my-1" data-bs-target="#addImageModal" data-bs-toggle="modal">Add Image Content +</a>&nbsp;&nbsp;
                        <a href="javascript:void(0)" class="btn btn-secondary btn-sm codemodal my-1" data-bs-target="#addCodeModal" data-bs-toggle="modal">Add Code +</a>`,
                    2: `<a href="javascript:void(0)" data-bs-toggle="modal" data-bs-target="#addVideoModal" class="btn btn-secondary btn-sm vidmodal my-1">Add Video Content +</a>`,
                    3: `<a href="javascript:void(0)" data-bs-toggle="modal" data-bs-target="#addVideoModal" class="btn btn-secondary btn-sm vidmodal my-1">Add Video Content +</a>`,
                }
                const button = (ty) => buttons[ty] || "";
                return button(type);
            }

            function dropDownButton(id) {
                if (type == 4) {
                    return ``
                } else {
                    return `<a href="#" class="text-inherit" data-bs-toggle="collapse"
                                    data-bs-target="#collapselist${id}" aria-expanded="false"
                                    aria-controls="collapselist${id}">
                                    <span class="chevron-arrow"><i class="fe fe-chevron-down"></i></span></a>`
                }
            }

            window.URL = window.URL || window.webkitURL;

            document.getElementById('file_upload').onchange = setFileInfo;

            function setFileInfo() {
                let file = this.files;
                let video = document.createElement('video');
                video.preload = 'metadata';

                video.onloadedmetadata = function () {
                    window.URL.revokeObjectURL(video.src);
                    var duration = video.duration;
                    if (duration > 1254) {
                        $("#file_upload").fileinput('clear')
                        salat("The video is longer is longer than 20mins and cannot be uploaded", 1);
                    } else {
                        $("input#video_length").val(duration);
                    }

                }

                video.src = URL.createObjectURL(file[0]);
            }

            function updateMainContent(url) {
                lecture_id = $("#lecu_id").val();
                duration = $("input#video_length").val();
                let published = sessionStorage.getItem('published');
                if (published && published != 0) {
                    salat('This course has been submitted for review and cannot be edited', 1);
                    return;
                }
                $.ajax({
                    url: api_url + "admin/update_lecture_video",
                    method: "POST",
                    data: {
                        uri: url,
                        lecture_id: lecture_id,
                        duration: duration,
                    }
                }).done(res => {
                    console.log(res);
                }).fail(res => {
                    console.log(res);
                })
            }

            function updateMainContent2(lecture_id, content, bt) {
                let published = sessionStorage.getItem('published');
                if (published && published != 0) {
                    salat('This course has been submitted for review and cannot be edited', 1);
                    return;
                }
                $.ajax({
                    url: api_url + "admin/update_lecture_text",
                    method: "POST",
                    data: {
                        lecture_id: lecture_id,
                        content: content,
                    },
                    beforeSend: () => {
                        btn(bt, '', 'before');
                    }
                }).done(res => {
                    console.log(res);
                    salat(res.message);
                    $("#addTextModal").modal('hide');
                    textcontent.setData("");
                    grandparent2.find($("div.mc")).html(content);
                    btn(bt, 'Submit', 'after');
                }).fail(res => {
                    console.log(res);
                    concatError(res.responseJSON);
                    btn(bt, 'Submit', 'after');
                })
            }

            function updateTextContent(lecture_id, content, bt) {
                let published = sessionStorage.getItem('published');
                if (published && published != 0) {
                    salat('This course has been submitted for review and cannot be edited', 1);
                    return;
                }
                $.ajax({
                    url: api_url + "admin/update_lecture_article",
                    method: "POST",
                    data: {
                        lecture_id: lecture_id,
                        text: content,
                    },
                    beforeSend: () => {
                        btn(bt, '', 'before');
                    }
                }).done(res => {
                    console.log(res);
                    salat(res.message);
                    $("#addTextModal2").modal('hide');
                    textcontent2.setData("");
                    grandparent2.find($("div.tc")).html(content);
                    btn(bt, 'Submit', 'after');
                }).fail(res => {
                    console.log(res);
                    concatError(res.responseJSON);
                    btn(bt, 'Submit', 'after');
                })
            }

            function updateCodeContent(lecture_id, code, lang, bt) {
                let published = sessionStorage.getItem('published');
                if (published && published != 0) {
                    salat('This course has been submitted for review and cannot be edited', 1);
                    return;
                }
                $.ajax({
                    url: api_url + "admin/update_lecture_code",
                    method: "POST",
                    data: {
                        lecture_id: lecture_id,
                        language: lang,
                        code: code,
                    },
                    beforeSend: () => {
                        btn(bt, '', 'before');
                    }
                }).done(res => {
                    console.log(res);
                    salat(res.message);
                    $("#addCodeModal").modal('hide');
                    btn(bt, 'Submit', 'after');
                    $("#addCodeForm")[0].reset();
                }).fail(res => {
                    console.log(res);
                    concatError(res.responseJSON);
                    btn(bt, 'Submit', 'after');
                })
            }

            $("#addCodeForm").submit(function (e) {
                e.preventDefault();
                but = $(this).find($('button[type="submit"]'));
                lecture_id = $(this).find($('input[name="lecture_id"]')).val();
                code = $(this).find($('textarea')).val();
                lang = $(this).find($('select[name="lang"]')).val();
                updateCodeContent(lecture_id, code, lang, but);
            });


            $(document).on('click', '.textmodal', function (e) {
                e.preventDefault();
                grandparent2 = $(this).parent().parent().parent();
                lect_id = grandparent2.find($("input.lec_id")).val();
                main_con = grandparent2.find($("div.mc")).html();
                $("#addTextForm").find($('input[name="lecture_id"]')).val(lect_id);
                textcontent.setData(main_con);
            })

            $(document).on('click', '.textmodal2', function (e) {
                e.preventDefault();
                grandparent2 = $(this).parent().parent().parent();
                lect_id = grandparent2.find($("input.lec_id")).val();
                main_con = grandparent2.find($("div.tc")).html();
                console.log(grandparent2.find($("div")));
                $("#addTextForm2").find($('input[name="lecture_id"]')).val(lect_id);
                textcontent2.setData(main_con);
            })

            $(document).on('click', '.imgmodal', function (e) {
                e.preventDefault();
                grandparent2 = $(this).parent().parent().parent();
                lect_id = grandparent2.find($("input.lec_id")).val();
                $("#image_info").find($('input[name="lecture_id"]')).val(lect_id);
            })

            $(document).on('click', '.codemodal', function (e) {
                e.preventDefault();
                grandparent3 = $(this).parent().parent().parent();
                lect_id = grandparent3.find($("input.lec_id")).val();
                $("#addCodeForm").find($('input[name="lecture_id"]')).val(lect_id);
            })

            function mainContentField(type, content, text) {
                let fields = {
                    1: `<div class="tc" hidden>${text}</div>`,
                    2: `<div class="mc" hidden>${content}</div>`,
                    3: `<div class="mc" hidden>${content}</div>`,
                }

                const field = (ty) => fields[ty] || '';
                return field(type);
            }

            $("#addTextForm").submit(function (e) {
                e.preventDefault();
                lecture_id = $(this).find($('input[name="lecture_id"]')).val();
                content = textcontent.getData();
                bt = $(this).find($("button[type='submit']"));
                if (!content) {
                    salat("Text field is required", 1);
                    return;
                }
                updateMainContent2(lecture_id, content, bt);
            })

            $("#addTextForm2").submit(function (e) {
                e.preventDefault();
                lecture_id = $(this).find($('input[name="lecture_id"]')).val();
                content = textcontent2.getData();
                bt = $(this).find($("button[type='submit']"));
                if (!content) {
                    salat("Text field is required", 1);
                    return;
                }
                updateTextContent(lecture_id, content, bt);
            })

            $("#file_upload").on('filepreupload', function (event, data, previewId, index, jqXHR) {
                let published = sessionStorage.getItem('published');
                if (published && published != 0) {
                    return {
                        message: 'course submitted for review no more uploads allowed',
                        data: {
                            key1: 'published error',
                            detail1: 'The course is under review already no more uploads allowed'
                        }
                    };
                }
            });
            $("#file_upload").fileinput({
                uploadUrl: "https://lentoria.site/api/video",
                allowedFileExtensions: [
                    'mp4',
                    'ogg'
                ],
                // allowedFileTypes: ['video'],
                removeFromPreviewOnError: true,
                dropZoneEnabled: false,
                theme: "bs5",
                // browseOnZoneClick: true,
                uploadAsync: true,
                fileActionSettings: {
                    showZoom: false,
                    showUpload: false,
                },
                mergeAjaxCallbacks: false,
                uploadExtraData: function (previewId, index) {
                    return {
                        title: $("#lecu_title").val(),
                        lecture_id: $("#lecu_id").val(),
                        duration: $("input#video_length").val(),
                    };
                },
            }).on('fileuploaded', function (event, data) {
                let form = data.form,
                    files = data.files,
                    extra = data.extra,
                    response = data.response,
                    reader = data.reader;
                updateMainContent(response.url);
                $("#addVideoModal").modal("hide");
                $("#file_upload").fileinput('clear');
                salat('Video upload successful');
            });
            $("#image_upload").on('filepreupload', function (event, data, previewId, index, jqXHR) {
                let published = sessionStorage.getItem('published');
                if (published && published != 0) {
                    return {
                        message: 'course submitted for review no more uploads allowed',
                        data: {
                            key1: 'published error',
                            detail1: 'The course is under review already no more uploads allowed'
                        }
                    };
                }
            });

            $("#image_upload").fileinput({
                uploadUrl: api_url + 'admin/update_lecture_image',
                browseOnZoneClick: true,
                fileActionSettings: {
                    showZoom: false,
                    showUpload: false,
                },
                allowedFileTypes: ['image'],

                uploadAsync: true,
                mergeAjaxCallbacks: true,
                uploadExtraData: function (previewId, index) {
                    lecture_id = $("#image_info").find($('input[name="lecture_id"]')).val()
                    return {
                        lecture_id: lecture_id,
                    };
                },
            }).on('fileuploaded', function (event, data) {
                var form = data.form,
                    files = data.files,
                    extra = data.extra,
                    response = data.response,
                    reader = data.reader;
                $("#addImageModal").modal("hide");
                salat(response.message);
                $("#image_upload").fileinput('clear');
            });

            $('#addsec1').click(function (e) {
                e.preventDefault();
                card = $(document).find($('#addseccard2'))
                if (!card.hasClass('d-none')) {
                    card.addClass('d-none');
                    card.find($('form'))[0].reset();
                }
                $('#addseccard').removeClass('d-none');
            });
            $('#addsec2').click(function (e) {
                e.preventDefault();
                card = $(document).find($('#addseccard'))
                if (!card.hasClass('d-none')) {
                    card.addClass('d-none');
                    card.find($('form'))[0].reset();
                }
                $('#addseccard2').removeClass('d-none');
            });


            function getAllSections(cid, type) {
                // course_id = $('#course_id').val();
                cardbody = $('#cur_card').find($('.main'))
                i = cardbody.find($('.section')).length;
                $.ajax({
                    method: 'GET',
                    url: api_url + 'admin/get_sections/' + cid,
                    beforeSend: () => {
                        cardbody.html(`
                    <div class="d-flex justify-content-center">
                        <div class="spinner-border text-black-100" style="width: 5rem; height: 5rem;" role="status">
                        <span class="visually-hidden">Loading...</span>
                        </div>
                    </div>
                        `);
                    },
                }).done(res => {
                    console.log(res);
                    if (res.data.length === 0) {
                        cardbody.html(`<div class="bg-light-secondary rounded p-2 mb-4 dummy">
                        <div class="d-inline-block me-3"><p class="text-capitalize fw-bold text-dark fs-4">Topic 1:</p></div>
                            <div class="d-inline-block me-3">
                            <span class="d-inline-block me-3"><h4 class="text-capitalize">Introduction</h4></span>
                            <span class="d-inline-block"><a href="javascript:void(0)" class="me-1 text-inherit alt_section" data-bs-toggle="tooltip" data-placement="top"
                                title="Edit"><i class="fe fe-edit fs-6"></i></a>
                                </span></div>
                                    <!-- List group -->
                                    <div class="list-group list-group-flush border-top-0" id="courseList">
                                        <div id="courseOne">
                                            <div class="list-group-item rounded px-3 mb-1" id="introduction">
                                                <div class="d-flex align-items-center justify-content-between">
                                                    <h5 class="mb-0">
                                                        <a href="#" class="text-inherit">
                                                            <i class="fe fe-menu me-1 text-muted align-middle"></i>
                                                            <span class="align-middle">Introduction</span>
                                                        </a>
                                                    </h5>
                                                    <div><a href="#" class="me-1 text-inherit"
                                                            data-bs-toggle="tooltip" data-placement="top" title="Edit"><i
                                                                class="fe fe-edit fs-6 alt_section"></i></a>
                                                    </div>
                                                </div>

                                            </div>
                                        </div>
                                    </div>
                                    <a href="javascript:void(0)" class="btn btn-outline-primary btn-sm mt-3 alt_section">Add Lecture +</a>
                                </div>`)
                        return;
                    }
                    cardbody.html('');
                    i = 1;
                    res.data.map(sec => {
                        lectures = ''
                        sec.lectures.forEach(lec => {
                            lectures += `
                        <div class="list-group-item rounded px-3 mb-1" id="${stripLower(lec.title + lec.id)}">
                            <div class="d-flex align-items-center justify-content-between lec_details">
                                <h5 class="mb-0">
                                <a href="#" class="text-inherit">
                                    <i class="fe fe-menu me-1 text-muted align-middle"></i>
                                    <span class="align-middle text-capitalize lec_tit">${lec.title}</span>
                                    <div hidden name="lec_desc" class="lec_desc">${lec.description}</div>
                                    <input type="hidden" name="lec_id" class="lec_id" value="${lec.id}" />
                                    <input type="hidden" name="sec_id" class="sec_id" value="${lec.section_id}" />
                                    ${mainContentField(type, lec.main_content ?? '', lec.text ?? '')}
                                </a>
                                </h5>
                                <div><a href="javascript:void(0)" class="me-1 text-inherit edit_lec" data-bs-toggle="tooltip" data-placement="top"
                                    title="Edit"><i class="fe fe-edit fs-6"></i></a>
                                ${dropDownButton(lec.id)}
                                </div>
                            </div>
                            <div id="collapselist${lec.id}" class="collapse" aria-labelledby="${stripLower(lec.title + lec.id)}"
                                data-bs-parent="#lecture${lec.section_id}">
                                <div class="card-body">
                                ${contentType(type)}
                                </div>
                            </div>
                        </div>
                        `
                        })
                        cardbody.append(`
                    <div class="bg-light-secondary rounded p-2 mb-4 section">
                            <div class="d-inline-block me-3"><p class="text-capitalize fw-bold text-dark fs-4">Topic ${i++}:</p></div>
                            <div class="d-inline-block me-3">
                            <input type="hidden" name="section_id" value="${sec.id}" />
                            <input type="hidden" name="gain" value="${sec.course_gain}" />
                            <span class="d-inline-block me-3"><h4 class="text-capitalize sec_title">${sec.title}</h4></span>
                            <span class="d-inline-block"><a href="javascript:void(0)" class="me-1 text-inherit" data-bs-toggle="tooltip" data-placement="top"
                                title="Edit"><i class="sec_edit fe fe-edit fs-6"></i></a></span></div>
                                <div class="list-group list-group-flush border-top-0" id="lecList${sec.id}">
                                    <div id="lecture${sec.id}">
                                        ${lectures}
                                    </div>
                                </div>
                            <div><button class="btn btn-outline-primary btn-sm mt-3 addlec" data-bs-toggle="modal"
                                data-bs-target="#addLectureModal">Add Lecture +</button></div>

                        </div>
                `)
                    })
                }).fail(res => {
                    concatError(res.responseJSON);
                })
            }

            $(document).on('click', '.alt_section', function (e) {
                e.preventDefault();
                card = $(document).find($('#addseccard2'))
                if (!card.hasClass('d-none')) {
                    card.addClass('d-none');
                    card.find($('form'))[0].reset();
                }
                $('#addseccard').removeClass('d-none');
            })


            form = $("div.addseccard").find($('form'));
            form.submit(function (e) {
                e.preventDefault();
                title = $(this).find('input[name="title"]').val();
                gain = $(this).find('input[name="purpose"]').val();
                course_id = $('#course_id').val();
                bt = $('form').find('button[type="submit"]');
                if (!title || !gain) {
                    salat('All Fields Required', 1);
                    return;
                }
                cardbody = $('#cur_card').find($('.main'))
                i = cardbody.find($('.section')).length;
                dummy = cardbody.find($("div.dummy"));
                $.ajax({
                    method: "POST",
                    url: api_url + `admin/add_section`,
                    data: {
                        course_id: course_id,
                        title: title,
                        gain: gain,
                    },
                    beforeSend: () => {
                        btn(bt, '', 'before');
                    }
                }).done(res => {
                    console.log(res);
                    salat(res.message);
                    btn(bt, 'Add Section', 'after');
                    if (dummy) {
                        dummy.remove();
                    }
                    cardbody.append(`
                        <div class="bg-light-secondary rounded p-2 mb-4 section">
                            <div class="d-inline-block me-3"><p class="text-capitalize fw-bold text-dark fs-4">Topic ${++i}:</p></div>
                            <div class="d-inline-block me-3">
                            <input type="hidden" name="section_id" value="${res.id}" />
                            <input type="hidden" name="gain" value="${gain}" />
                            <span class="d-inline-block me-3"><h4 class="text-capitalize sec_title">${title}</h4></span>
                            <span class="d-inline-block"><a href="javascript:void(0)" class="me-1 text-inherit" data-bs-toggle="tooltip" data-placement="top"
                                title="Edit"><i class="sec_edit fe fe-edit fs-6"></i></a></span></div>
                                <div class="list-group list-group-flush border-top-0" id="lecList${res.id}">
                                    <div id="lecture${res.id}">

                                    </div>
                                </div>
                            <div><button href="#" class="btn btn-outline-primary btn-sm mt-3 addlec" data-bs-toggle="modal"
                                data-bs-target="#addLectureModal">Add Lecture +</button></div>
                        </div>`)
                    $('form').each(function () {
                        this.reset()
                    });
                    $('.addseccard').addClass('d-none');
                }).fail(res => {
                    console.log(res);
                    concatError(res.responseJSON)
                    btn(bt, 'Add Section', 'after');
                })


            });
            $('.closecard').each((i, obj) => {
                $(obj).find($('a')).on('click', function (e) {
                    e.preventDefault();
                    $(this).closest($('.addseccard')).addClass('d-none');
                    $(this).closest($('.addseccard')).find('form')[0].reset()
                });
            });


            $(document).on('click', '.section', function (e) {
                e.preventDefault();

                if ($(e.target).hasClass('sec_edit')) {
                    section = $(this);
                    title = section.find($('.sec_title')).html();
                    gain = section.find($('input[name="gain"]')).val();
                    section_id = section.find($('input[name="section_id"]')).val();

                    $('#editSectionModal').modal('show');
                    form = $('#editSectionModal').find($('form'));
                    form.find($('input[name="title"]')).val(title);
                    form.find($('input[name="section_id"]')).val(section_id);
                    form.find($('input[name="gain"]')).val(gain);

                }

            });


            form = $('#editSectionModal').find($('form'));
            form.submit(function (e) {
                e.preventDefault();
                title = $(this).find($('input[name="title"]')).val();
                id = $(this).find($('input[name="section_id"]')).val();
                gain = $(this).find($('input[name="gain"]')).val();
                course_id = $('#course_id').val();
                bt = $(this).find($('button[type="submit"]'));

                if (!title || !gain) {
                    salat('All Fields Required', 1);
                    return;
                }

                $.ajax({
                    url: api_url + `admin/update_section`,
                    method: 'POST',
                    data: {
                        title: title,
                        id: id,
                        gain: gain,
                        course_id: course_id,
                    },
                    beforeSend: () => {
                        btn(bt, '', 'before');
                    },
                }).done(res => {
                    console.log(res);
                    btn(bt, 'Save Section', 'after');
                    section.find($('.sec_title')).html(title);
                    section.find($('input[name="gain"]')).val(gain);
                    salat(res.message);
                    $('#editSectionModal').modal('hide');
                }).fail(res => {
                    btn(bt, 'Save Section', 'after');
                    concatError(res.responseJSON);
                })
            })


            $(document).on('click', '.section', function (e) {
                e.preventDefault();
                if ($(event.target).hasClass('addlec')) {
                    section = $(this);
                    section_id = section.find($('input[name="section_id"]')).val();
                    form = $('#addLectureModal').find($('form'))
                    form.find($('input[name="section_id"]')).val(section_id);
                }

            });
            $('#addLectureModal').find($('form')).submit(function (e) {
                e.preventDefault();
                title = $(this).find($('input[name="title"]')).val();
                section_id = $(this).find($('input[name="section_id"]')).val();
                description = $(this).find($('textarea')).val();
                bt = $(this).find($('button[type="submit"]'));
                type = $("#ctype").val();

                if (!title || !description) {
                    salat('All Fields Required', 1);
                    return;
                }
                $.ajax({
                    url: api_url + `admin/add_lecture`,
                    method: 'POST',
                    data: {
                        title: title,
                        section_id: section_id,
                        description: description,
                    },
                    beforeSend: () => {
                        btn(bt, '', 'before');
                    },
                }).done(res => {
                    console.log(res);
                    salat(res.message);
                    btn(bt, 'Save Lecture', 'after');
                    $(document).find($(`#lecture${section_id}`)).append(`
                        <div class="list-group-item rounded px-3 mb-1" id="${stripLower(title + res.id)}">
                            <div class="d-flex align-items-center justify-content-between lec_details">
                                <h5 class="mb-0">
                                <a href="#" class="text-inherit">
                                    <i class="fe fe-menu me-1 text-muted align-middle"></i>
                                    <span class="align-middle text-capitalize lec_tit">${title}</span>
                                    <div hidden name="lec_desc" class="lec_desc">${description}</div>
                                    <input type="hidden" name="lec_id" class="lec_id" value="${res.id}" />
                                    <input type="hidden" name="sec_id" class="sec_id" value="${section_id}" />
                                    ${mainContentField(type, "", "")}
                                </a>
                                </h5>
                                <div><a href="javascript:void(0)" class="me-1 text-inherit edit_lec" data-bs-toggle="tooltip" data-placement="top"
                                    title="Edit"><i class="fe fe-edit fs-6"></i></a>
                                ${dropDownButton(res.id)}
                                </div>
                            </div>
                            <div id="collapselist${res.id}" class="collapse" aria-labelledby="${stripLower(title + res.id)}"
                                data-bs-parent="#lecture${section_id}">
                                <div class="card-body">
                                ${contentType(type)}
                                </div>
                            </div>
                        </div>
                        `)
                    $('#addLectureModal').modal('toggle')
                    form[0].reset();
                    try {
                        c_desc.setData('')
                    } catch (error) {
                        console.error(error);
                    }
                }).fail(res => {
                    console.log(res);
                    concatError(res.responseJSON);
                    btn(bt, 'Save Lecture', 'after');

                })
            })

            $(document).on('click', '.edit_lec', function (e) {
                e.preventDefault();
                parent = $(this).closest($("div.lec_details"));

                title = parent.find($("span.lec_tit")).html();
                id = parent.find($("input[name='lec_id']")).val();
                description = parent.find($("div[name='lec_desc']")).html();
                sec_id = parent.find($("input[name='sec_id']")).val();

                form = $("#editLectureModal").find($('form'));
                form.find($('input[name="title"]')).val(title);
                form.find($('input[name="lecture_id"]')).val(id);
                form.find($('input[name="section_id"]')).val(sec_id);
                edit_desc.setData(description);
                $("#editLectureModal").modal('show');

            })

            $("#editLectureForm").submit(function (e) {
                e.preventDefault();
                form = $(this);
                title = form.find($('input[name="title"]')).val();
                id = form.find($('input[name="lecture_id"]')).val();
                section_id = form.find($('input[name="section_id"]')).val();
                description = form.find($('textarea[name="edit_desc"]')).val();
                bt = form.find($('button[type="submit"]'));

                $.ajax({
                    url: api_url + 'admin/update_lecture',
                    method: 'POST',
                    data: {
                        title: title,
                        section_id: section_id,
                        id: id,
                        description: description,
                    },
                    beforeSend: () => {
                        btn(bt, '', 'before');
                    }
                }).done(res => {
                    console.log(res);
                    btn(bt, 'Save', 'after');
                    salat(res.message);
                    parent.find($("span.lec_tit")).html(title);
                    parent.find($("input[name='lec_id']")).val(id);
                    parent.find($("div[name='lec_desc']")).html(description);
                    parent.find($("input[name='sec_id']")).val(section_id);
                    $("#editLectureModal").modal('hide');
                }).fail(res => {
                    console.log(res);
                    btn(bt, 'Save', 'after');
                    concatError(res.responseJSON);
                })

            });

            $(document).on('click', '.vidmodal', function (e) {
                e.preventDefault();
                grandparent = $(this).parent().parent().parent();
                title = grandparent.find($("span.lec_tit")).html();
                description = grandparent.find($("input.lec_desc")).val();
                lecture_id = grandparent.find($("input.lec_id")).val();

                video_form = $("#video_info");
                video_form.find($('input[name="lecture_id"]')).val(lecture_id);
                video_form.find($('input[name="lecture_title"]')).val(title);
                video_form.find($('input[name="lecture_description"]')).val(description);
            })

        });
    </script>
@endsection

?>