This djangocms plugin allows you to create Call To Action (CTA) indicators, to display them as buttons in a Django CMS plugin, to track user click on these buttons on a GA conversion tunnel. Each CTA is linked with a fobi form which registers the user email in a given mailing list.
Project description
djangocms-call-to-action
A djangocms plugin that allows you to create Call To Action (CTA) indicators, to display them as buttons in a Django CMS plugin, to track user click on these buttons on a GA conversion tunnel. Each CTA is linked with a fobi form which registers the user email in a given mailing list.
This project is a WIP and might need some improvements.
Installation
This plugin requires Django-CMS
, sendgrid
, django-fobi
.
- Install module using pipenv:
pipenv install djangocms-call-to-action
- Or pip:
pip install djangocms-call-to-action
- Add it to your installed apps:
"djangocms_call_to_action",
- Apply migrations
py manage.py migrate djangocms_call_to_action
- Include your sendgrid api key in your settings
DJANGOCMS_CTA_SENDGRID_API_KEY = "YOUR_API_KEY"
- Or load it using an environment var:
import os
DJANGOCMS_CTA_SENDGRID_API_KEY = os.getenv("SENDGRID_API_KEY", None)
- Include your Google analytics GA code in your settings
DJANGOCMS_CTA_GA_UA = "UA-*******-*"
- Or load it using an environment var:
import os
DJANGOCMS_CTA_GA_UA = os.getenv("GA_UA", None)
- Include the CTAFobiFormWidgetRedirectMiddleware before all other middlewares, and CTAPagePermissionMiddleware after django-cms CurrentPageMiddleware:
MIDDLEWARE = (
"djangocms_call_to_action.middleware.CTAFobiFormWidgetRedirectMiddleware",
...
"cms.middleware.page.CurrentPageMiddleware",
...
"djangocms_call_to_action.middleware.CTAPagePermissionMiddleware",
)
- Add
djangocms_call_to_action.urls
to your urls:
urlpatterns = [
...
path("cta/", include("djangocms_call_to_action.urls")),
...
re_path("^", include("cms.urls")),
]
Optional settings
- Configure templates used to display the CMS plugin
from django.utils.translation import ugettext_lazy as _
DJANGOCMS_CTA_TEMPLATES = (("default.html", _("Link")), ("button_primary.html", _("Button primary")), ("button_secondary.html", _("Button secondary")),)
- Activate select2 for cms page selectors (requires django-select2)
DJANGOCMS_CTA_USE_SELECT2 = True
- Configure labels used for actions in GA
DJANGOCMS_CTA_DISPLAYED_USER_GA_LABEL = "Affiché"
DJANGOCMS_CTA_CLICKED_USER_GA_LABEL = "Cliqué"
DJANGOCMS_CTA_CONVERTED_USER_GA_LABEL = "Converti"
- Change cache duration for deny pages ids
DJANGOCMS_CTA_DENY_PAGES_IDS_CACHE_DURATION = 24 * 60 * 60 # Cache for 24h
How to use
- Create a fobi form using fobi interface.
In order to work properly with sendgrid registration, the form must contains the following fields: - First name - Last name - Email - An opt-in checkbox to consent the user email registration on sendgrid list
-
Add the sendgrid handler to register the email address of the user into
-
Create a CMS page to display the fobi form into
-
Insert the fobi form into the new page, using the CMS plugin "Call to Action"
-
On the django admin, create a Campaign linked with the CMS page created on step 4. Choose where the user will be redirected on form validation:
- To an external link
- To an internal link
- To a file
You can choose to deny the access to the page if the form was not validated by the user.
- On your content, insert some CTA plugins to redirect to the form using the "Click To Action" cms plugin
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Hashes for djangocms-call-to-action-0.0.2.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | 45919a26971e7d23c12df62ed24465472b0c1bf94e17a54747a9b9f2427bf11c |
|
MD5 | cb584263d0159a865c1b31560d28c98a |
|
BLAKE2b-256 | bc19611ca763434e3a4f23459dbe9d5d215bee4bc0920ea5ef4e659b19318913 |