From 4fbd8a17073a8dfb9f0600dbf0963067554a4463 Mon Sep 17 00:00:00 2001 From: Ivan Date: Sun, 17 Sep 2023 15:22:14 +0300 Subject: [PATCH] export and playback update --- server.js | 89 +++++-- static/styles/main.css | 63 ++++- static/templates/videos/export.html | 345 +++++++++++++++++++------- static/templates/videos/playback.html | 236 +++++++++++------- 4 files changed, 532 insertions(+), 201 deletions(-) diff --git a/server.js b/server.js index 2c5473b..341472d 100644 --- a/server.js +++ b/server.js @@ -172,17 +172,17 @@ conn.on('error', function(err) { }); -// const DB_User = process.env.DB_USER; -// const DB_Password = process.env.DB_PASSWORD; -// const DB_Host = process.env.DB_HOST; -// const DB_Port = process.env.DB_PORT; -// const DB_Name = process.env.DB_NAME; +const DB_User = process.env.DB_USER; +const DB_Password = process.env.DB_PASSWORD; +const DB_Host = process.env.DB_HOST; +const DB_Port = process.env.DB_PORT; +const DB_Name = process.env.DB_NAME; -const DB_User = "postgres"; -const DB_Password = process.env.POSTGRES_PASSWORD; -const DB_Host = "postgres"; -const DB_Port = "5432"; -const DB_Name = "postgres"; +// const DB_User = "postgres"; +// const DB_Password = process.env.POSTGRES_PASSWORD; +// const DB_Host = "postgres"; +// const DB_Port = "5432"; +// const DB_Name = "postgres"; async function index(req, res) { if (req.session.userId === undefined) { @@ -3283,7 +3283,7 @@ app.get('/getData', async (req, res) => { try { const successResponse = await axios.get(`http://krbl.ru:8080/http/filelist/request?serial=${selectedSerial}&querytime=${selectedDate}&channel=${selectedChannel}`); if (successResponse.data.SUCCESS) { - await new Promise(resolve => setTimeout(resolve, 5000)); + await new Promise(resolve => setTimeout(resolve, 7000)); const dataResponse = await axios.get(`http://krbl.ru:8080/http/filelist/get?serial=${selectedSerial}&querytime=${selectedDate}&channel=${selectedChannel}`); if (successResponse.data.SUCCESS) { const dataId = dataResponse.data.DATAID; @@ -3356,12 +3356,14 @@ app.post("/getspeedarchive", async (req, res) => { port: DB_Port, }); const client = await pool.connect(); - const sqlQuery = ` - SELECT speed, latitude, longitude + + // Запрос для получения первой и последней временных отметок + const timeRangeQuery = ` + SELECT MIN(time) as min_time, MAX(time) as max_time FROM geo WHERE serial = $1 AND time >= $2 - AND time < $3; + AND time <= $3; `; const startTime = new Date(formattedDateTime); @@ -3369,29 +3371,64 @@ app.post("/getspeedarchive", async (req, res) => { const endTime = new Date(startTime); endTime.setHours(endTime.getHours() + 1); - pool.query(sqlQuery, [serial, startTime, endTime], (error, results) => { + // Первый запрос для получения временных отметок + pool.query(timeRangeQuery, [serial, startTime, endTime], (error, timeResults) => { if (error) { console.error("Ошибка при выполнении SQL-запроса:", error); res.status(500).json({ error: "Ошибка на сервере" }); } else { - const speeds = results.rows.map((row) => row.speed); - const transformedSpeeds = speeds.map((speed) => { - if (speed > 150) { - return speed / 100; + const { min_time, max_time } = timeResults.rows[0]; + + // Запрос для получения данных скорости и геолокации + const sqlQuery = ` + SELECT speed, latitude, longitude, time + FROM geo + WHERE serial = $1 + AND time >= $2 + AND time <= $3; + `; + + pool.query(sqlQuery, [serial, startTime, endTime], (error, results) => { + if (error) { + console.error("Ошибка при выполнении SQL-запроса:", error); + res.status(500).json({ error: "Ошибка на сервере" }); } else { - return speed; + const data = results.rows.map((row) => ({ + speed: row.speed > 150 ? row.speed / 100 : row.speed, + geo: { + latitude: row.latitude, + longitude: row.longitude, + }, + time: row.time.toLocaleTimeString("ru-RU", { + hour: "2-digit", + minute: "2-digit", + hour12: false, + }), + })); + + // Функция для сравнения времени в формате "час:минута" + function compareTime(a, b) { + return new Date('1970-01-01 ' + a.time) - new Date('1970-01-01 ' + b.time); + } + + // Сортируем массив данных + data.sort(compareTime); + + // Разделяем отсортированный массив обратно на отдельные массивы + const transformedSpeeds = data.map((item) => item.speed); + const geoData = data.map((item) => item.geo); + const names = data.map((item) => item.time); + + res.json({ speeds: transformedSpeeds, geo: geoData, names }); } }); - - const geoData = results.rows.map((row) => ({ - latitude: row.latitude, - longitude: row.longitude, - })); - res.json({ speeds: transformedSpeeds, geo: geoData }); } }); }); + + + const port = 8081; app.listen(port, () => { console.log(`Server is running on port ${port}`); diff --git a/static/styles/main.css b/static/styles/main.css index 8847da1..de68c78 100644 --- a/static/styles/main.css +++ b/static/styles/main.css @@ -325,9 +325,9 @@ header h2 span { } .whole-width h1 { - font-weight: 500; - font-size: 30px; - margin: 35px 0 0 44px; + font-weight: 500 !important; + font-size: 30px !important; + margin: 35px 0 0 44px !important; } .whole-width h3 { @@ -355,6 +355,15 @@ header h2 span { margin-bottom: 25px; } +.loader-container { + width: fit-content; + height: fit-content; + padding: 50px; + padding-bottom: 25px; + border-radius: 10px; + background: white; +} + .square { background: #8086F9; width: 10px; @@ -415,6 +424,54 @@ header h2 span { animation: loader_5191 675ms ease-in-out 600ms infinite; } +#sq11 { + margin-top: -25px; + margin-left: -25px; + animation: loader_5191 675ms ease-in-out 0s infinite alternate; +} + +#sq12 { + margin-top: -25px; + animation: loader_5191 675ms ease-in-out 75ms infinite alternate; +} + +#sq13 { + margin-top: -25px; + margin-left: 15px; + animation: loader_5191 675ms ease-in-out 150ms infinite; +} + +#sq14 { + margin-left: -25px; + animation: loader_5191 675ms ease-in-out 225ms infinite; +} + +#sq15 { + animation: loader_5191 675ms ease-in-out 300ms infinite; +} + +#sq16 { + margin-left: 15px; + animation: loader_5191 675ms ease-in-out 375ms infinite; +} + +#sq17 { + margin-top: 15px; + margin-left: -25px; + animation: loader_5191 675ms ease-in-out 450ms infinite; +} + +#sq18 { + margin-top: 15px; + animation: loader_5191 675ms ease-in-out 525ms infinite; +} + +#sq19 { + margin-top: 15px; + margin-left: 15px; + animation: loader_5191 675ms ease-in-out 600ms infinite; +} + .content .organisation { width: 250px; diff --git a/static/templates/videos/export.html b/static/templates/videos/export.html index 263ff7f..305f6dc 100644 --- a/static/templates/videos/export.html +++ b/static/templates/videos/export.html @@ -60,6 +60,7 @@
+ + {{#if ifDBError}}
@@ -106,6 +124,7 @@ {{#each devices}}
  • +