Skip to main content

A drop-in enhancement for Django's contrib.flatpages

Project description

Django Flatpages Extra 💅

A drop-in replacement for Django's contrib.flatpages with extra 💅 features.

Features

  • Drop-in replacement: installing the app only requires 2 line changes, and optionally a management command.
  • Non-destructive: no flatpage data is lost if you uninstall it.
  • Revisions: direct edits to a page's content are forbidden in favor of creating page revisions.
  • Better history: every revision has a detailed description, and a diff view to see exactly what changed.
  • Previews: revisions can be previewed before they're published, and even shared via a private URL.
  • 1-click revert: once published, revisions can be reverted via a single click.

Compatibility

flatpages_extra should compatible with all curently supported versions of Python and Django.

Installation

First make sure the package is installed:

uv add django-flatpages-extra

Or if you're using pip:

pip install django-flatpages-extra

Then add flatpages_extra to your settings.INSTALLED_APPS, making sure it comes before contrib.flatpages:

# settings.py
INSTALLED_APPS = [
    ...
    "flatpages_extra",
    "contrib.flatpages",
    ...
]

Finally, include the URL configuration. The exact path doesn't matter as long as it's reachable somewhere:

# urls.py
urlpatters = [
    ...
    # Replace `flatpagesextra` with whatever you'd like:
    path("flatpagesextra/", include("flatpages_extra.urls")),
    ...
]

Once you've done all that, the app should be installed and running. Optionally you can run this command to import data from contrib.flatpages:

python manage.py flatpages_extra_import_initial

Running this command will do the following:

  • create initial Revisions for all existing flatpages;
  • copy the pages' history from contrib.flatpages (otherwise the "History" page in the admin would be empty);
  • copy any custom FlatPage permission;
  • copy user and group permissions.

How to use it

flatpages_extra is meant to be used from the Django admin. Once installed, it replaces Django's contrib.flatpages in the admin interface with its own (look for its signature 💅 emoji).

When you want to make changes to an existing page, create a new revision (the FlatPage change form will prompt you to do so).

Once a revision is created, you can make changes to it, preview it, and even share the preview link.

When you're happy with the changes, you can publish the revision via the "publish" button on the Revision changelist.

Publishing a revision will automatically update the related page's content and create a descriptive entry in that page's history.

Configuration

flatpages_extra does not currently have any configurable options at the moment.

How it works

flatpages_extra works by creating a proxy model to Django's original FlatPage, which lets us change how the model works in the admin while keeping the same database table. It also adds a new Revision model that lets us preview, revert, and track changes to flat pages. Both of those models are registered in the admin and will replace the original contrib.flatpages admin pages.

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

django_flatpages_extra-1.0.tar.gz (13.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

django_flatpages_extra-1.0-py3-none-any.whl (22.8 kB view details)

Uploaded Python 3

File details

Details for the file django_flatpages_extra-1.0.tar.gz.

File metadata

File hashes

Hashes for django_flatpages_extra-1.0.tar.gz
Algorithm Hash digest
SHA256 60f7d27f08198426e56291a7d166bcba8f89ef988bca6f5128c477fa2ffd93e4
MD5 4d48b43463ae382491acb904209b7827
BLAKE2b-256 bf703f773fdc90930f68b54c39700d64fd2918e1ea75af7b4c01a4e689e73a70

See more details on using hashes here.

File details

Details for the file django_flatpages_extra-1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for django_flatpages_extra-1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 2f1120f543cccd73d94e2c31b70c4ab93898d890b7b619e64df9abf1d95cb68f
MD5 f8387c940db18add5febbd0bf12d427d
BLAKE2b-256 bdc7937118efa9c1e9573fdcb476dcac697b30249c725a6e1b513f4e8566bd8f

See more details on using hashes here.

Supported by

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