Skip to main content

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 the head* 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.

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

local_reload-1.1.0.tar.gz (10.1 kB view details)

Uploaded Source

Built Distribution

local_reload-1.1.0-py3-none-any.whl (20.3 kB view details)

Uploaded Python 3

File details

Details for the file local_reload-1.1.0.tar.gz.

File metadata

  • Download URL: local_reload-1.1.0.tar.gz
  • Upload date:
  • Size: 10.1 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

Hashes for local_reload-1.1.0.tar.gz
Algorithm Hash digest
SHA256 ed90ec8b65500b6c1effd92e39289861db0fa2f147fe91538306bdf06d697b76
MD5 cf5f15e5d3e2ca448f949811e248dc66
BLAKE2b-256 13f6af8d9ab3f0c9962e55c2233b473de486ccc95a9d140f0395b6092df338db

See more details on using hashes here.

File details

Details for the file local_reload-1.1.0-py3-none-any.whl.

File metadata

  • Download URL: local_reload-1.1.0-py3-none-any.whl
  • Upload date:
  • Size: 20.3 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

Hashes for local_reload-1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 1951221fe9d58f8e63723cda1719f003ce7a2c7d27c463739eb7f85434de18a9
MD5 7e0c3e74d145b054843550c596b02ed1
BLAKE2b-256 631d1770479df185349dbdc6aa9b49e16e8dbafdcc0fb1698469993c144bcd53

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page