Skip to content

Commit

Permalink
Docs for .render_template(), refs #577
Browse files Browse the repository at this point in the history
Also improved parameter documentation for other methods, refs #576
  • Loading branch information
simonw committed Feb 14, 2020
1 parent 3ffb8f3 commit efa54b4
Showing 1 changed file with 41 additions and 1 deletion.
42 changes: 41 additions & 1 deletion docs/datasette.rst
Original file line number Diff line number Diff line change
Expand Up @@ -7,9 +7,17 @@ Many of Datasette's :ref:`plugin_hooks` pass a ``datasette`` object to the plugi

This object is an instance of the ``Datasette`` class. That class currently has a large number of methods on it, but it should not be considered stable (at least until Datasette 1.0) with the exception of the methods that are documented on this page.

.. _datasette_add_database:

.add_database(name, db)
-----------------------

``name`` - string
The unique name to use for this database. Also used in the URL.

``db`` - datasette.database.Database instance
The database to be attached.

The ``datasette.add_database(name, db)`` method lets you add a new database to the current Datasette instance. This database will then be served at URL path that matches the ``name`` parameter, e.g. ``/mynewdb/``.

The ``db`` parameter should be an instance of the ``datasette.database.Database`` class. For example:
Expand All @@ -32,12 +40,44 @@ Use ``is_mutable`` if it is possible that updates will be made to that database

Use ``is_memory`` if the connection is to an in-memory SQLite database.

.. _datasette_remove_database:

.remove_database(name)
----------------------

``name`` - string
The name of the database to be removed.

This removes a database that has been previously added. ``name=`` is the unique name of that database, also used in the URL for it.

.. _datasette_plugin_config:

.plugin_config(plugin_name, database=None, table=None)
------------------------------------------------------

This method lets you read plugin configuration values that were set in ``metadata.json``. See :ref:`plugins_plugin_config` for full details.
``plugin_name`` - string
The name of the plugin to look up configuration for. Usually this is something similar to ``datasette-cluster-map``.

``database`` - None or string
The database the user is interacting with.

``table`` - None or string
The table the user is interacting with.

This method lets you read plugin configuration values that were set in ``metadata.json``. See :ref:`plugins_plugin_config` for full details of how this method should be used.

.. _datasette_render_template:

.render_template(template, context=None, request=None)
------------------------------------------------------

``template`` - string
The template file to be rendered, e.g. ``my_plugin.html``. Datasette will search for this file first in the ``--template-dir=`` location, if it was specified - then in the plugin's bundled templates and finally in Datasette's set of default templates.

``conttext`` - None or a Python dictionary
The context variables to pass to the template.

``request`` - request object or None
If you pass a Datasette request object here it will be made available to the template.

Renders a `Jinja template <https://jinja.palletsprojects.com/en/2.11.x/>`__ using Datasette's preconfigured instance of Jinja and returns the resulting string. The template will have access to Datasette's default template functions and any functions that have been made available by other plugins.

0 comments on commit efa54b4

Please sign in to comment.