Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/exolever/django-exo-mentions
Listen to mentions of an user in a TextField, define pattern and the callback to notify to your app
https://github.com/exolever/django-exo-mentions
django pip python
Last synced: about 1 month ago
JSON representation
Listen to mentions of an user in a TextField, define pattern and the callback to notify to your app
- Host: GitHub
- URL: https://github.com/exolever/django-exo-mentions
- Owner: exolever
- License: mit
- Created: 2018-08-31T11:27:01.000Z (over 6 years ago)
- Default Branch: devel
- Last Pushed: 2019-11-12T16:35:38.000Z (about 5 years ago)
- Last Synced: 2024-11-16T12:49:43.787Z (2 months ago)
- Topics: django, pip, python
- Language: Python
- Homepage:
- Size: 84 KB
- Stars: 1
- Watchers: 6
- Forks: 0
- Open Issues: 3
-
Metadata Files:
- Readme: README.rst
- Changelog: HISTORY.rst
- Contributing: CONTRIBUTING.rst
- License: LICENSE
Awesome Lists containing this project
README
=============================
django-exo-mentions
=============================.. image:: https://badge.fury.io/py/django-exo-mentions.svg
:target: https://badge.fury.io/py/django-exo-mentions.. image:: https://requires.io/github/exolever/django-exo-mentions/requirements.svg?branch=master
:target: https://requires.io/github/exolever/django-exo-mentions/requirements/?branch=master
:alt: Requirements Status.. image:: https://travis-ci.org/exolever/django-exo-mentions.svg?branch=master
:target: https://travis-ci.org/exolever/django-exo-mentions.. image:: https://codecov.io/gh/exolever/django-exo-mentions/branch/master/graph/badge.svg
:target: https://codecov.io/gh/exolever/django-exo-mentions
.. image:: https://img.shields.io/badge/contributions-welcome-brightgreen.svg?style=flat
:target: https://github.com/exolever/django-exo-mentions/issues
.. image:: https://img.shields.io/badge/License-MIT-green.svg
:target: https://opensource.org/licenses/MITDocumentation
-------------The purpose of this package is to handle in some way mentions to users in a text field of a model. You can choose the model you want, the field you want to listen to mentions, the pattern you use to codify the mention and the callback to notify to your app.
The package will notify to callback function each time there is a mention in this field of the model. Then you can act accordingly on your application requisites.
The full documentation is at https://exo-mentions.readthedocs.io.
Quickstart
----------Install django-exo-mentions::
pip install django-exo-mentions
=====
Usage
=====To use django-exo-mentions in a project, add it to your `INSTALLED_APPS`:
.. code-block:: python
INSTALLED_APPS = (
...
'exo_mentions',
...
)Define a signal for the callback
.. code-block:: python
from django.dispatch import receiver
from django.core.signals import request_finished@receiver(request_finished)
def post_detect_mention_callback(sender, **kwargs):
""" You will receive information of the mention
user_from: kwargs.get('user_from')
User that mentions
object_pk: kwargs.get('object_pk')
User's Pk that has been mentioned
target: kwargs.get('target')
The object where the mention was made
"""# Your code here
Register a model and field in which you want to detect mentions.
You can override the pattern if you want... code-block:: python
from django.apps import AppConfig
from exo_mentions.registry import registerclass MyAppConfig(AppConfig):
name = 'myapp'def ready(self):
model = Post
field = 'description'
callback = post_detect_mention_callbackregister(model, field, callback)
At this point the library will notify to the callback each time there is a mention in the field of the registered model. Thats all! :)
.. code-block:: python
def register(model, field, callback, pattern):
"""
This method handles the mentions about the model in the field and notify to the callback when there is any mentionParameters
----------
model : Models
The model to register for detect mentions
field : str
Field of the model to detect mentions
callback : function
Callback function to notify when there are mentions
pattern : regular expression
The pattern to codify the mentions (default r'class="mention" data-user=[\'"]?([^\'" >]+)')
"""Running Tests
-------------Does the code actually work?
::
source /bin/activate
(myenv) $ pip install tox
(myenv) $ toxCredits
-------Tools used in rendering this package:
* Cookiecutter_
* `cookiecutter-djangopackage`_.. _Cookiecutter: https://github.com/audreyr/cookiecutter
.. _`cookiecutter-djangopackage`: https://github.com/pydanny/cookiecutter-djangopackage