Skip to main content

Editable Content in Flask

Project description


"Can't you just, rewrite it to sound more *edgy?*"

Clients blowing up your phone to change some copy on the ``/about``

Enter **Flask-Edits**. Mark sections of your templates with
``{% editable %}`` and their content is exposed in a slick admin panel.
Never worry about tweaking copy again.

.. figure::
:alt: Screenshot



$ pip install flask-edits



from flask.ext.edits import Edits

app = Flask(__name__)
edits = Edits(app)

All edits are saved to the disk as JSON, so configure a path to save the
edits. Edits can be commited to version control along with the rest of
the app.


import os.path as op
app.config['EDITS_PATH'] = op.join(op.dirname(op.abspath(__file__)), 'edits.json')

Mark sections of your Jinja templates as editable. The section name is
required, it's used as the section label when editing and the key that
the edits are stored under.


{% editable 'Section name' %}
Python is a programming language that lets you work quickly and integrate systems more effectively.
{% endeditable %}


There is no automatic detection of editable sections (yet). You have to
visit the URL that renders the template to register it as editable. It
will not show up in the admin panel until it has been rendered with


The Flask-Edits admin view is exposed by default at ``/edits``. The base
URL can be changed in the configuration:


app.config['EDITS_URL'] = '/edits'

**Note on security:**

Like Flask-Admin, Flask-Edits does not make any assumptions about the
authentication system you might be using. So, by default, the admin
interface is completely open. Protect it behind basic auth or another
form of authentication.


All pages that have registered editable sections are available to edit
in the interface. At this time, only static HTML is supported. Support
for Jinja2 is on the roadmap.

The `Summernote <>`__ HTML editor
is included but not used by default. To enable it:


app.config['EDITS_SUMMERNOTE'] = True

When a page is saved it instantly updates the Jinja context and writes
to the JSON file on the server.

Within a page, multiple sections with the same name will only show up
once in the admin panel, but the edits will be applied to each section.

Clearing a section will revert it to the original content in the


Preview mode is on by default. Edits will not show up on pages unless
``?preview=true`` is passed in the URL. This allows for easy editing
before content is live. Toggle the preview mode in the admin panel. If
previews are turned off, edits become live as they are saved.

Preview mode can be toggled in the configuration. To turn off previews
by default:


app.config['EDITS_PREVIEW'] = False

Turning off previews is recommended for use in production.


- Automatically register editable sections
- Jinja2 content with context evaluation
- Multiple database backends
- In-place page editing

Project details

Release history Release notifications

This version
History Node


History Node


History Node


History Node


History Node


History Node


History Node


History Node


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Filename, size & hash SHA256 hash help File type Python version Upload date
Flask-Edits-0.8.tar.gz (253.3 kB) Copy SHA256 hash SHA256 Source None Aug 26, 2014

Supported by

Elastic Elastic Search Pingdom Pingdom Monitoring Google Google BigQuery Sentry Sentry Error logging CloudAMQP CloudAMQP RabbitMQ AWS AWS Cloud computing Fastly Fastly CDN DigiCert DigiCert EV certificate StatusPage StatusPage Status page