Untitled

mail@pastecode.io avatar
unknown
plain_text
a month ago
3.2 kB
2
Indexable
Never
module.exports.getCourseDetailsById = async (req, res, next) => {
  const courseId = req.params.courseId;

  try {
    // Find the course by ID
    const course = await courseCollection.findOne({ _id: new ObjectId(courseId) });

    if (!course) {
      return res.status(404).json({ message: "Course not found" });
    }

    // Find chapters for the course
    const chapters = await chapterCollection.find({ courseId: courseId }).toArray();

    // Count the number of chapters
    const numberOfChapters = chapters.length;

    // Extract unique weekIds and count the number of weeks
    const weekIds = new Set(chapters.map((chapter) => chapter.weekId));
    const numberOfWeeks = weekIds.size;

    // Count the number of students enrolled in the course
    const studentCount = await userCollection.countDocuments({
      "courses.courseId": courseId,
    });

    // Task type breakdown with task data, completion percentage, and overall percentage
    const taskTypeDetails = chapters.reduce((acc, chapter) => {
      chapter.tasks.forEach((task) => {
        if (!task) return; // Skip null tasks
        
        // Calculate completion percentage for the individual task
        const participantsCount = task.participants ? task.participants.length : 0;
        const completionPercentage = (participantsCount / studentCount) * 100;

        // Initialize the task type in the accumulator if not already present
        if (!acc[task.taskType]) {
          acc[task.taskType] = {
            tasks: [],
            totalCompletionParticipants: 0,
            taskCount: 0
          };
        }

        // Add task details along with completion percentage
        acc[task.taskType].tasks.push({
          taskId: task.taskId,
          taskName: task.taskName,
          participantsCount,
          completionPercentage,
          ...task // Include all other task details
        });

        // Accumulate the completion percentage and task count
        acc[task.taskType].totalCompletionParticipants += completionPercentage;
        acc[task.taskType].taskCount += 1;
      });
      return acc;
    }, {});

    // Calculate the overall completion percentage for each task type
    Object.keys(taskTypeDetails).forEach(taskType => {
      const taskTypeInfo = taskTypeDetails[taskType];
      taskTypeInfo.overallCompletionPercentage = (taskTypeInfo.totalCompletionParticipants / taskTypeInfo.taskCount).toFixed(2);
    });

    // Calculate the total task count
    const totalTaskCount = Object.values(taskTypeDetails).reduce(
      (sum, { taskCount }) => sum + taskCount,
      0
    );

    // Construct the response
    const courseWithDetails = {

      numberOfChapters,
      numberOfWeeks,
      totalTaskCount,
      studentCount,
      taskTypeDetails, // Include detailed task information with overall completion percentages
      chapters, // Include chapters if you still need the full details
    };

    res.status(200).json(courseWithDetails);
  } catch (error) {
    console.error("Error retrieving course details:", error);
    res.status(500).json({ message: "Internal Server Error" });
  }
};
Leave a Comment