django-fsm-admin-django-4
=========================
Mixin and template tags to integrate django-fsm_ state transitions into the
Django Admin.
Note: This is a fork of https://github.com/gadventures/django-fsm-admin
which is not maintained anymore. This fork is compatible with Django 4.
Installation
------------
.. code:: sh
$ pip install django-fsm-admin-django-4
Or from GitHub:
.. code:: sh
$ pip install -e git://github.com/7tg/django-fsm-admin-django-4.git#egg=django-fsm-admin-django-4
Usage
-----
1. Add ``fsm_admin`` to your ``INSTALLED_APPS``.
2. Ensure that you have ``"django.core.context_processors.request"`` in your
``TEMPLATE_CONTEXT_PROCESSORS`` in Django settings. If the setting variable
is not yet defined, add:
.. code:: python
from django.conf import settings
TEMPLATE_CONTEXT_PROCESSORS = settings.TEMPLATE_CONTEXT_PROCESSORS + (
"django.core.context_processors.request",
)
3. In your ``admin.py`` file, use ``FSMTransitionMixin`` to add behaviour to your
ModelAdmin. ``FSMTransitionMixin`` should be before ``ModelAdmin``, the order is
important.
It assumes that your workflow state field is named ``state``, however you can
override it or add additional workflow state fields with the attribute
``fsm_field``.
.. code:: python
from fsm_admin.mixins import FSMTransitionMixin
class YourModelAdmin(FSMTransitionMixin, admin.ModelAdmin):
# The name of one or more FSMFields on the model to transition
fsm_field = ['wf_state',]
admin.site.register(YourModel, YourModelAdmin)
4. By adding ``custom=dict(admin=False)`` to the transition decorator, one can
disallow a transition to show up in the admin interface. This specially is
useful, if the transition method accepts parameters without default values,
since in **django-fsm-admin-django-4** no arguments can be passed into the transition
method.
.. code:: python
@transition(
field='state',
source=['startstate'],
target='finalstate',
custom=dict(admin=False),
)
def do_something(self, param):
# will not add a button "Do Something" to your admin model interface
By adding ``FSM_ADMIN_FORCE_PERMIT = True`` to your configuration settings, the
above restriction becomes the default. Then one must explicitly allow that a
transition method shows up in the admin interface.
.. code:: python
@transition(
field='state',
source=['startstate'],
target='finalstate',
custom=dict(admin=True),
)
def proceed(self):
# will add a button "Proceed" to your admin model interface
This is useful, if most of your state transitions are handled by other means,
such as external events communicating with the API of your application.
Try the example
---------------
.. code:: sh
$ git clone git@github.com:7tg/django-fsm-admin-django-4.git
$ cd django-fsm-admin-django-4
$ mkvirtualenv fsm_admin
$ pip install -r requirements.txt
$ python setup.py develop
$ cd example
$ python manage.py syncdb
$ python manage.py runserver
.. _django-fsm: https://github.com/kmmbvnr/django-fsm
Raw data
{
"_id": null,
"home_page": "https://github.com/7tg/django-fsm-admin-django-4",
"name": "django-fsm-admin-django-4",
"maintainer": "",
"docs_url": null,
"requires_python": "",
"maintainer_email": "",
"keywords": "django fsm admin",
"author": "G Adventures",
"author_email": "software@gadventures.com",
"download_url": "https://files.pythonhosted.org/packages/8c/de/806617180fc7f8fff9172686618cf11c4cd7a3feffa9ca302020596f7055/django-fsm-admin-django-4-1.2.7.tar.gz",
"platform": "any",
"description": "django-fsm-admin-django-4\n=========================\n\nMixin and template tags to integrate django-fsm_ state transitions into the\nDjango Admin.\n\nNote: This is a fork of https://github.com/gadventures/django-fsm-admin\nwhich is not maintained anymore. This fork is compatible with Django 4.\n\nInstallation\n------------\n\n.. code:: sh\n\n $ pip install django-fsm-admin-django-4\n\nOr from GitHub:\n\n.. code:: sh\n\n $ pip install -e git://github.com/7tg/django-fsm-admin-django-4.git#egg=django-fsm-admin-django-4\n\nUsage\n-----\n\n1. Add ``fsm_admin`` to your ``INSTALLED_APPS``.\n\n2. Ensure that you have ``\"django.core.context_processors.request\"`` in your\n ``TEMPLATE_CONTEXT_PROCESSORS`` in Django settings. If the setting variable\n is not yet defined, add:\n\n.. code:: python\n\n from django.conf import settings\n\n TEMPLATE_CONTEXT_PROCESSORS = settings.TEMPLATE_CONTEXT_PROCESSORS + (\n \"django.core.context_processors.request\",\n )\n\n3. In your ``admin.py`` file, use ``FSMTransitionMixin`` to add behaviour to your\n ModelAdmin. ``FSMTransitionMixin`` should be before ``ModelAdmin``, the order is\n important.\n\nIt assumes that your workflow state field is named ``state``, however you can\noverride it or add additional workflow state fields with the attribute\n``fsm_field``.\n\n.. code:: python\n\n from fsm_admin.mixins import FSMTransitionMixin\n\n class YourModelAdmin(FSMTransitionMixin, admin.ModelAdmin):\n # The name of one or more FSMFields on the model to transition\n fsm_field = ['wf_state',]\n\n admin.site.register(YourModel, YourModelAdmin)\n\n4. By adding ``custom=dict(admin=False)`` to the transition decorator, one can\n disallow a transition to show up in the admin interface. This specially is\n useful, if the transition method accepts parameters without default values,\n since in **django-fsm-admin-django-4** no arguments can be passed into the transition\n method.\n\n.. code:: python\n\n @transition(\n field='state',\n source=['startstate'],\n target='finalstate',\n custom=dict(admin=False),\n )\n def do_something(self, param):\n # will not add a button \"Do Something\" to your admin model interface\n\nBy adding ``FSM_ADMIN_FORCE_PERMIT = True`` to your configuration settings, the\nabove restriction becomes the default. Then one must explicitly allow that a\ntransition method shows up in the admin interface.\n\n.. code:: python\n\n @transition(\n field='state',\n source=['startstate'],\n target='finalstate',\n custom=dict(admin=True),\n )\n def proceed(self):\n # will add a button \"Proceed\" to your admin model interface\n\nThis is useful, if most of your state transitions are handled by other means,\nsuch as external events communicating with the API of your application.\n\nTry the example\n---------------\n\n.. code:: sh\n\n $ git clone git@github.com:7tg/django-fsm-admin-django-4.git\n $ cd django-fsm-admin-django-4\n $ mkvirtualenv fsm_admin\n $ pip install -r requirements.txt\n $ python setup.py develop\n $ cd example\n $ python manage.py syncdb\n $ python manage.py runserver\n\n\n.. _django-fsm: https://github.com/kmmbvnr/django-fsm\n\n\n",
"bugtrack_url": null,
"license": "MIT",
"summary": "Integrate django-fsm state transitions into the django admin with django 4 support.",
"version": "1.2.7",
"project_urls": {
"Homepage": "https://github.com/7tg/django-fsm-admin-django-4"
},
"split_keywords": [
"django",
"fsm",
"admin"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "8cde806617180fc7f8fff9172686618cf11c4cd7a3feffa9ca302020596f7055",
"md5": "4f635189a4eae8bd5f977f56eaa51a25",
"sha256": "729d455444f1116d25affdf8d3956aad7ece4e532893db71ab46c82524558b9e"
},
"downloads": -1,
"filename": "django-fsm-admin-django-4-1.2.7.tar.gz",
"has_sig": false,
"md5_digest": "4f635189a4eae8bd5f977f56eaa51a25",
"packagetype": "sdist",
"python_version": "source",
"requires_python": null,
"size": 11799,
"upload_time": "2024-01-03T12:46:39",
"upload_time_iso_8601": "2024-01-03T12:46:39.649119Z",
"url": "https://files.pythonhosted.org/packages/8c/de/806617180fc7f8fff9172686618cf11c4cd7a3feffa9ca302020596f7055/django-fsm-admin-django-4-1.2.7.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-01-03 12:46:39",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "7tg",
"github_project": "django-fsm-admin-django-4",
"travis_ci": false,
"coveralls": false,
"github_actions": false,
"requirements": [],
"lcname": "django-fsm-admin-django-4"
}