DjangoCMS Plugin to add and edit ChartJs charts
Project description
DjangoCMS_Charts
A plugin for DjangoCMS that creates easy to use and fully customisable ChartJs (ver 2.x) charts - with a table and csv upload interface.
Updates / Changelog
3.1.0 — Django 4.2 / djangoCMS 3.11 / Python 3.11 (2026-03 → 2026-05)
- Upgrade to Django 4.2 LTS, django CMS 3.11, Python 3.9 – 3.11.
- Replaced all
ugettext_lazywithgettext_lazy(removed in Django 4.x) - Updated
install_requirestodjango>=4.2,<5.0,django-cms>=3.11,<3.12,django-select2>=8.0 - Updated
setup.pyclassifiers andpython_requires>=3.9
- Replaced all
- Architecture documentation — new
ARCHITECTURE.mddescribing models, options, datasets, colors, axes and plugins. - Test suite — tests moved into a dedicated
tests/directory withtests/settings.py+tests/urls.py, runnable aspython -m django test tests --settings=tests.settings. Coverage now includes utilities,CHART_TYPES, options type coercion, nested options dict building, color/axis models, dataset parsing (rows/cols/scatter), chart model properties,get_chart_as_dict(), plugin registration and global options. extras_require[test]added (djangocms-text-ckeditor,django-sekizai,django-admin-sortable2).- Bug fixes
AxisOptionsGroupModel: secondsave()now usesupdate_fields=['slug']to avoid the previous double-insert triggered byforce_insert=True.utils.color_variant: hex values are now zero-padded to two digits using an f-string ({:02x}) so dark colour variants render correctly.
- Repo hygiene:
__pycache__/and.idea/removed from version control and added to.gitignore.
3.0.3 (2023-03-26)
- Bug fix: chart-specific options are now copied on publish.
3.0.2 (2021-08-09 → 2020-11-09)
- Fix for migrations error.
- Increase field sizes for type/label fields (avoids truncation on long ChartJS option names).
3.0.0 / 3.0.1 — Complete refactor to ChartJS 2.x (2020-05 → 2020-10)
- CAUTION — complete refactor of DjangoCMS Charts to ChartJS 2.x.
- All Models, Fields and Options have changed
- Due to changes in ChartJS 1.x → 2.x not all custom settings can be migrated
- Migrations attempt to bring over any settings that were changed from their defaults on each previous chart.
- ChartJS is enabled by default — see settings below to disable.
- All chart types are now available in the single ChartJS plugin.
- Multiple Datasets can be added as child plugins of the parent ChartJS plugin.
- Global Options are added in the Admin, as required.
- All Options come from the ChartJS object / dictionary and use a Select2 list.
- Upgrade to Django 2.2+ and Python 3 compatibility fixes.
- CSV upload fixes.
2.x (2019)
- Python 3.7 compatibility.
- Removed bundled (outdated) jQuery — now relies on a project-supplied
version added to the
jssekizai block.
1.x (2016 – 2018)
- Initial release on the Aldryn marketplace.
- Django 1.11 URL/
get_all_field_namesfixes.
Quick start
-
Add 'djangocms_charts' to your INSTALLED_APPS setting like this::
INSTALLED_APPS = [ ... 'djangocms_charts', ]
-
Run
python manage.py migrateto create the djangocms_charts models. -
Ensure you have your own version of jQuery added to block 'js'. See here: https://django-sekizai.readthedocs.io/en/latest/#example
-
Add a DjangoCMS ChartJS Plugin to your web page!
Caching [Optional]
The queries and building up of each chart can be expensive for many options/data rows/charts etc. To speed this up set up a dedicated DjangoCMS Charts cache. This should be a unique cache as it will require to be cleared after saving any charts object due to the complex relationship between all objects.
-
In
settings.pyaddDJANGOCMS_CHARTS_CACHE = 'djangocms_charts'which should map to a unique cache. -
In your
CACHESadd the charts cache - sample backend below - use your own cache system:
CACHES = {
'default': {
...
},
'djangocms_charts':{
'BACKEND': 'django.core.cache.backends.locmem.LocMemCache',
'LOCATION': 'djangocms_charts',
'TIMEOUT': CACHE_MIDDLEWARE_SECONDS,
'OPTIONS': {
'MAX_ENTRIES': 5000
}
},
}
URLS [Optional]
If access to the JSON Vesion of the chart is required add the following to your urls.py :
urlpatterns = [
...
url(r'^chartjs/', include('djangocms_charts.urls')),
...
]
The JSON view can then be accessed via:
- Chart View:
[url]/chartjs/get_chart_as_json/[chart_id]/ - Global Options View:
[url]/get_global_options_as_json/[options_id]/
ChartJs-Sass [Optional]
All chart dataset colours (backgroundColor, borderColor, etc) can be set using CSS via ChartJS-Sass. This JS library will update any unspecified colors with those specified in the CSS and built using SASS. For more details see: https://github.com/mcldev/ChartJS-Sass
- To disable/enable, in
settings.pyaddDJANGOCMS_CHARTS_ENABLE_CHARTJS_SASS = True or False (default=True)
Usage
Chart Types
The following chart types can be selected with options (see below)
- Line
- Line XY (Scatter with line)
- Bar
- Horizontal Bar
- Radar
- Polar
- Pie
- Doughnut
- Bubble
- Scatter
- Mixed (see Multiple Datasets)
Input Data
All input data will be used as below.
NB: Multiple datasets can be added as either:
- Dataset Plugins as child to each Chart Plugin (customisable colours/formats etc)
- Multiple rows or columns within a Chart input table (scriptable colours/formats)
# Line, Bar, Radar, Doughnut, Pie, PolarArea
# ------------------------------------------
# Datasets in 'cols' > TRANSPOSED
# Label_1, Label_2, ...
# Jan-20 10 30
# Feb-20 20 40
# ...
#
# OR
#
# Datasets in 'rows' > USES THIS FORMAT INTERNALLY
# Jan-20 Feb-20, ...
# Label_1 10 20
# Label_2 30 40
# ...
#
# Bubble [r], Scatter, Line_XY
# ----------------------------
# [r - radius - is ignored for line and scatter]
#
# Datasets in 'cols' > TRANSPOSED
# x 10 20 ...
# y 30 40 ...
# [r] 5 10 ...
#
# OR
#
# Datasets in 'rows' > USES THIS FORMAT INTERNALLY
# x, y, [r]
# 10 30 5
# 20 40 10
# ...
Axes
https://www.chartjs.org/docs/latest/axes/
Multiple Axes can be added using X Axis or Y Axis. Each Axis can be used multiple times (e.g. Linear axis). Options for Axes are set below.
Multiple Datasets
https://www.chartjs.org/docs/latest/charts/mixed.html#drawing-order
Multiple datasets can be added as rows/columns of the main chart, or added as Dataset child plugins. The rendering order for ChartJS is that the first dataset is top-most - this plugin prepends the subsequent child datasets so the last dataset is top-most.
Mixed Types
https://www.chartjs.org/docs/latest/charts/mixed.html
Each child Dataset can have a different type, thus creating a Mixed Chart. NB: Some types do not mix well (Radar/Bar etc) - we make no validation on each possible combination.
Dataset Colors
Dataset Color Groups can be specified as a user-friendly list of colors, with a click-and-drag sortable feature.
Specifying the color group
Specifications for each group require the following:
- Type (select multiple types with Ctrl)
- the Chart/Dataset type that these colors will be applied to
- Namespace Labels (select multiple types with Ctrl)
- the dataset namespace labels that will use these colors
- e.g.
backgroundColor, borderColor, pointBackgroundColor, ...
- Colors
- a text list of hex only colors
- these can be selected/edited/rearranged through the interface
Application of Color Groups
These color groups can then be applied as follows:
- Globally
- by assigning the color group to the Global Settings
- any Chart/Dataset (without colors specified) will use these colors
- By Chart
- all of the Chart datasets and any sub-datasets (without colors specified) will have these colors applied
- By Dataset
- any Dataset can specifically use this Color Group
Color By Dataset or Series
The flag to set 'Color by Dataset' will do the following:
- Color by Dataset:
True- Each individual Dataset will use one color from the color array based on its index
- e.g. with a color array of
[red, green, blue]
# Jan-20 Feb-20, ... # Label_1 10 20 <- red # Label_2 30 40 <- green # Label_3 50 60 <- blue - Color by Series:
False- Each individual Dataset will get the full color array to use for each element in Series
- e.g. with a color array of
[red, green, blue]
# Jan-20 Feb-20, ... # Label_1 10 <- red 20 <- green # Label_2 30 <- red 40 <- green # Label_3 50 <- red 60 <- green
Options
https://www.chartjs.org/docs/latest/configuration/
Options are set in JavaScript using the settings provided by ChartJS - Use this documentation: https://www.chartjs.org/docs/latest/
The Options are assigned in ascending order of priority as:
Chart.defaults.global.<option>- see GlobalOptionsGroup in Adminchart.options.<option>- see ChartOptions Group selectable for each chartchart.options.<option>- see ChartSpecificOptions assigned to each chart individuallydataset.<option>- see DatasetOptionsGroup selectable for each datasetdataset.<option>- see DatasetSpecificOptions assigned to each dataset individuallychart.options.scales.<axes>.<option>- see AxisOptionsGroup selectable for each axis
Option Input Types
https://www.chartjs.org/docs/latest/general/options.html
ChartJS accepts various input option formats, some can be scripted, functions, numbers, or text. DjangoCMS Charts options can be input as any one of the following types:
NB. there is no validation of input types - Errors will appear in the console
- text
- Any form of text input, such as a colour. e.g.
#28aece - Sample output:
{"option_name": "#28aece"}
- Any form of text input, such as a colour. e.g.
- number
- Either an integer or float can be input e.g.
2 or 3.5 - A float (with a '.') will be converted to float
- Sample output:
{"option_name": 2}
- Either an integer or float can be input e.g.
- boolean
- Text or number be cast to a boolean, can be any of
'true', 'false', 1, 0 - Sample output:
{"option_name": true}
- Text or number be cast to a boolean, can be any of
- json
- Text to be parsed and loaded as valid Json, e.g.
['red', 'blue', 'green'] - Sample output:
{"option_name": ["red", "blue", "green"]}
- Text to be parsed and loaded as valid Json, e.g.
- array
- Will split a string array into elements using the following (in order):
"\n"(new line)","(comma)"\t"(tab)" "(space)
- Sample input:
red blue green - Sample output:
{"option_name": ["red", "green", "blue"}]
- Will split a string array into elements using the following (in order):
- function
- A js function string that will be cleaned (new lines etc.) and injected into the code.
- Can be a valid function name or complete function without comments
- Sample:
function(context) { var index = context.dataIndex; var value = context.dataset.data[index]; return value < 0 ? 'red' : index % 2 ? 'blue' : 'green'; }
More details on ChartJs
ChartJs is a dynamic JS charting application giving users an interactive and visually appealing chart in an html 5 canvas. Each type of chart is available:
Testing
Install test dependencies
pip install -e ".[test]"
This installs the package in editable mode along with test dependencies:
djangocms-text-ckeditordjango-sekizaidjango-admin-sortable2
Run tests
python -m django test tests --settings=tests.settings
For verbose output:
python -m django test tests --settings=tests.settings -v 2
Tests use an in-memory SQLite database and cover:
- Utility functions (
transpose,get_unique_list,color_variant) - Chart type constants and coordinate type detection
- Options type coercion (text, number, boolean, JSON, array, function)
- Nested options dict building from dot-separated labels
- Color model/group parsing and dict generation
- Axis options group model and axis dict building
- Dataset parsing (rows, columns, scatter coordinates, empty data)
- Chart model properties (slugified names, IDs, width/height helpers)
- Full chart dict generation (
get_chart_as_dict()) - CMS plugin registration (
ChartJsPlugin,DatasetPlugin) - Global options and global colors
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file djangocms_charts-3.1.0.tar.gz.
File metadata
- Download URL: djangocms_charts-3.1.0.tar.gz
- Upload date:
- Size: 874.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
779879d2abac5d9392f2aad0c39620ce88c9d026f1fac5272772e3c209a8189a
|
|
| MD5 |
a7bd4e5de589347c47d9734dac4392b1
|
|
| BLAKE2b-256 |
a2df5846022be8d8ef8837e42dc8b067aa99aafd283806ba4da0d763d3928a56
|
File details
Details for the file djangocms_charts-3.1.0-py3-none-any.whl.
File metadata
- Download URL: djangocms_charts-3.1.0-py3-none-any.whl
- Upload date:
- Size: 896.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7e5359220aed85838d312da1bb117181135ae456bfadc0837821a4a5882a0497
|
|
| MD5 |
9e11ec6536f9346a93099fcea3325a14
|
|
| BLAKE2b-256 |
ebf6ba7ef1aa00d15105831f9df6e72b58ecac87e76aa9a6e50779534009eb83
|