You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
What feature do you want to improve?
The view indexes for an offline Pouch database are built on demand. So, for example, a freetext search view is only built the first time a user tries to search. After the initial build, the view is kept up to date as data in the database changes, but the initial indexing only happens when the first request is made.
The trouble is that for big views (like the freetext ones) the initial indexing time has been measured in minutes for a user with a non-trivial amount of data. This is time the user spends waiting (probably giving up) on the app to do what they want.
Describe the improvement you'd like
Instead of waiting for the user to trigger a query, we could proactively warm the views when the app starts (as suggested here: #9661 (comment)). This makes it much more likely that view queries will be responsive even the first time the user tries to use them.
Describe alternatives you've considered
The main question to consider would be if we should warm all the views or just some. If just some, how do we decide which views to warm? Warming all the views could waste disk space and processing power since we will be maintaining views that are not actually used by that user's workflows. (e.g. the reports_by_freetext view might not ever get used if the user cannot even access the Reports tab to see the search bar.)
Additional context
This issue is particularly relevant for #9544 and #9208 since both of those are going to trigger full-reindexing of the Pouch views.
The text was updated successfully, but these errors were encountered:
We used to index all views on startup in v2 and have removed it since, because it took a very long time, cannot be cancelled and users end up being blocked from using their device.
What feature do you want to improve?
The view indexes for an offline Pouch database are built on demand. So, for example, a freetext search view is only built the first time a user tries to search. After the initial build, the view is kept up to date as data in the database changes, but the initial indexing only happens when the first request is made.
The trouble is that for big views (like the freetext ones) the initial indexing time has been measured in minutes for a user with a non-trivial amount of data. This is time the user spends waiting (probably giving up) on the app to do what they want.
Describe the improvement you'd like
Instead of waiting for the user to trigger a query, we could proactively warm the views when the app starts (as suggested here: #9661 (comment)). This makes it much more likely that view queries will be responsive even the first time the user tries to use them.
Describe alternatives you've considered
The main question to consider would be if we should warm all the views or just some. If just some, how do we decide which views to warm? Warming all the views could waste disk space and processing power since we will be maintaining views that are not actually used by that user's workflows. (e.g. the reports_by_freetext view might not ever get used if the user cannot even access the Reports tab to see the search bar.)
Additional context
This issue is particularly relevant for #9544 and #9208 since both of those are going to trigger full-reindexing of the Pouch views.
The text was updated successfully, but these errors were encountered: