mirror of
https://github.com/go-vikunja/vikunja.git
synced 2026-05-29 23:19:48 +00:00
Add useWebSocket composable with: - Auto-connect on login, disconnect on logout - Exponential backoff with ±25% jitter for reconnects - Auth failure detection to prevent reconnect loops - Trailing slash stripping from API_URL - Overlapping reconnect prevention - visibilityState check for fallback polling Replace notification polling with real-time WebSocket push in the Notifications component. Initial state is still loaded via REST on mount, with fallback polling when WebSocket is disconnected. Incoming notifications are deduplicated against already-loaded REST data. Notifications are reloaded via REST on WS disconnect to catch missed events.
Web frontend for Vikunja
The todo app to organize your life.
This is the web frontend for Vikunja, written in Vue.js.
Take a look at our roadmap (hosted on Vikunja!) for a list of things we're currently working on!
For general information about the project, refer to the top-level readme of this repo.
Project setup
pnpm install
Development
Define backend server
You can develop the web front end against any accessible backend, including the demo at https://try.vikunja.io
In order to do so, you need to set the DEV_PROXY env variable. The recommended way to do so is to:
- Copy
.env.local.exampleas.env.local - Uncomment the
DEV_PROXYline - Set the backend url you want to use
In the end, it should look like DEV_PROXY=https://try.vikunja.io if you work against the online demo backend.
Start dev server (compiles and hot-reloads)
pnpm run dev
Compiles and minifies for production
pnpm run build
Lints and fixes files
pnpm run lint
License
This project is licensed under the AGPL-3.0-or-later license. See the LICENSE file for details.