Задать вопрос
  • Как отобразить данные на странице из API?

    @noskiddie Автор вопроса
    Алексей, Я вроде разобрался наконец. Единственное что смущает, я в консоли получаю информацию о 4-х записях (днях)
    а на странице html.pug видно только текущий день.

    Как можно вывести все записи?
  • Как отобразить данные на странице из API?

    @noskiddie Автор вопроса
    Алексей, Я не правильный пример предоставил?)

    60567e6405eb7745605883.png
  • Как отобразить данные на странице из API?

    @noskiddie Автор вопроса
    Алексей, Вы правильно предполагаете. Но если не сложно, попрошу помочь разобраться как мне извлечь из массива stepsArray, поле steps.value ( там еще поле intVal: "Количество шагов"

    Это весь код.

    const express = require("express")
    const app = express()
    const port = 1234
    const {google} = require("googleapis")
    const request = require("request")
    const cors = require("cors")
    const urlParse = require("url-parse")
    const queryParse = require("query-string")
    const bodyParser = require("body-parser")
    const axios =   require("axios")
    const { response } = require("express")
    const path = require("path")
    const pug = require("pug")
    
    
    // APP
    
    app.use(cors())
    app.use(bodyParser.urlencoded({ extended: true}))
    app.use(bodyParser.json())
    app.set('view engine', 'pug')
    
    
    app.get("/", (req, res) => {
        res.sendFile(path.resolve(__dirname, 'static', 'index.html'))
    })
    
    app.get("/getURL", (req, res) => {
        const oauth2Client = new google.auth.OAuth2(
            // client id
            "000000-000000.apps.googleusercontent.com",
            // client secret
            "00000000000",
            // link to redirect
            "http://localhost:1234/steps"
        )
    
            const scopes = [ "https://www.googleapis.com/auth/fitness.activity.read profile email openid" ]
    
            const url = oauth2Client.generateAuthUrl({
                access_type: "offline",
                scope: scopes,
                state: JSON.stringify({
                    callbackUrl: req.body.callbackUrl,
                    userID: req.body.userid
                })
            })
    
            request(url, (err, response, body) => {
                console.log("error: ", err)
                console.log("statusCode: ", response && response.statusCode)
                res.send({ url })
            })
    })
    
    app.get("/steps", async (req, res) => {
        const queryURL = new urlParse(req.url)
        const code = queryParse.parse(queryURL.query).code
        const oauth2Client = new google.auth.OAuth2(
            // client id
            "0000-00000.apps.googleusercontent.com",
            // client secret
            "0000000000000",
            // link to redirect
            "http://localhost:1234/steps"
        )
        
        const tokens = await oauth2Client.getToken(code)
        
    
        let stepArray = []
    
        try {
            const result = await axios({
              method: "POST",
              headers: {
                authorization: "Bearer " + tokens.tokens.access_token,
              },
              "Content-Type": "application/json",
              url: `https://www.googleapis.com/fitness/v1/users/me/dataset:aggregate`,
              data: {
                aggregateBy: [
                  {
                    dataTypeName: "com.google.step_count.delta",
                    dataSourceId:
                      "derived:com.google.step_count.delta:com.google.android.gms:estimated_steps",
                  },
                ],
                bucketByTime: { durationMillis: 86400000 },
                startTimeMillis: Date.now() - 30 * 86400000,
                endTimeMillis: Date.now(),
              },
            });
    
            stepArray = result.data.bucket
        } catch (e) {
            console.log(e)
        }
        try {
            for (const dataSet of stepArray){
                // console.log(dataSet)
                for (const points of dataSet.dataset) {
                    // console.log(points)
                    for (const steps of points.point) {
                        console.log(steps.value)
                        
                    }
                }
            }
        } catch (e) {
            console.log(e)
        }
            
            const steps = 
        
        res.render('index', { title: 'Steps', steps: stepArray })
          
        // res.sendFile(path.resolve(__dirname, 'static', 'steps.html'))
    
    })
    
    
    
    
    app.listen(port, () => console.log('GFit ready to running on port: 1234'))
  • Как отобразить данные на странице из API?

    @noskiddie Автор вопроса
    Алексей, Спасибо. Правда теперь он отображает его как Object Object, как правильно отобразить их из массива stepsArray в pug?