Django app for automatically identifying and reloading stale web pages
Project description
local_reload
Provides a means of identifying and automatically reloading "stale" pages.
Keeps a "last update time" in localStorage, and updates it whenever the user "updates data". Any time the user "returns" to a page (via browser history, or switches tabs/windows), that page will automatically reload if it is stale (if it was rendered before the last update time).
Intended for use on CRUD heavy sites, especially when you use history.back() or use multiple tabs/windows as part of the normal workflow.
Limitations
Update Time is Per-Browser
If data is updated in one browser, it will not reload pages in another browser. This is designed for a single user updating and viewing data in a single browser. We use window.localStorage
to store the update time, so our scope is the same as that of localStorage (hence the name "local_reload").
Update Time is Site-Wide
A single, site-wide "update time" is maintained. A change in one piece of data will invalidate all previously rendered pages, even if they do not display that data.
Update Detection
We automatically reset the update time when any form is POSTed. To be more precise - we reset the update time on every form submit event, as long as the form's method is not GET.
This works well if you use actual form submissions (even if handled via javascript) as the event which triggers data updates. If you update data without the user submitting a form, then you must manually call window.local_reload_invalidate()
.
No Background Reload
Pages will not be reloaded in background tabs/windows. They will only be reloaded when the user returns focus to them. This is actually by design. Previous attempts to reload background windows/tabs resulted in undesirable behaviour in many situations.
Installation
pip install local_reload
- add 'local_reload' to
INSTALLED_APPS
{% include "local_reload/local_reload_support.html" %}
in thehead
* of any page that displays or updates data
* This should be added near the top of your head
, so it can run as early as possible.
window.disable_local_reload
Set this to true if you want to temporarily/conditionally disable local reload on the given window.
NavTricks
We include a copy of NavTricks.js in our static files. This script pairs perfectly with local_reload.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file local_reload-1.2.0.tar.gz
.
File metadata
- Download URL: local_reload-1.2.0.tar.gz
- Upload date:
- Size: 10.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/40.6.2 requests-toolbelt/0.9.1 tqdm/4.43.0 CPython/3.6.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 3af1fef6b056d64908fce1733bf150b9f9b5d54484dd9b462b4ec7f5a8a5df31 |
|
MD5 | 408959260c1d8fe060dcd0b8fdbae305 |
|
BLAKE2b-256 | 179b4183c7d3e9500fe50685ec808d7a36375a21ec54e85c076e19a11af5c21e |
File details
Details for the file local_reload-1.2.0-py3-none-any.whl
.
File metadata
- Download URL: local_reload-1.2.0-py3-none-any.whl
- Upload date:
- Size: 20.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/40.6.2 requests-toolbelt/0.9.1 tqdm/4.43.0 CPython/3.6.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d21638b835d4ff56a0b2b7362ea29ffc3f4d79cc83e6199498b17e6cd2a7cb30 |
|
MD5 | ff6bac92c7e6c0cb1e8e63f535755f3a |
|
BLAKE2b-256 | 78e96f50435f1dd4c057e7d5208875f0f3c3e6ecf7b84d3e890152ecc374e09c |