Формирование JSON данных из пожарного магазина - PullRequest
0 голосов
/ 25 февраля 2020

Я использую облачную функцию для загрузки своей коллекции БД в виде файла JSON.

Код

exports.csvJsonReport = functions.https.onRequest((request, response) => {
  const db = admin.firestore()
  const userAnswers = db.collection('/surveys/CNA/submissions')
  return (
    userAnswers
      .get()
      .then(querySnapshot => {
        let answers = []
        querySnapshot.forEach(doc => {
          const answer = doc.data()
          answers.push({ ...answer.answers, ...answer.anonUser })
        })

        response.setHeader('Content-disposition', 'attachment; filename=cna.json')
        response.set('Content-Type', 'application/json')
        response.status(200).send(answers)
      })
      .catch(error => {
        console.log(error)
      })
  )
})

Большую часть времени меня волнует только value , но иногда value вложено внутрь .. и когда оно будет вложено, мне понадобится value и name

токовый выход

[{
"2": {
      "loopIndex": null,
      "questionType": "multiChoice",
      "value": "Farm owner",
      "id": 1
    },
"7": {
      "1": {
        "name": "Enviroment management",
        "questionType": "responsiveMultiCheckBox",
        "valueId": 4,
        "value": "My top priority right now",
        "id": 1
      },
      "2": {
        "questionType": "responsiveMultiCheckBox",
        "valueId": 3,
        "value": "One of my top priorities",
        "id": 2,
        "name": "Financial management"
      },
      "3": {
        "value": "My top priority right now",
        "id": 3,
        "name": "People management",
        "questionType": "responsiveMultiCheckBox",
        "valueId": 4
      },
      "4": {
        "name": "Reproduction management",
        "questionType": "responsiveMultiCheckBox",
        "valueId": 4,
        "value": "My top priority right now",
        "id": 4
      },
      "5": {
        "name": "Feed management",
        "questionType": "responsiveMultiCheckBox",
        "valueId": 4,
        "value": "My top priority right now",
        "id": 5
      }
    },
}]

желаемый выход:

[{
    "2": {
          "value": "Farm owner",
        },
    "7": {
          "1": {
            "name": "Enviroment management",
            "value": "My top priority right now",
          },
          "2": {
            "value": "One of my top priorities",
            "name": "Financial management"
          },
          "3": {
            "value": "My top priority right now",
            "name": "People management",
          },
          "4": {
            "name": "Reproduction management",
            "value": "My top priority right now",
         },
          "5": {
            "name": "Feed management",
            "value": "My top priority right now",
          }
        },
    }]

Я пытался

answer.answers.map(questionId => {
            return console.log('value', questionId.value)
          })

, но answers.answers.map не является функцией

1 Ответ

1 голос
/ 25 февраля 2020

вот рабочая скрипка: https://jsfiddle.net/uekbhta6/2/

let result = {}; 
// I am assuming that your answers array always contains one object with the rest of data    
for (let id in answers[0])
{
    // If the value is present on the 1st level, push it to the buffer
    if (answers[0][id].value) 
    {
        result[id] = answers[0][id].value;
    }
    // otherwise, iterate through the second level and push name/value to result buffer
    else
    {
       result[id] = {};
       for(let id2 in answers[0][id])
       {
          result[id][id2] = {
                name:answers[0][id][id2].name,
              value:answers[0][id][id2].value
          };
       }
    }   
}
// wrap result in an array and print
console.log([result])

Это можно сделать более элегантно с Array.reduce(), однако уже поздно и мне нужно немного поспать.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...