DjangoCMS FAQ let you create FAQ plugins that contains other plugins and provide an API to get questions/answers from keywords!
Project description
DjangoCMS FAQ
Frequently asked questions plugin for Django CMS, with an API to load questions from another page!
Install
-
Install module
python3 -m pip install djangocms-faq
Or use this command if you want to add a scoop of fuzzy-search in your api:
python3 -m pip install djangocms-faq[fuzzy_search]
-
Add it to your INSTALLED_APPS
"djangocms_faq",
-
Add the API endpoint to your
urls.py
(if you want to use the Faq Search Plugin):path("djangocms-faq/", include("djangocms_faq.urls")),
-
Launch your django-cms site, it should be here!
Requirements
django-cms
: Obviously.django-sekizai
: For default templates (you can uninstall it if you use custom templates without sekizai). Not required in this package (it's a requirement of django-cms).thefuzz
: If you want to use fuzzy search, optional package.
Features
A faq
Add FAQ Containers plugins, which have a (hidden and required) name, a (public and optional) title, and can only contain FAQ Questions plugins.
Then, add FAQ Questions plugins that can contain text/image/videos plugins (that provide answers)!
You can also add keywords to your FAQ questions, because you may want your users to find a specific answer to a general question.
You can create an alias of a Question and paste if where you want, but it is more coherent to copy the whole Faq Container, or tu put a search bar.
It is discouraged to create a FAQ on a non-cms page (like a djangocms-blog post) : the search function will not work (this plugin does not know how to get the current url if it's not on a placeholder that's on a cms page object).
A search plugin that uses an API
Ask a question to the FAQ and the plugin will return with the corresponding questions/answers.
Quick note: since the form uses javascript and a simple view, that means that the search works without javascript too!
Another quick note: The search results will not include results from aliased plugins, it will only link to original questions.
Select in which FAQ the searches will be applied
Display format is {FAQ Name} ({Page title})
.
Fuzzy search!
Users can make mistakes. So this package can use the token_sort_ratio
function from the package fuzzywuzzy to return str that are at least (>=) 85% the same (you can change the number).
To activate it, simply install the package like this:
python3 -m pip install djangocms-faq[fuzzy_search]
And add this to your settings :
DJANGOCMS_FAQ_ENABLE_FUZZY_SEARCH = True
Query detection in question title is still used when fuzzy search is enabled:
Fuzzy search:
Here, "this long string" match "that long string" at 87%, so the question is returned.
Configuration
-
DJANGOCMS_FAQ_ENABLE_API
(default isTrue
): Enable or not the API endpoint and the Faq Search plugins.If you create a Faq Search Plugin and then set this setting to
False
, then you will be greeted with a coolKeyError 'FaqPluginSearchPublished'
error message. Please do not do this. -
DJANGOCMS_FAQ_MAX_QUERY_LENGTH
(default is60
): Max size of a query to the api. The module will truncate user requests toDJANGOCMS_FAQ_MAX_QUERY_LENGTH
chars. -
DJANGOCMS_FAQ_ANSWER_PLUGINS
(default is["TextPlugin", "FilePlugin", "VideoPlayerPlugin"]
): Add plugins that can be added to your answers! -
DJANGOCMS_FAQ_SHOW_KEYWORDS_QUESTION
(default isTrue
): Display keywords in the questions of a FAQ. -
DJANGOCMS_FAQ_SHOW_KEYWORDS_ANSWER
(default isTrue
): Display keywords in answers (faq search plugin). -
DJANGOCMS_FAQ_ENABLE_FUZZY_SEARCH
(default isFalse
): Wanna use fuzzy search ? (see fuzzy-search) -
DJANGOCMS_FAQ_FUZZY_SEARCH_PERCENTAGE
(default is85
): Score to reach before returning a match between two patterns (query/question or query/keyword) from the api. -
DJANGOCMS_FAQ_SEARCH_WORD_BY_WORD_KEYWORDS
(default isFalse
): If you want to split user queries & keywords in order to return a question if at least one word from the query is the same of at least one word of it's keywords.
Here's a screenshot with different examples (configs: DJANGOCMS_FAQ_ENABLE_FUZZY_SEARCH
and DJANGOCMS_FAQ_SEARCH_WORD_BY_WORD_KEYWORDS
):
Warning! Do not use stopwords in keywords, or else you might get a looot of results!
API
When you're searching for something in the input, searches will be made using the API if you don't type anything for 1 second (see templates/faq_search.html
).
Here's the format:
[
{
"question": "question title",
"slug": "question-title",
"url": "/page-url/",
"keywords": ["keyword", "another keyword", "..."]
},
{
"question": "question title 2",
"slug": "question-title2",
"url": "/page-url/",
"keywords": ["keyword", "an other key word", "..."]
},
]
Api format
djangocms-faq/?question=keyword&search_in=aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaaa%20bbbbbbbb-bbbb-bbbb-bbbb-bbbbbbbbbbbbb&draft=True
Where keyword
is a string, the uuid
s are valid uuids (strings) of FAQs separated by spaces, and draft
is the faq to search into (draft or live version of the CMSPlugin).
You can submit requests without the draft parameter, the script will then search only in published (live) version of each faq CMSPlugin (like draft=False
).
Customize it!
The templates included in this project are for demonstration purposes only, it is up to you to integrate them into your graphic charter by creating faq_plugin.html
, faq_question.html
and faq_search.html
files in templates/faq/
.
How it works
Faq container & questions are classic django-cms plugins, see in cms_plugins.py
for more informations.
Faq search plugin is a django-cms plugin, and uses on top of that an API endpoint using vanilla javascript (the default template uses fetch
, which is not compatible with IE).
The API endpoint is a single view that returns json (see views.py
).
Since the function to get answers from a "question" str is used two times (in the view for the API and in the FaqPluginSearchPublisher plugin), I've put it in a file named utils.py
.
When using fuzzy search mode, results are returned if the query is a substring of a question, or if the score between the question and the query or a keyword and the query is >= to DJANGOCMS_FAQ_FUZZY_SEARCH_PERCENTAGE
(default = 85%).
When you publish a page containing a FAQ used in a search form, the copy_relations
function will update the id of the FAQ using the class named RelationSearchFaq
(that store the uuids of FaqPluginModel
& SearchFaqPluginModel
).
Here's a bad drawing of the problem, and here's another bad drawing of the current solution.
It's a custom and dirty solution to the problem of handling relations between CMSPlugins.
It is much harder to manage the copying of relations when they are from one plugin to another.
source: Django-cms doc, Handling Relations > Relations between plugins.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file djangocms_faq-1.5.2.tar.gz
.
File metadata
- Download URL: djangocms_faq-1.5.2.tar.gz
- Upload date:
- Size: 32.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1b5290c03300c359efa9e83d73cd1d387900432b1740d0d59898d8c65a0d06f9 |
|
MD5 | 6862d1210de0fc12dcb1d8a4b9d0250e |
|
BLAKE2b-256 | de3a98eb57740233803daa53acde4c1fd8c1b07ac5bb066f3deefb0464487ea5 |
File details
Details for the file djangocms_faq-1.5.2-py3-none-any.whl
.
File metadata
- Download URL: djangocms_faq-1.5.2-py3-none-any.whl
- Upload date:
- Size: 34.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4b416137a6a7a3b5f73b031e6d027d1516750801994f85ed11e813736ae14e62 |
|
MD5 | 191b793110bdb62397d8c8cba2c72e19 |
|
BLAKE2b-256 | 53d31871e0351954a1733ac6f5c81094a489d6d35f8557c8466027ba42295a6b |