LMS/E-Learning-Backend-main/app/controllers/meeting.controller.js
2025-09-01 19:37:35 +05:30

281 lines
13 KiB
JavaScript

const db = require("../models");
const API = require('../helper/API_Response');
const db_helper = require("../helper/db_helper");
const helper = require("../helper/helper");
const { MeetingChats, Flashcard, StudyMaterial, QuestionDiscussion, User, References, Books } = require("../models");
exports.add = async (req, res) => {
const input = await helper.decryptRequest(req.body.data);
res.status(200).send(API._200(await db_helper.addData('Meetings', input)));
};
exports.byId = async (req, res) => {
const input = await helper.decryptRequest(req.body.data);
res.status(200).send(API._200(await db_helper.byId('Meetings', input.id)));
};
exports.delete = async (req, res) => {
const input = await helper.decryptRequest(req.body.data);
const result = await db.sequelize.query("delete from meetings where id= :id", { replacements: { id: input.id } }).then((res) => {
return Array.from(new Set(res));
})
res.status(200).send(API._200(await result));
};
exports.get_message = async (req, res) => {
const input = await helper.decryptRequest(req.body.data);
const all = await MeetingChats.findAll({
where: {
status: 0,
meeting_id: input.meeting_id,
},
order: [
['createdAt', 'DESC'],
['id', 'ASC'],
],
include: [{
model: User,
attributes: ['id', 'email', 'name', 'aliasname', 'avatar_url']
}],
limit: [input.limitRecord, 100]
});
res.status(200).send(API._200(await all));
};
exports.get_single_message = async (req, res) => {
const input = await helper.decryptRequest(req.body.data);
const all = await MeetingChats.findAll({
where: {
status: 0,
meeting_id: input.meeting_id,
},
order: [
['createdAt', 'DESC'],
['id', 'ASC'],
],
include: [{
model: User,
attributes: ['id', 'email', 'name', 'aliasname', 'avatar_url']
}],
limit: [10]
});
res.status(200).send(API._200(await all));
};
exports.save_message = async (req, res) => {
const input = await helper.decryptRequest(req.body.data);
res.status(200).send(API._200(await db_helper.addData('MeetingChats', input)));
};
exports.get_know_report = async (req, res) => {
debugger
const data = await helper.decryptRequest(req.body.data);
var ass_ids = [];
const know_assess = await db.sequelize.query("SELECT ka.id,ka.knowass_name,case when RowNumber is not null then true else false end ViewSummeryicon from knowledge_asses as ka inner join cohorts as c on find_in_set(ka.id,c.knowassessments) left join (SELECT count(ass_id) RowNumber ,ass_id,cohort_id FROM know_ass_ques_ans where active=0 and cohort_id= :cohort_id and user_id= :user_id group by ass_id,cohort_id) ret on ret.ass_id=ka.id and ret.cohort_id=c.id where ka.certi_id= :cource_id and find_in_set(" + data.user_id + ",c.userslist) and ka.status=0 and c.id= :cohort_id group by ka.id, ka.knowass_name,ret.RowNumber", { replacements: { user_id: data.user_id, cohort_id: data.cohort_id, cource_id: data.cource_id } })
.then((data) => {
ass_ids = Array.from(new Set(data[0]));
});
var d = [];
if (ass_ids.length > 0) {
var c_date_data = await db_helper.selectByWhere('KaComplete', { user_id: data.user_id, cohort_id: data.cohort_id }, ['createdAt', 'ka_id']);
var schedule_data = await db_helper.selectByWhere('CohortSchedule', { type: "KA", cohort_id: data.cohort_id }, ['due_date', 'overdue_date', 'type_id']);
for (let i = 0; i < ass_ids.length; i++) {
const knowAssQues = await db.sequelize.query(`SELECT ans,correct from know_ass_ques_ans WHERE cohort_id=${data.cohort_id} AND user_id=${data.user_id} AND active=1 AND ass_id=${ass_ids[i].id}`).then(data => Array.from(new Set(data[0])));
const knowAss = await db.sequelize.query(`SELECT id from know_ass_ques WHERE FIND_IN_SET(${ass_ids[i].id}, ass_id) and status=0`).then(data => Array.from(new Set(data[0])));
let schedule = schedule_data.filter(x => x.type_id == ass_ids[i].id)
let c_date = "";
if (c_date_data.length > 0) {
let c_date_array = c_date_data.filter(x => x.ka_id == ass_ids[i].id)
if (c_date_array.length > 0) {
c_date = c_date_array[0].createdAt;
} else {
c_date = "";
}
} else {
c_date = "";
}
let correct = [];
correct = await knowAssQues.filter(res => res.correct == 1);
let wrong = [];
wrong = await knowAssQues.filter(res => res.correct == 0);
let dknow = [];
dknow = await knowAssQues.filter(res => res.correct == "2");
var r = await {
ass_id: ass_ids[i].id,
knowass_name: ass_ids[i].knowass_name,
user_id: data.user_id,
currect: correct.length,
dknow: dknow.length,
panding: knowAss.length - (correct.length + wrong.length + dknow.length),
wrong: wrong.length,
total: wrong.length + correct.length + (knowAss.length - (correct.length + wrong.length)),
c_date,
schedule,
ViewSummeryicon: ass_ids[i].ViewSummeryicon
}
let ab = await r;
await d.push(ab);
}
} else {
res.status(200).send(API._200(await d));
}
res.status(200).send(API._200(await d));
};
exports.filter_knowledge_question = async (req, res) => {
const data = await helper.decryptRequest(req.body.data);
var q = "";
if (data.RowNumber > 0) {
q = "Select kaq.*,(CASE WHEN kaqa.ans IS NULL then false ELSE true END) as answered,kaqa.ans as user_ans from (SELECT *, @cur:= IF(KAQ_id=@id, @cur+1, 1) AS RowNumber, @id := KAQ_id FROM know_ass_ques_ans t CROSS JOIN(SELECT @id:=(SELECT MIN(KAQ_id) FROM know_ass_ques_ans where active=0 and cohort_id=" + data.cohort_id + " and ass_id=" + data.ass_id + " and user_id=" + data.user_id + "), @cur:=0) AS init where active=0 and cohort_id=" + data.cohort_id + " and ass_id=" + data.ass_id + " and user_id=" + data.user_id + " ORDER BY t.KAQ_id) as kaqa RIGHT JOIN know_ass_ques as kaq ON kaqa.KAQ_id=kaq.id WHERE FIND_IN_SET(" + data.ass_id + ",kaq.ass_id) and kaq.status=0 AND kaqa.RowNumber=" + data.RowNumber;
} else {
q = "Select * from know_ass_ques as kaq WHERE FIND_IN_SET(" + data.ass_id + ",kaq.ass_id) and kaq.status=0";
}
for (const [key, value] of Object.entries(data)) {
if (key != "ass_id" && key != "user_id" && key != "cohort_id" && key != "method_id" && key != "material_type" && key != "method_type" && key != "RowNumber") {
q += " and kaq." + key + "=" + value;
}
}
const knowAssQues = await db.sequelize.query(q)
.then(function (data) {
return Array.from(new Set(data[0]));
})
let knowAssQuesAns = []
if (data.RowNumber <= 0) {
knowAssQuesAns = await db.sequelize.query("Select (CASE WHEN kaqa.ans IS NULL then false ELSE true END) as answered,kaqa.ans as user_ans,KAQ_id from (select * from know_ass_ques_ans where cohort_id=" + data.cohort_id + " and active=1 and user_id=" + data.user_id + " and ass_id=" + data.ass_id + ") as kaqa")
.then(function (data) {
return Array.from(new Set(data[0]));
})
}
for (let i = 0; i < knowAssQues.length; i++) {
if (data.RowNumber <= 0) {
let answers = knowAssQuesAns.filter(x => x.KAQ_id == knowAssQues[i].id)
if (answers.length > 0) {
knowAssQues[i].answered = answers[0].answered;
knowAssQues[i].user_ans = answers[0].user_ans;
} else {
knowAssQues[i].answered = 0;
knowAssQues[i].user_ans = null;
}
}
}
if (!knowAssQues) {
res.status(404).send(API._404({ message: "No data found" }));
}
res.status(200).send(API._200(await knowAssQues.sort((a, b) => a.id - b.id)));
};
exports.knowledge_result_pagination = async (req, res) => {
const data = await helper.decryptRequest(req.body.data);
var offset = (data.pageNumber - 1) * data.pageSize;
var limit = data.pageSize;
var q = "";
if (data.RowNumber > 0) {
q = "Select kaq.*,(CASE WHEN kaqa.ans IS NULL then false ELSE true END) as answered,kaqa.ans as user_ans from (SELECT *, @cur:= IF(KAQ_id=@id, @cur+1, 1) AS RowNumber, @id := KAQ_id FROM know_ass_ques_ans t CROSS JOIN(SELECT @id:=(SELECT MIN(KAQ_id) FROM know_ass_ques_ans where active=0 and cohort_id=" + data.cohort_id + " and ass_id=" + data.ass_id + " and user_id=" + data.user_id + "), @cur:=0) AS init where active=0 and cohort_id=" + data.cohort_id + " and ass_id=" + data.ass_id + " and user_id=" + data.user_id + " ORDER BY t.KAQ_id) as kaqa RIGHT JOIN know_ass_ques as kaq ON kaqa.KAQ_id=kaq.id WHERE FIND_IN_SET(" + data.ass_id + ",kaq.ass_id) and kaq.status=0 AND kaqa.RowNumber=" + data.RowNumber + " LIMIT " + limit + " OFFSET " + offset;
} else {
q = "Select * from know_ass_ques as kaq WHERE FIND_IN_SET(" + data.ass_id + ",kaq.ass_id) and kaq.status=0 LIMIT " + limit + " OFFSET " + offset;
}
for (const [key, value] of Object.entries(data)) {
if (key != "ass_id" && key != "user_id" && key != "cohort_id" && key != "method_id" && key != "material_type" && key != "method_type" && key != "RowNumber" && key != 'pageSize' && key != 'pageNumber') {
q += " and kaq." + key + "=" + value;
}
}
const cohort_data = await db_helper.query("select videos,mindmaps,flashcard_access,video_access,mindmap_access,summary_access,reference_access from cohorts where id=" + data.cohort_id);
const knowAssQues = await sequelize.query(q)
.then(function (data) {
return Array.from(new Set(data[0]));
})
let knowAssQuesAns = []
if (data.RowNumber <= 0) {
knowAssQuesAns = await sequelize.query("Select (CASE WHEN kaqa.ans IS NULL then false ELSE true END) as answered,kaqa.ans as user_ans,KAQ_id from (select * from know_ass_ques_ans where cohort_id=" + data.cohort_id + " and active=1 and user_id=" + data.user_id + " and ass_id=" + data.ass_id + ") as kaqa")
.then(function (data) {
return Array.from(new Set(data[0]));
})
}
for (let i = 0; i < knowAssQues.length; i++) {
if (data.RowNumber <= 0) {
let answers = knowAssQuesAns.filter(x => x.KAQ_id == knowAssQues[i].id)
if (answers.length > 0) {
knowAssQues[i].answered = answers[0].answered;
knowAssQues[i].user_ans = answers[0].user_ans;
} else {
knowAssQues[i].answered = 0;
knowAssQues[i].user_ans = null;
}
}
const fls = await Flashcard.findAll({
where: {
topic_id: knowAssQues[i].topic_id,
status: 0
},
attributes: ['id', 'term', 'definition']
});
var study = [];
study = await StudyMaterial.findAll({
where: {
topic_id: knowAssQues[i].topic_id,
status: 0
},
attributes: ['id', 'title', 'content']
});
let vquery = "";
vquery = "select id,video_title,video_thumbnil,duration,type,topic_list,video_link from videos where status=0 and find_in_set(" + knowAssQues[i].topic_id + ",topic_id) order by sr_number";
var video = await db_helper.query(vquery);
const dissc = await QuestionDiscussion.findAll({
where: {
test_id: knowAssQues[i].ass_id,
test_type: 'KA',
q_id: knowAssQues[i].id,
status: 0
},
include: [{
model: User,
attributes: ['id', 'name', 'email', 'avatar_url']
}]
});
var refers = [];
refers = await References.findAll({
where: {
topic_id: knowAssQues[i].topic_id,
status: 0
},
include: [{
model: Books,
attributes: ['id', 'book_title', 'book_img']
}]
});
var mind = await db_helper.query("select id,thumbnail_link,name from mind_maps where status=0 and find_in_set(" + knowAssQues[i].topic_id + ",topic_id) order by sr_number");
knowAssQues[i].Flashcards = fls;
knowAssQues[i].StudyMaterials = study;
knowAssQues[i].Video = video[0];
knowAssQues[i].Discussion = dissc;
knowAssQues[i].References = refers;
knowAssQues[i].MindMaps = mind[0];
knowAssQues[i].MindMapsAccess = cohort_data[0][0].mindmap_access;
knowAssQues[i].ReferencesAccess = cohort_data[0][0].reference_access;
knowAssQues[i].VideoAccess = cohort_data[0][0].video_access;
knowAssQues[i].StudyMaterialsAccess = cohort_data[0][0].summary_access;
knowAssQues[i].FlashcardAccess = cohort_data[0][0].flashcard_access;
}
if (!knowAssQues) {
res.status(404).send(API._404({ message: "No data found" }));
}
res.status(200).send(API._200(await knowAssQues.sort((a, b) => a.id - b.id)));
};
exports.delete_meeting_chats = async (req, res) => {
const input = await helper.decryptRequest(req.body.data);
let message = input.meeting_name + " has been completed ";
const notifications = await db_helper.query("update notifications set noti_type='complete_meeting', message='" + message + "' where test_type='meeting' and test_id=" + input.meeting_id);
const result = await db.sequelize.query("delete from meeting_chats where meeting_id= :id", { replacements: { id: input.meeting_id } }).then((res) => {
return Array.from(new Set(res));
})
res.status(200).send(API._200(await result));
};
exports.update = async (req, res) => {
const input = await helper.decryptRequest(req.body.data);
res.status(200).send(API._200(await db_helper.update('Meetings', input)));
};