123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346 |
- const { CloudQuery, CloudObject } = require("../lib/ncloud");
- const { QuestionnaireResultList, QuestionnaireList, QuestionList, OptionList, UserInterestProfileList } = require("./data");
- let DataMap = {
- QuestionnaireResult: {},
- Questionnaire: {},
- Question: {},
- Option: {},
- UserInterestProfile: {}
- };
- async function importData() {
-
- if (!UserInterestProfileList || UserInterestProfileList.length === 0) {
- console.log("UserInterestProfileList 数据为空或未定义!");
- return;
- }
-
- let questionnaireResultList = QuestionnaireResultList;
- for (let index = 0; index < questionnaireResultList.length; index++) {
- let result = questionnaireResultList[index];
- result = await importObject("QuestionnaireResult", result);
- }
-
- let questionnaireList = QuestionnaireList;
- for (let index = 0; index < questionnaireList.length; index++) {
- let questionnaire = questionnaireList[index];
- questionnaire = await importObject("Questionnaire", questionnaire);
- }
-
- let questionList = QuestionList;
- for (let index = 0; index < questionList.length; index++) {
- let question = questionList[index];
- question = await importObject("Question", question);
- }
-
- let optionList = OptionList;
- for (let index = 0; index < optionList.length; index++) {
- let option = optionList[index];
- option = await importObject("Option", option);
- }
-
- let userInterestProfileList = UserInterestProfileList;
- for (let index = 0; index < userInterestProfileList.length; index++) {
- let profile = userInterestProfileList[index];
- profile = await importObject("UserInterestProfile", profile);
- }
-
- }
- async function importObject(className, data) {
-
- let idField = `${className}Id`;
- let srcId = data[idField];
-
- let query = new CloudQuery(className);
- query.equalTo("srcId", srcId);
- let importObj = await query.first();
- console.log(importObj);
-
- Object.keys(data)?.forEach(key => {
- let field = data[key];
- let fieldSrcId = field?.objectId || field?.OptionId || field?.QuestionId || field?.UserInterestProfileId;
- if (fieldSrcId) {
- if (key === "userIds" || key === "questionnaireIds" || key === "questionIds") {
-
- data[key] = Array.isArray(field) ? field.map(item => {
- return {
- className: item.className,
- srcId: DataMap?.[item.className]?.[item.srcId]?.id || item.srcId
- };
- }) : [{
- className: key.replace("Ids", ""),
- srcId: DataMap?.[key.replace("Ids", "")]?.[fieldSrcId]?.id || fieldSrcId
- }];
- } else if (Array.isArray(field)) {
- data[key] = field.map(item => {
- return {
- className: item.className,
- srcId: DataMap?.[item.className]?.[item.srcId]?.id || item.srcId
- };
- });
- }
- }
- });
-
- if (!importObj?.id) {
- importObj = new CloudObject(className);
- }
-
- data.srcId = srcId;
- importObj.set(data);
- importObj = await importObj.save();
-
- DataMap[className][srcId] = importObj;
- }
- async function displayQuestionnaireDetails(questionnaireId) {
-
- let questionnaireQuery = new CloudQuery("Questionnaire");
- questionnaireQuery.equalTo("QuestionnaireId", questionnaireId);
- let questionnaire = await questionnaireQuery.first();
-
- if (!questionnaire) {
- console.log("问卷未找到,无法展示问题和选项。");
- return;
- }
- console.log(`问卷标题: ${questionnaire.get('title')}`);
- console.log(`问卷状态: ${questionnaire.get('status')}`);
- console.log("问题列表:");
-
- let questionIds = questionnaire.get('questions');
-
- let questionQuery = new CloudQuery("Question");
- questionQuery.containedIn("QuestionId", questionIds);
- let questions = await questionQuery.find();
-
- if (questions.length === 0) {
- console.log("当前问卷没有问题。");
- return;
- }
-
- for (let question of questions) {
-
- if (!question) {
- console.log("问题未找到,无法展示选项。");
- continue;
- }
- console.log(` 问题: ${question.questionText}`);
-
- let optionIds = question.options;
-
- let optionQuery = new CloudQuery("Option");
- optionQuery.containedIn("OptionId", optionIds);
- let options = await optionQuery.find();
-
- console.log(" 选项:");
- if (options.length === 0) {
- console.log(" - 此问题没有选项。");
- } else {
- for (let option of options) {
- console.log(` - ${option.optionText} (已选: ${option.isSelected ? "是" : "否"})`);
- }
- }
- console.log("");
- }
- }
- displayQuestionnaireDetails("test_q1");
|