Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Game library performance improvements #475

Closed
andrew-codes opened this issue Aug 13, 2024 · 1 comment
Closed

Game library performance improvements #475

andrew-codes opened this issue Aug 13, 2024 · 1 comment
Assignees
Labels
app:library-updater App/service to update game library from Playnite via MQTT messages app:playnite-web Web app enhancement New feature or request released

Comments

@andrew-codes
Copy link
Owner

Currently, the entire game library is loaded when viewing the My Library page. This means the query for all games must complete before any HTML is sent to the browser. The delay is significant, upwards of 2-3 seconds just to get the first HTML payload.

Instead, ship only the first N games of data down to the browser. As the user scrolls, fetch more games as necessary. The library should appear as though all games are already present (not pagination navigation buttons).

Note: getting some games is the same cost as getting all games at the moment. This is because to get any set of games requires retrieving all game releases in order to compute the set of games. This will make the query slow regardless of pagination. In order to remedy this, consider a database collection to store games; computed from the current set of games releases. This will enable querying a small data set and also avoid transformations on the dataset to aggregate into games at time of query.

Also note, that new games come in individually via the game db updater. For this reason, the game collection will need to be updated incrementally as new game release come in; as opposed to a single aggregation once all games are "known."

@andrew-codes andrew-codes added enhancement New feature or request app:playnite-web Web app app:library-updater App/service to update game library from Playnite via MQTT messages labels Aug 13, 2024
@github-project-automation github-project-automation bot moved this to Needs Triage 🗃️ in Playnite-Web Aug 13, 2024
@andrew-codes andrew-codes self-assigned this Aug 13, 2024
andrew-codes added a commit that referenced this issue Aug 15, 2024
Introduce a database table for the graph game concept; named
`consolidated-games`. Games can now be queried directly from this table,
instead of requiring a query for or all game releases.

The game updater aggregates games by their name and updates this table as messages are received.

✅ Closes: #475
@andrew-codes andrew-codes moved this from In Progress ▶️ to Review 🎥 in Playnite-Web Aug 15, 2024
andrew-codes added a commit that referenced this issue Aug 15, 2024
andrew-codes added a commit that referenced this issue Aug 15, 2024
@github-project-automation github-project-automation bot moved this from Review 🎥 to Done ✅ in Playnite-Web Aug 15, 2024
Copy link

🎉 This issue has been resolved in version 5.1.0 🎉

The release is available on:

Your semantic-release bot 📦🚀

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
app:library-updater App/service to update game library from Playnite via MQTT messages app:playnite-web Web app enhancement New feature or request released
Projects
Archived in project
Development

No branches or pull requests

1 participant