diff --git a/.gitignore b/.gitignore index 485ffa8..65da70e 100644 --- a/.gitignore +++ b/.gitignore @@ -33,6 +33,10 @@ node_modules # Env .env +.env.* .fake -.ionide \ No newline at end of file +.ionide + +# api-mock +/api-mock/endpoints/ \ No newline at end of file diff --git a/api-mock/fetchEndpoints.js b/api-mock/fetchEndpoints.js new file mode 100644 index 0000000..bc2cdf8 --- /dev/null +++ b/api-mock/fetchEndpoints.js @@ -0,0 +1,33 @@ +import { existsSync } from 'fs'; +import { mkdir, writeFile } from 'fs/promises'; + +async function fetchJSONEndpointData(url, fileName) { + try { + const res = await fetch(url); + const data = await res.json(); + await writeFile(`./endpoints/${fileName}`, JSON.stringify(data)); + + return true; + } catch (error) { + console.error(error); + } + + return false; +} + +async function main() { + if (!existsSync('endpoints')) await mkdir('endpoints'); + + Promise.all( + ['getActiveData', 'getDonators', 'getSceneries', 'getVehicles'].map((endpointName) => + fetchJSONEndpointData( + `https://stacjownik.spythere.eu/api/${endpointName}`, + `${endpointName}.json` + ) + ) + ).then(() => { + console.log('Endpoints downloaded!'); + }); +} + +main(); diff --git a/api-mock/index.js b/api-mock/index.js new file mode 100644 index 0000000..167ff96 --- /dev/null +++ b/api-mock/index.js @@ -0,0 +1,28 @@ +import express from 'express'; +import path from 'path'; +import { cwd } from 'process'; +import cors from 'cors'; + +const app = express(); + +app.use(cors()); + +app.get('/api/getActiveData', (_, res) => { + res.sendFile(path.join(cwd(), 'endpoints', 'getActiveData.json')); +}); + +app.get('/api/getSceneries', (_, res) => { + res.sendFile(path.join(cwd(), 'endpoints', 'getSceneries.json')); +}); + +app.get('/api/getVehicles', (_, res) => { + res.sendFile(path.join(cwd(), 'endpoints', 'getVehicles.json')); +}); + +app.get('/api/getDonators', (_, res) => { + res.sendFile(path.join(cwd(), 'endpoints', 'getDonators.json')); +}); + +app.listen(3123, () => { + console.log('Mocking API server...'); +}); diff --git a/api-mock/package.json b/api-mock/package.json new file mode 100644 index 0000000..3b0b3c1 --- /dev/null +++ b/api-mock/package.json @@ -0,0 +1,18 @@ +{ + "name": "api-mock", + "version": "1.0.0", + "description": "", + "type": "module", + "main": "index.js", + "scripts": { + "test": "echo \"Error: no test specified\" && exit 1", + "start": "node index.js", + "fetch": "node fetchEndpoints.js" + }, + "author": "", + "license": "ISC", + "dependencies": { + "cors": "^2.8.5", + "express": "^4.18.3" + } +} diff --git a/api-mock/yarn.lock b/api-mock/yarn.lock new file mode 100644 index 0000000..244de18 --- /dev/null +++ b/api-mock/yarn.lock @@ -0,0 +1,481 @@ +# THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY. +# yarn lockfile v1 + + +accepts@~1.3.8: + version "1.3.8" + resolved "https://registry.yarnpkg.com/accepts/-/accepts-1.3.8.tgz#0bf0be125b67014adcb0b0921e62db7bffe16b2e" + integrity sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw== + dependencies: + mime-types "~2.1.34" + negotiator "0.6.3" + +array-flatten@1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/array-flatten/-/array-flatten-1.1.1.tgz#9a5f699051b1e7073328f2a008968b64ea2955d2" + integrity sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg== + +body-parser@1.20.3: + version "1.20.3" + resolved "https://registry.yarnpkg.com/body-parser/-/body-parser-1.20.3.tgz#1953431221c6fb5cd63c4b36d53fab0928e548c6" + integrity sha512-7rAxByjUMqQ3/bHJy7D6OGXvx/MMc4IqBn/X0fcM1QUcAItpZrBEYhWGem+tzXH90c+G01ypMcYJBO9Y30203g== + dependencies: + bytes "3.1.2" + content-type "~1.0.5" + debug "2.6.9" + depd "2.0.0" + destroy "1.2.0" + http-errors "2.0.0" + iconv-lite "0.4.24" + on-finished "2.4.1" + qs "6.13.0" + raw-body "2.5.2" + type-is "~1.6.18" + unpipe "1.0.0" + +bytes@3.1.2: + version "3.1.2" + resolved "https://registry.yarnpkg.com/bytes/-/bytes-3.1.2.tgz#8b0beeb98605adf1b128fa4386403c009e0221a5" + integrity sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg== + +call-bind@^1.0.7: + version "1.0.7" + resolved "https://registry.yarnpkg.com/call-bind/-/call-bind-1.0.7.tgz#06016599c40c56498c18769d2730be242b6fa3b9" + integrity sha512-GHTSNSYICQ7scH7sZ+M2rFopRoLh8t2bLSW6BbgrtLsahOIB5iyAVJf9GjWK3cYTDaMj4XdBpM1cA6pIS0Kv2w== + dependencies: + es-define-property "^1.0.0" + es-errors "^1.3.0" + function-bind "^1.1.2" + get-intrinsic "^1.2.4" + set-function-length "^1.2.1" + +content-disposition@0.5.4: + version "0.5.4" + resolved "https://registry.yarnpkg.com/content-disposition/-/content-disposition-0.5.4.tgz#8b82b4efac82512a02bb0b1dcec9d2c5e8eb5bfe" + integrity sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ== + dependencies: + safe-buffer "5.2.1" + +content-type@~1.0.4, content-type@~1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/content-type/-/content-type-1.0.5.tgz#8b773162656d1d1086784c8f23a54ce6d73d7918" + integrity sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA== + +cookie-signature@1.0.6: + version "1.0.6" + resolved "https://registry.yarnpkg.com/cookie-signature/-/cookie-signature-1.0.6.tgz#e303a882b342cc3ee8ca513a79999734dab3ae2c" + integrity sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ== + +cookie@0.6.0: + version "0.6.0" + resolved "https://registry.yarnpkg.com/cookie/-/cookie-0.6.0.tgz#2798b04b071b0ecbff0dbb62a505a8efa4e19051" + integrity sha512-U71cyTamuh1CRNCfpGY6to28lxvNwPG4Guz/EVjgf3Jmzv0vlDp1atT9eS5dDjMYHucpHbWns6Lwf3BKz6svdw== + +cors@^2.8.5: + version "2.8.5" + resolved "https://registry.yarnpkg.com/cors/-/cors-2.8.5.tgz#eac11da51592dd86b9f06f6e7ac293b3df875d29" + integrity sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g== + dependencies: + object-assign "^4" + vary "^1" + +debug@2.6.9: + version "2.6.9" + resolved "https://registry.yarnpkg.com/debug/-/debug-2.6.9.tgz#5d128515df134ff327e90a4c93f4e077a536341f" + integrity sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA== + dependencies: + ms "2.0.0" + +define-data-property@^1.1.4: + version "1.1.4" + resolved "https://registry.yarnpkg.com/define-data-property/-/define-data-property-1.1.4.tgz#894dc141bb7d3060ae4366f6a0107e68fbe48c5e" + integrity sha512-rBMvIzlpA8v6E+SJZoo++HAYqsLrkg7MSfIinMPFhmkorw7X+dOXVJQs+QT69zGkzMyfDnIMN2Wid1+NbL3T+A== + dependencies: + es-define-property "^1.0.0" + es-errors "^1.3.0" + gopd "^1.0.1" + +depd@2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/depd/-/depd-2.0.0.tgz#b696163cc757560d09cf22cc8fad1571b79e76df" + integrity sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw== + +destroy@1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/destroy/-/destroy-1.2.0.tgz#4803735509ad8be552934c67df614f94e66fa015" + integrity sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg== + +ee-first@1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/ee-first/-/ee-first-1.1.1.tgz#590c61156b0ae2f4f0255732a158b266bc56b21d" + integrity sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow== + +encodeurl@~1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/encodeurl/-/encodeurl-1.0.2.tgz#ad3ff4c86ec2d029322f5a02c3a9a606c95b3f59" + integrity sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w== + +encodeurl@~2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/encodeurl/-/encodeurl-2.0.0.tgz#7b8ea898077d7e409d3ac45474ea38eaf0857a58" + integrity sha512-Q0n9HRi4m6JuGIV1eFlmvJB7ZEVxu93IrMyiMsGC0lrMJMWzRgx6WGquyfQgZVb31vhGgXnfmPNNXmxnOkRBrg== + +es-define-property@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/es-define-property/-/es-define-property-1.0.0.tgz#c7faefbdff8b2696cf5f46921edfb77cc4ba3845" + integrity sha512-jxayLKShrEqqzJ0eumQbVhTYQM27CfT1T35+gCgDFoL82JLsXqTJ76zv6A0YLOgEnLUMvLzsDsGIrl8NFpT2gQ== + dependencies: + get-intrinsic "^1.2.4" + +es-errors@^1.3.0: + version "1.3.0" + resolved "https://registry.yarnpkg.com/es-errors/-/es-errors-1.3.0.tgz#05f75a25dab98e4fb1dcd5e1472c0546d5057c8f" + integrity sha512-Zf5H2Kxt2xjTvbJvP2ZWLEICxA6j+hAmMzIlypy4xcBg1vKVnx89Wy0GbS+kf5cwCVFFzdCFh2XSCFNULS6csw== + +escape-html@~1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/escape-html/-/escape-html-1.0.3.tgz#0258eae4d3d0c0974de1c169188ef0051d1d1988" + integrity sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow== + +etag@~1.8.1: + version "1.8.1" + resolved "https://registry.yarnpkg.com/etag/-/etag-1.8.1.tgz#41ae2eeb65efa62268aebfea83ac7d79299b0887" + integrity sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg== + +express@^4.18.3: + version "4.21.0" + resolved "https://registry.yarnpkg.com/express/-/express-4.21.0.tgz#d57cb706d49623d4ac27833f1cbc466b668eb915" + integrity sha512-VqcNGcj/Id5ZT1LZ/cfihi3ttTn+NJmkli2eZADigjq29qTlWi/hAQ43t/VLPq8+UX06FCEx3ByOYet6ZFblng== + dependencies: + accepts "~1.3.8" + array-flatten "1.1.1" + body-parser "1.20.3" + content-disposition "0.5.4" + content-type "~1.0.4" + cookie "0.6.0" + cookie-signature "1.0.6" + debug "2.6.9" + depd "2.0.0" + encodeurl "~2.0.0" + escape-html "~1.0.3" + etag "~1.8.1" + finalhandler "1.3.1" + fresh "0.5.2" + http-errors "2.0.0" + merge-descriptors "1.0.3" + methods "~1.1.2" + on-finished "2.4.1" + parseurl "~1.3.3" + path-to-regexp "0.1.10" + proxy-addr "~2.0.7" + qs "6.13.0" + range-parser "~1.2.1" + safe-buffer "5.2.1" + send "0.19.0" + serve-static "1.16.2" + setprototypeof "1.2.0" + statuses "2.0.1" + type-is "~1.6.18" + utils-merge "1.0.1" + vary "~1.1.2" + +finalhandler@1.3.1: + version "1.3.1" + resolved "https://registry.yarnpkg.com/finalhandler/-/finalhandler-1.3.1.tgz#0c575f1d1d324ddd1da35ad7ece3df7d19088019" + integrity sha512-6BN9trH7bp3qvnrRyzsBz+g3lZxTNZTbVO2EV1CS0WIcDbawYVdYvGflME/9QP0h0pYlCDBCTjYa9nZzMDpyxQ== + dependencies: + debug "2.6.9" + encodeurl "~2.0.0" + escape-html "~1.0.3" + on-finished "2.4.1" + parseurl "~1.3.3" + statuses "2.0.1" + unpipe "~1.0.0" + +forwarded@0.2.0: + version "0.2.0" + resolved "https://registry.yarnpkg.com/forwarded/-/forwarded-0.2.0.tgz#2269936428aad4c15c7ebe9779a84bf0b2a81811" + integrity sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow== + +fresh@0.5.2: + version "0.5.2" + resolved "https://registry.yarnpkg.com/fresh/-/fresh-0.5.2.tgz#3d8cadd90d976569fa835ab1f8e4b23a105605a7" + integrity sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q== + +function-bind@^1.1.2: + version "1.1.2" + resolved "https://registry.yarnpkg.com/function-bind/-/function-bind-1.1.2.tgz#2c02d864d97f3ea6c8830c464cbd11ab6eab7a1c" + integrity sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA== + +get-intrinsic@^1.1.3, get-intrinsic@^1.2.4: + version "1.2.4" + resolved "https://registry.yarnpkg.com/get-intrinsic/-/get-intrinsic-1.2.4.tgz#e385f5a4b5227d449c3eabbad05494ef0abbeadd" + integrity sha512-5uYhsJH8VJBTv7oslg4BznJYhDoRI6waYCxMmCdnTrcCrHA/fCFKoTFz2JKKE0HdDFUF7/oQuhzumXJK7paBRQ== + dependencies: + es-errors "^1.3.0" + function-bind "^1.1.2" + has-proto "^1.0.1" + has-symbols "^1.0.3" + hasown "^2.0.0" + +gopd@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/gopd/-/gopd-1.0.1.tgz#29ff76de69dac7489b7c0918a5788e56477c332c" + integrity sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA== + dependencies: + get-intrinsic "^1.1.3" + +has-property-descriptors@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/has-property-descriptors/-/has-property-descriptors-1.0.2.tgz#963ed7d071dc7bf5f084c5bfbe0d1b6222586854" + integrity sha512-55JNKuIW+vq4Ke1BjOTjM2YctQIvCT7GFzHwmfZPGo5wnrgkid0YQtnAleFSqumZm4az3n2BS+erby5ipJdgrg== + dependencies: + es-define-property "^1.0.0" + +has-proto@^1.0.1: + version "1.0.3" + resolved "https://registry.yarnpkg.com/has-proto/-/has-proto-1.0.3.tgz#b31ddfe9b0e6e9914536a6ab286426d0214f77fd" + integrity sha512-SJ1amZAJUiZS+PhsVLf5tGydlaVB8EdFpaSO4gmiUKUOxk8qzn5AIy4ZeJUmh22znIdk/uMAUT2pl3FxzVUH+Q== + +has-symbols@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/has-symbols/-/has-symbols-1.0.3.tgz#bb7b2c4349251dce87b125f7bdf874aa7c8b39f8" + integrity sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A== + +hasown@^2.0.0: + version "2.0.2" + resolved "https://registry.yarnpkg.com/hasown/-/hasown-2.0.2.tgz#003eaf91be7adc372e84ec59dc37252cedb80003" + integrity sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ== + dependencies: + function-bind "^1.1.2" + +http-errors@2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/http-errors/-/http-errors-2.0.0.tgz#b7774a1486ef73cf7667ac9ae0858c012c57b9d3" + integrity sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ== + dependencies: + depd "2.0.0" + inherits "2.0.4" + setprototypeof "1.2.0" + statuses "2.0.1" + toidentifier "1.0.1" + +iconv-lite@0.4.24: + version "0.4.24" + resolved "https://registry.yarnpkg.com/iconv-lite/-/iconv-lite-0.4.24.tgz#2022b4b25fbddc21d2f524974a474aafe733908b" + integrity sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA== + dependencies: + safer-buffer ">= 2.1.2 < 3" + +inherits@2.0.4: + version "2.0.4" + resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.4.tgz#0fa2c64f932917c3433a0ded55363aae37416b7c" + integrity sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ== + +ipaddr.js@1.9.1: + version "1.9.1" + resolved "https://registry.yarnpkg.com/ipaddr.js/-/ipaddr.js-1.9.1.tgz#bff38543eeb8984825079ff3a2a8e6cbd46781b3" + integrity sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g== + +media-typer@0.3.0: + version "0.3.0" + resolved "https://registry.yarnpkg.com/media-typer/-/media-typer-0.3.0.tgz#8710d7af0aa626f8fffa1ce00168545263255748" + integrity sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ== + +merge-descriptors@1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/merge-descriptors/-/merge-descriptors-1.0.3.tgz#d80319a65f3c7935351e5cfdac8f9318504dbed5" + integrity sha512-gaNvAS7TZ897/rVaZ0nMtAyxNyi/pdbjbAwUpFQpN70GqnVfOiXpeUUMKRBmzXaSQ8DdTX4/0ms62r2K+hE6mQ== + +methods@~1.1.2: + version "1.1.2" + resolved "https://registry.yarnpkg.com/methods/-/methods-1.1.2.tgz#5529a4d67654134edcc5266656835b0f851afcee" + integrity sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w== + +mime-db@1.52.0: + version "1.52.0" + resolved "https://registry.yarnpkg.com/mime-db/-/mime-db-1.52.0.tgz#bbabcdc02859f4987301c856e3387ce5ec43bf70" + integrity sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg== + +mime-types@~2.1.24, mime-types@~2.1.34: + version "2.1.35" + resolved "https://registry.yarnpkg.com/mime-types/-/mime-types-2.1.35.tgz#381a871b62a734450660ae3deee44813f70d959a" + integrity sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw== + dependencies: + mime-db "1.52.0" + +mime@1.6.0: + version "1.6.0" + resolved "https://registry.yarnpkg.com/mime/-/mime-1.6.0.tgz#32cd9e5c64553bd58d19a568af452acff04981b1" + integrity sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg== + +ms@2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/ms/-/ms-2.0.0.tgz#5608aeadfc00be6c2901df5f9861788de0d597c8" + integrity sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A== + +ms@2.1.3: + version "2.1.3" + resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.3.tgz#574c8138ce1d2b5861f0b44579dbadd60c6615b2" + integrity sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA== + +negotiator@0.6.3: + version "0.6.3" + resolved "https://registry.yarnpkg.com/negotiator/-/negotiator-0.6.3.tgz#58e323a72fedc0d6f9cd4d31fe49f51479590ccd" + integrity sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg== + +object-assign@^4: + version "4.1.1" + resolved "https://registry.yarnpkg.com/object-assign/-/object-assign-4.1.1.tgz#2109adc7965887cfc05cbbd442cac8bfbb360863" + integrity sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg== + +object-inspect@^1.13.1: + version "1.13.2" + resolved "https://registry.yarnpkg.com/object-inspect/-/object-inspect-1.13.2.tgz#dea0088467fb991e67af4058147a24824a3043ff" + integrity sha512-IRZSRuzJiynemAXPYtPe5BoI/RESNYR7TYm50MC5Mqbd3Jmw5y790sErYw3V6SryFJD64b74qQQs9wn5Bg/k3g== + +on-finished@2.4.1: + version "2.4.1" + resolved "https://registry.yarnpkg.com/on-finished/-/on-finished-2.4.1.tgz#58c8c44116e54845ad57f14ab10b03533184ac3f" + integrity sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg== + dependencies: + ee-first "1.1.1" + +parseurl@~1.3.3: + version "1.3.3" + resolved "https://registry.yarnpkg.com/parseurl/-/parseurl-1.3.3.tgz#9da19e7bee8d12dff0513ed5b76957793bc2e8d4" + integrity sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ== + +path-to-regexp@0.1.10: + version "0.1.10" + resolved "https://registry.yarnpkg.com/path-to-regexp/-/path-to-regexp-0.1.10.tgz#67e9108c5c0551b9e5326064387de4763c4d5f8b" + integrity sha512-7lf7qcQidTku0Gu3YDPc8DJ1q7OOucfa/BSsIwjuh56VU7katFvuM8hULfkwB3Fns/rsVF7PwPKVw1sl5KQS9w== + +proxy-addr@~2.0.7: + version "2.0.7" + resolved "https://registry.yarnpkg.com/proxy-addr/-/proxy-addr-2.0.7.tgz#f19fe69ceab311eeb94b42e70e8c2070f9ba1025" + integrity sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg== + dependencies: + forwarded "0.2.0" + ipaddr.js "1.9.1" + +qs@6.13.0: + version "6.13.0" + resolved "https://registry.yarnpkg.com/qs/-/qs-6.13.0.tgz#6ca3bd58439f7e245655798997787b0d88a51906" + integrity sha512-+38qI9SOr8tfZ4QmJNplMUxqjbe7LKvvZgWdExBOmd+egZTtjLB67Gu0HRX3u/XOq7UU2Nx6nsjvS16Z9uwfpg== + dependencies: + side-channel "^1.0.6" + +range-parser@~1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/range-parser/-/range-parser-1.2.1.tgz#3cf37023d199e1c24d1a55b84800c2f3e6468031" + integrity sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg== + +raw-body@2.5.2: + version "2.5.2" + resolved "https://registry.yarnpkg.com/raw-body/-/raw-body-2.5.2.tgz#99febd83b90e08975087e8f1f9419a149366b68a" + integrity sha512-8zGqypfENjCIqGhgXToC8aB2r7YrBX+AQAfIPs/Mlk+BtPTztOvTS01NRW/3Eh60J+a48lt8qsCzirQ6loCVfA== + dependencies: + bytes "3.1.2" + http-errors "2.0.0" + iconv-lite "0.4.24" + unpipe "1.0.0" + +safe-buffer@5.2.1: + version "5.2.1" + resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.2.1.tgz#1eaf9fa9bdb1fdd4ec75f58f9cdb4e6b7827eec6" + integrity sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ== + +"safer-buffer@>= 2.1.2 < 3": + version "2.1.2" + resolved "https://registry.yarnpkg.com/safer-buffer/-/safer-buffer-2.1.2.tgz#44fa161b0187b9549dd84bb91802f9bd8385cd6a" + integrity sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg== + +send@0.19.0: + version "0.19.0" + resolved "https://registry.yarnpkg.com/send/-/send-0.19.0.tgz#bbc5a388c8ea6c048967049dbeac0e4a3f09d7f8" + integrity sha512-dW41u5VfLXu8SJh5bwRmyYUbAoSB3c9uQh6L8h/KtsFREPWpbX1lrljJo186Jc4nmci/sGUZ9a0a0J2zgfq2hw== + dependencies: + debug "2.6.9" + depd "2.0.0" + destroy "1.2.0" + encodeurl "~1.0.2" + escape-html "~1.0.3" + etag "~1.8.1" + fresh "0.5.2" + http-errors "2.0.0" + mime "1.6.0" + ms "2.1.3" + on-finished "2.4.1" + range-parser "~1.2.1" + statuses "2.0.1" + +serve-static@1.16.2: + version "1.16.2" + resolved "https://registry.yarnpkg.com/serve-static/-/serve-static-1.16.2.tgz#b6a5343da47f6bdd2673848bf45754941e803296" + integrity sha512-VqpjJZKadQB/PEbEwvFdO43Ax5dFBZ2UECszz8bQ7pi7wt//PWe1P6MN7eCnjsatYtBT6EuiClbjSWP2WrIoTw== + dependencies: + encodeurl "~2.0.0" + escape-html "~1.0.3" + parseurl "~1.3.3" + send "0.19.0" + +set-function-length@^1.2.1: + version "1.2.2" + resolved "https://registry.yarnpkg.com/set-function-length/-/set-function-length-1.2.2.tgz#aac72314198eaed975cf77b2c3b6b880695e5449" + integrity sha512-pgRc4hJ4/sNjWCSS9AmnS40x3bNMDTknHgL5UaMBTMyJnU90EgWh1Rz+MC9eFu4BuN/UwZjKQuY/1v3rM7HMfg== + dependencies: + define-data-property "^1.1.4" + es-errors "^1.3.0" + function-bind "^1.1.2" + get-intrinsic "^1.2.4" + gopd "^1.0.1" + has-property-descriptors "^1.0.2" + +setprototypeof@1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/setprototypeof/-/setprototypeof-1.2.0.tgz#66c9a24a73f9fc28cbe66b09fed3d33dcaf1b424" + integrity sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw== + +side-channel@^1.0.6: + version "1.0.6" + resolved "https://registry.yarnpkg.com/side-channel/-/side-channel-1.0.6.tgz#abd25fb7cd24baf45466406b1096b7831c9215f2" + integrity sha512-fDW/EZ6Q9RiO8eFG8Hj+7u/oW+XrPTIChwCOM2+th2A6OblDtYYIpve9m+KvI9Z4C9qSEXlaGR6bTEYHReuglA== + dependencies: + call-bind "^1.0.7" + es-errors "^1.3.0" + get-intrinsic "^1.2.4" + object-inspect "^1.13.1" + +statuses@2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/statuses/-/statuses-2.0.1.tgz#55cb000ccf1d48728bd23c685a063998cf1a1b63" + integrity sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ== + +toidentifier@1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/toidentifier/-/toidentifier-1.0.1.tgz#3be34321a88a820ed1bd80dfaa33e479fbb8dd35" + integrity sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA== + +type-is@~1.6.18: + version "1.6.18" + resolved "https://registry.yarnpkg.com/type-is/-/type-is-1.6.18.tgz#4e552cd05df09467dcbc4ef739de89f2cf37c131" + integrity sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g== + dependencies: + media-typer "0.3.0" + mime-types "~2.1.24" + +unpipe@1.0.0, unpipe@~1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/unpipe/-/unpipe-1.0.0.tgz#b2bf4ee8514aae6165b4817829d21b2ef49904ec" + integrity sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ== + +utils-merge@1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/utils-merge/-/utils-merge-1.0.1.tgz#9f95710f50a267947b2ccc124741c1028427e713" + integrity sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA== + +vary@^1, vary@~1.1.2: + version "1.1.2" + resolved "https://registry.yarnpkg.com/vary/-/vary-1.1.2.tgz#2299f02c6ded30d4a5961b0b9f74524a18f634fc" + integrity sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg== diff --git a/package.json b/package.json index cd67176..582102e 100644 --- a/package.json +++ b/package.json @@ -1,10 +1,12 @@ { "name": "stacjownik", - "version": "1.28.1", + "version": "1.28.2", "private": true, "type": "module", "scripts": { - "dev": "vite", + "dev": "vite --mode staging", + "dev:mock": "vite --mode development & yarn --cwd ./api-mock start", + "dev:fetch": "yarn --cwd ./api-mock fetch", "build": "vue-tsc --noEmit && vite build", "deploy:prod": "yarn build && firebase deploy --only hosting", "deploy:dev": "yarn build && firebase hosting:channel:deploy dev --expires 7d", diff --git a/src/components/JournalView/JournalDispatchers/JournalDispatchersList.vue b/src/components/JournalView/JournalDispatchers/JournalDispatchersList.vue index 91942e0..979a407 100644 --- a/src/components/JournalView/JournalDispatchers/JournalDispatchersList.vue +++ b/src/components/JournalView/JournalDispatchers/JournalDispatchersList.vue @@ -1,43 +1,45 @@ @@ -81,6 +83,15 @@ export default defineComponent({ }; }, + watch: { + '$route.query': { + deep: true, + handler() { + this.extraInfoIndexes.length = 0; + } + } + }, + methods: { toggleExtraInfo(id: number) { const existingIdx = this.extraInfoIndexes.indexOf(id); diff --git a/src/components/JournalView/JournalTimetables/EntryDetails.vue b/src/components/JournalView/JournalTimetables/EntryDetails.vue index 6983ce2..81c3cdf 100644 --- a/src/components/JournalView/JournalTimetables/EntryDetails.vue +++ b/src/components/JournalView/JournalTimetables/EntryDetails.vue @@ -66,19 +66,28 @@ + +
+

{{ $t('warnings.header-title') }}

+

+ {{ timetable.warningNotes }} +

+
@@ -234,6 +243,19 @@ hr { list-style: disc; padding-left: 1em; padding-top: 0.5em; + white-space: pre-wrap; +} + +.dangers-notes { + margin-top: 0.5em; + white-space: pre-wrap; + + p { + margin-top: 0.25em; + max-height: 200px; + max-width: 500px; + overflow: auto; + } } @include smallScreen() { diff --git a/src/components/JournalView/JournalTimetables/EntryGeneral.vue b/src/components/JournalView/JournalTimetables/EntryGeneral.vue index 3c21cf9..7c7254c 100644 --- a/src/components/JournalView/JournalTimetables/EntryGeneral.vue +++ b/src/components/JournalView/JournalTimetables/EntryGeneral.vue @@ -7,21 +7,38 @@ class="train-badge twr" v-if="timetable.twr" data-tooltip-type="BaseTooltip" - :data-tooltip-content=" - $t('general.TWR') + `${timetable.warningNotes ? ':\n' + timetable.warningNotes : ''}` - " + :data-tooltip-content="$t('warnings.TWR')" > TWR + SKR + + TN + + + + PN + + TWR - SKR + TN + + + + PN {{ train.timetableData.category }} + {{ train.trainNo }} +
@@ -142,15 +153,30 @@
-
- TWR - {{ $t('general.TWR') }} - ({{ train.timetableData?.warningNotes }}) +
+
+
TWR
+ - {{ $t('warnings.TWR') }} +
+ +
+
TN
+ - {{ $t('warnings.TN') }} +
+ +
+
PN
+ - {{ $t('warnings.PN') }} +
-
- SKR - {{ $t('general.SKR') }} +
+

{{ $t('warnings.header-title') }}

+

+ {{ train.timetableData?.warningNotes }} +

@@ -254,6 +280,24 @@ export default defineComponent({ margin-top: 0.5em; } +.dangers-badges { + display: flex; + flex-direction: column; + gap: 0.5em; +} + +.dangers-notes { + margin-top: 0.5em; + white-space: pre-wrap; + + p { + margin-top: 0.25em; + max-height: 200px; + max-width: 500px; + overflow: auto; + } +} + .train-info { display: grid; grid-template-columns: 2fr 1fr; diff --git a/src/components/TrainsView/typings.ts b/src/components/TrainsView/typings.ts index 865bb76..30de2b4 100644 --- a/src/components/TrainsView/typings.ts +++ b/src/components/TrainsView/typings.ts @@ -12,12 +12,14 @@ export const enum TrainFilterId { withComments = 'withComments', twr = 'twr', - skr = 'skr', + tn = 'tn', + pn = 'pn', common = 'common', passenger = 'passenger', freight = 'freight', other = 'other', + noTimetable = 'noTimetable', withTimetable = 'withTimetable' } @@ -40,7 +42,12 @@ export const trainFilters: TrainFilter[] = [ isActive: true }, { - id: TrainFilterId.skr, + id: TrainFilterId.tn, + section: TrainFilterSection.TRAIN_TYPE, + isActive: true + }, + { + id: TrainFilterId.pn, section: TrainFilterSection.TRAIN_TYPE, isActive: true }, diff --git a/src/locales/en.json b/src/locales/en.json index 8b646d3..efd54f6 100644 --- a/src/locales/en.json +++ b/src/locales/en.json @@ -20,11 +20,16 @@ "dispatcher-message": "Dispatcher supporting the Stacjownik project!", "driver-message": "Driver supporting the Stacjownik project!" }, + "warnings": { + "TWR": "Train with high risk cargo", + "SKR": "Train with exceeded gauge", + "PN": "Train with extra deliveries", + "TN": "Train with dangerous cargo", + "header-title": "Freight notes:" + }, "general": { "and": " and ", - "refresh": "REFRESH", - "TWR": "High risk freight train", - "SKR": "Train with exceeded gauge" + "refresh": "REFRESH" }, "update": { "title": "Stacjownik update!", @@ -188,15 +193,17 @@ "sort-beginDate": "date", "sort-timetableId": "timetable ID", "sort-timestampFrom": "date", - "sort-duration": "duration", + "sort-currentDuration": "duration", "filter-noComments": "NO COMMENTS", "filter-withComments": "COMMENTS", - "filter-twr": "HIGH RISK CARGO", - "filter-skr": "EXCEEDED GAUGE", + "filter-twr": "TWR", + "filter-skr": "SKR", + "filter-tn": "TN", + "filter-pn": "PN", "filter-twr-skr": "BOTH TYPES", "filter-all-specials": "ALL", - "filter-common": "NO WARNINGS", + "filter-common": "COMMON", "filter-passenger": "PASSENGER", "filter-freight": "FREIGHT", "filter-other": "OTHER", diff --git a/src/locales/pl.json b/src/locales/pl.json index 2063a7f..f8e5829 100644 --- a/src/locales/pl.json +++ b/src/locales/pl.json @@ -20,11 +20,16 @@ "dispatcher-message": "Dyżurny wspierający projekt Stacjownika!", "driver-message": "Maszynista wspierający projekt Stacjownika!" }, + "warnings": { + "TWR": "Pociąg z towarami niebezpiecznie wysokiego ryzyka", + "SKR": "Pociąg z przekroczoną skrajnią", + "PN": "Pociąg z przesyłkami nadzwyczajnymi", + "TN": "Pociąg z towarami niebezpiecznymi", + "header-title": "Uwagi przewozowe:" + }, "general": { "and": " oraz ", - "refresh": "ODŚWIEŻ", - "TWR": "Towar niebezpieczny wysokiego ryzyka", - "SKR": "Przekroczona skrajnia" + "refresh": "ODŚWIEŻ" }, "update": { "title": "Aktualizacja Stacjownika!", @@ -177,7 +182,7 @@ "sort-beginDate": "data", "sort-timetableId": "ID rozkładu", "sort-timestampFrom": "data", - "sort-duration": "czas dyżuru", + "sort-currentDuration": "czas dyżuru", "sort-id": "id rozkładu", "sort-mass": "masa", @@ -190,8 +195,10 @@ "filter-withComments": "UWAGI EKSPLOATACYJNE", "filter-noComments": "BEZ UWAG", - "filter-twr": "WYS. RYZYKA", - "filter-skr": "SKRAJNIA", + "filter-twr": "TWR", + "filter-skr": "SKR", + "filter-tn": "TN", + "filter-pn": "PN", "filter-twr-skr": "TWR/SKR", "filter-all-statuses": "WSZYSTKIE", "filter-common": "ZWYKŁE", @@ -364,7 +371,7 @@ "current-track": "na szlaku", "vmax-tooltip": "Maksymalna prędkość na podstawie pojazdów w składzie - nie bierze pod uwagę masy hamowania", - + "catenary-tooltip": "Szlak zelektryfikowany", "no-catenary-tooltip": "Szlak niezelektryfikowany", "sbl-tooltip": "Szlak posiadający\nsamoczynną blokadę liniową", diff --git a/src/managers/trainFilterManager.ts b/src/managers/trainFilterManager.ts index 1acf953..46c1c19 100644 --- a/src/managers/trainFilterManager.ts +++ b/src/managers/trainFilterManager.ts @@ -45,8 +45,11 @@ function filterTrainList( case TrainFilterId.twr: return !train.timetableData?.TWR; - case TrainFilterId.skr: - return !train.timetableData?.SKR; + case TrainFilterId.pn: + return !train.timetableData?.hasExtraDeliveries; + + case TrainFilterId.tn: + return !train.timetableData?.hasDangerousCargo; case TrainFilterId.common: return train.timetableData?.SKR || train.timetableData?.TWR; diff --git a/src/store/mainStore.ts b/src/store/mainStore.ts index 5dea181..3fdde31 100644 --- a/src/store/mainStore.ts +++ b/src/store/mainStore.ts @@ -87,14 +87,16 @@ export const useMainStore = defineStore('mainStore', { timetableData: timetable ? { timetableId: timetable.timetableId, - SKR: timetable.SKR, - TWR: timetable.TWR, route: timetable.route, category: timetable.category, followingStops: timetable.stopList, routeDistance: timetable.stopList[timetable.stopList.length - 1].stopDistance, sceneries: timetable.sceneries, + TWR: timetable.TWR, + SKR: timetable.SKR, warningNotes: timetable.warningNotes, + hasDangerousCargo: timetable.hasDangerousCargo, + hasExtraDeliveries: timetable.hasExtraDeliveries, timetablePath: timetable.path.split(';').map((pathElementString) => { const [arrival, station, departure] = pathElementString.split(','); diff --git a/src/styles/badge.scss b/src/styles/badge.scss index edaa5a9..f29645d 100644 --- a/src/styles/badge.scss +++ b/src/styles/badge.scss @@ -79,18 +79,17 @@ } .train-badge { - display: flex; - align-items: center; + display: inline-block; gap: 0.3em; padding: 0.1em 0.3em; border-radius: 0.2em; font-weight: bold; + user-select: none; &.twr { background-color: var(--clr-twr); box-shadow: 0 0 5px 1px var(--clr-twr); - color: black; } &.skr { @@ -98,6 +97,17 @@ box-shadow: 0 0 5px 1px var(--clr-skr); } + &.tn { + background-color: var(--clr-tn); + box-shadow: 0 0 5px 1px var(--clr-tn); + } + + &.pn { + background-color: var(--clr-pn); + box-shadow: 0 0 5px 1px var(--clr-pn); + color: black; + } + &.offline { background-color: #be3728; } diff --git a/src/styles/global.scss b/src/styles/global.scss index 2d3bc8f..9b081fb 100644 --- a/src/styles/global.scss +++ b/src/styles/global.scss @@ -13,7 +13,9 @@ --clr-accent2: #ff3d5d; --clr-skr: #ff5100; - --clr-twr: #ffbb00; + --clr-twr: #ee503e; + --clr-tn: #cb4dcf; + --clr-pn: #ffd000; --clr-error: #fa3636; --clr-warning: #c59429; diff --git a/src/styles/variables.scss b/src/styles/variables.scss index c7b741d..914d8d6 100644 --- a/src/styles/variables.scss +++ b/src/styles/variables.scss @@ -9,6 +9,3 @@ $warningCol: #ffe15b; $accentCol: #ffc014; $accent2Col: #ff3d5d; - -$skr: #ff5100; -$twr: #ffbb00; diff --git a/src/typings/api.ts b/src/typings/api.ts index 8327bf6..3dde248 100644 --- a/src/typings/api.ts +++ b/src/typings/api.ts @@ -201,10 +201,11 @@ export namespace API { TWR: boolean; SKR: boolean; - sceneries: string[]; - - path: string; + hasDangerousCargo: boolean; + hasExtraDeliveries: boolean; warningNotes: string | null; + sceneries: string[]; + path: string; } } @@ -262,10 +263,13 @@ export namespace API { checkpointArrivalsScheduled: string[]; checkpointDeparturesScheduled: string[]; checkpointStopTypes: string[]; + checkpointComments: string[]; visitedSceneries: string[]; sceneryNames: string[]; path: string; warningNotes: string | null; + hasDangerousCargo: boolean; + hasExtraDeliveries: boolean; } export type Response = Data[]; diff --git a/src/typings/common.ts b/src/typings/common.ts index 7fd270e..0f1626a 100644 --- a/src/typings/common.ts +++ b/src/typings/common.ts @@ -84,10 +84,12 @@ export interface TrainTimetableData { followingStops: TrainStop[]; TWR: boolean; SKR: boolean; + hasDangerousCargo: boolean; + hasExtraDeliveries: boolean; + warningNotes: string | null; routeDistance: number; sceneries: string[]; timetablePath: TimetablePathElement[]; - warningNotes: string | null; } export interface Station { diff --git a/src/views/JournalDispatchers.vue b/src/views/JournalDispatchers.vue index fda4acb..2332ddd 100644 --- a/src/views/JournalDispatchers.vue +++ b/src/views/JournalDispatchers.vue @@ -7,8 +7,8 @@ ({ statsButtons, - currentQuery: '', - currentQueryArray: [] as string[], dataRefreshedAt: null as Date | null, + currentQueryParams: {} as DispatchersQueryParams, scrollDataLoaded: true, scrollNoMoreData: false, @@ -109,9 +130,6 @@ export default defineComponent({ 'search-date': '' } as Journal.DispatcherSearchType); - const countFromIndex = ref(0); - const countLimit = 15; - provide('sorterActive', sorterActive); provide('journalFilterActive', journalFilterActive); provide('searchersValues', searchersValues); @@ -126,19 +144,17 @@ export default defineComponent({ sorterActive, searchersValues, - countFromIndex, - countLimit, - - scrollElement, - maxCount: ref(15) + scrollElement }; }, watch: { - currentQueryArray(q: string[]) { - this.currentOptionsActive = - q.length > 2 || - q.some((qv) => qv.startsWith('sortBy=') && qv.split('=')[1] != 'timestampFrom'); + currentQueryParams(queryParams: DispatchersQueryParams) { + this.currentOptionsActive = Object.keys(queryParams).some( + (k) => + queryParams[k as keyof DispatchersQueryParams] != + defaultQueryParams[k as keyof DispatchersQueryParams] + ); }, 'mainStore.dispatcherStatsData'(stats) { @@ -234,13 +250,10 @@ export default defineComponent({ async addHistoryData() { this.scrollDataLoaded = false; - - this.countFromIndex = this.historyList.length; + this.currentQueryParams['countFrom'] = this.historyList.length; const responseData: API.DispatcherHistory.Response = await ( - await this.apiStore.client!.get( - `api/getDispatchers?${this.currentQuery}&countFrom=${this.countFromIndex}` - ) + await this.apiStore.client!.get(`api/getDispatchers`, { params: this.currentQueryParams }) ).data; if (!responseData) return; @@ -254,43 +267,38 @@ export default defineComponent({ this.scrollDataLoaded = true; }, - async fetchHistoryData(reset = false) { - const queries: string[] = []; + async fetchHistoryData() { + const queryParams: DispatchersQueryParams = {}; - const dispatcher = this.searchersValues['search-dispatcher'].trim(); - const station = this.searchersValues['search-station'].trim(); - const dateString = this.searchersValues['search-date'].trim(); + const dispatcherName = this.searchersValues['search-dispatcher'].trim() || undefined; + const stationName = this.searchersValues['search-station'].trim() || undefined; + const dateString = this.searchersValues['search-date'].trim() || undefined; const timestampFrom = dateString ? Date.parse(new Date(dateString).toISOString()) - 120 * 60 * 1000 : undefined; + const timestampTo = timestampFrom ? timestampFrom + 86400000 : undefined; - if (dispatcher) queries.push(`dispatcherName=${dispatcher}`); - - if (station.startsWith("#")) queries.push(`stationHash=${station.slice(1)}`); - else if (station.length > 0) queries.push(`stationName=${station}`); + queryParams['dispatcherName'] = dispatcherName; + queryParams['timestampFrom'] = timestampFrom; + queryParams['timestampTo'] = timestampTo; + queryParams['countLimit'] = 30; - if (timestampFrom && timestampTo) - queries.push(`timestampFrom=${timestampFrom}`, `timestampTo=${timestampTo}`); + if (stationName && stationName.startsWith('#')) + queryParams['stationHash'] = stationName.slice(1); + else queryParams['stationName'] = stationName; - // API: const SORT_TYPES = ['allStopsCount', 'endDate', 'beginDate', 'routeDistance']; - if (this.sorterActive.id == 'timestampFrom') queries.push('sortBy=timestampFrom'); - else if (this.sorterActive.id == 'duration') queries.push('sortBy=currentDuration'); - else queries.push('sortBy=timestampFrom'); + queryParams['sortBy'] = this.sorterActive.id; - queries.push('countLimit=30'); + if (JSON.stringify(this.currentQueryParams) != JSON.stringify(queryParams)) + this.dataStatus = Status.Data.Loading; - if (this.currentQuery != queries.join('&')) this.dataStatus = Status.Data.Loading; - - this.currentQuery = queries.join('&'); - this.currentQueryArray = queries; + this.currentQueryParams = queryParams; try { - if (reset) this.dataStatus = Status.Data.Loading; - const responseData: API.DispatcherHistory.Response = await ( - await this.apiStore.client!.get(`api/getDispatchers?${this.currentQuery}`) + await this.apiStore.client!.get(`api/getDispatchers`, { params: this.currentQueryParams }) ).data; if (!responseData) { diff --git a/src/views/JournalTimetables.vue b/src/views/JournalTimetables.vue index 34a2434..4b97470 100644 --- a/src/views/JournalTimetables.vue +++ b/src/views/JournalTimetables.vue @@ -105,7 +105,13 @@ export const journalTimetableFilters: Journal.TimetableFilter[] = [ default: false }, { - id: Journal.TimetableFilterId.TWR_SKR, + id: Journal.TimetableFilterId.TN, + filterSection: Journal.FilterSection.SPECIAL, + isActive: false, + default: false + }, + { + id: Journal.TimetableFilterId.PN, filterSection: Journal.FilterSection.SPECIAL, isActive: false, default: false @@ -118,8 +124,6 @@ interface TimetablesQueryParams { timetableId?: string; authorName?: string; - // timestampFrom?: number; - // timestampTo?: number; dateFrom?: string; dateTo?: string; @@ -136,6 +140,8 @@ interface TimetablesQueryParams { twr?: number; skr?: number; + pn?: number; + tn?: number; sortBy?: Journal.TimetableSorter['id']; } @@ -327,7 +333,7 @@ export default defineComponent({ const responseData: API.TimetableHistory.Response = await ( await this.apiStore.client!.get('api/getTimetables', { - params: { ...this.currentQueryParams } + params: this.currentQueryParams }) ).data; @@ -391,21 +397,24 @@ export default defineComponent({ case Journal.TimetableFilterId.ALL_SPECIALS: queryParams['twr'] = undefined; queryParams['skr'] = undefined; + queryParams['pn'] = undefined; + queryParams['tn'] = undefined; break; case Journal.TimetableFilterId.TWR: queryParams['twr'] = 1; - queryParams['skr'] = 0; break; case Journal.TimetableFilterId.SKR: - queryParams['twr'] = 0; queryParams['skr'] = 1; break; - case Journal.TimetableFilterId.TWR_SKR: - queryParams['twr'] = 1; - queryParams['skr'] = 1; + case Journal.TimetableFilterId.TN: + queryParams['tn'] = 1; + break; + + case Journal.TimetableFilterId.PN: + queryParams['pn'] = 1; break; default: