Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/vlzh/django-editorjs
Widget of editor.js for django admin
https://github.com/vlzh/django-editorjs
django django-admin editor editorjs
Last synced: 3 months ago
JSON representation
Widget of editor.js for django admin
- Host: GitHub
- URL: https://github.com/vlzh/django-editorjs
- Owner: VLZH
- License: mit
- Created: 2020-07-18T22:14:43.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2021-02-05T18:05:15.000Z (about 4 years ago)
- Last Synced: 2024-08-08T20:53:38.247Z (6 months ago)
- Topics: django, django-admin, editor, editorjs
- Language: JavaScript
- Homepage:
- Size: 36.1 KB
- Stars: 29
- Watchers: 5
- Forks: 12
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# django-editorjs
[data:image/s3,"s3://crabby-images/0b4e5/0b4e569d95251170406154d62c6f2df8e96053d6" alt="GitHub version"](https://badge.fury.io/gh/VLZH%2Fdjango-editorjs)
[data:image/s3,"s3://crabby-images/dea86/dea86dadf35672abdc318b93cde663c693d9549e" alt="PyPi downloads"](https://pypi.org/project/django-editorjs/)Plugin for using [Editor.js](https://editorjs.io/) in django admin.
# Supported plugins/tools
- `@editorjs/paragraph` - [data:image/s3,"s3://crabby-images/4a6ce/4a6ce168af3d08cb6976dcfd1c870e9de35ad8b2" alt="npm version"](https://badge.fury.io/js/%40editorjs%2Fparagraph)
- `@editorjs/image` - [data:image/s3,"s3://crabby-images/71604/7160443f178bbe76229920494aad4d5c8f88f0c5" alt="npm version"](https://badge.fury.io/js/%40editorjs%2Fimage)
- `@editorjs/header` - [data:image/s3,"s3://crabby-images/9d43a/9d43adc9c2e2135a82cc1c907b6dd89ef7781a4e" alt="npm version"](https://badge.fury.io/js/%40editorjs%2Fheader)
- `@editorjs/checklist` - [data:image/s3,"s3://crabby-images/6f1d2/6f1d2c7ce082505137066966708fc5d91726c2c7" alt="npm version"](https://badge.fury.io/js/%40editorjs%2Fchecklist)
- `@editorjs/list` - [data:image/s3,"s3://crabby-images/4d279/4d279f8308761aa76bb0b3abf414aeff70b81d36" alt="npm version"](https://badge.fury.io/js/%40editorjs%2Flist)
- `@editorjs/quote` - [data:image/s3,"s3://crabby-images/0708c/0708c0049b6097f7d7bff664714301867910cd1b" alt="npm version"](https://badge.fury.io/js/%40editorjs%2Fquote)
- `@editorjs/raw` - [data:image/s3,"s3://crabby-images/139b6/139b68e6eb09db7f838af224f0c8b9cb86390201" alt="npm version"](https://badge.fury.io/js/%40editorjs%2Fraw)
- `@editorjs/embed` - [data:image/s3,"s3://crabby-images/a11cd/a11cdd882544aaa28039211550199ddcdd02b0f7" alt="npm version"](https://badge.fury.io/js/%40editorjs%2Fembed)
- `@editorjs/delimiter` - [data:image/s3,"s3://crabby-images/ec4ae/ec4ae904b679daeffc17c9796b3c7bb58cfa624e" alt="npm version"](https://badge.fury.io/js/%40editorjs%2Fdelimiter)
- `@editorjs/warning` - [data:image/s3,"s3://crabby-images/b737a/b737acba40276b8b65e3348e4f0c9a7bbedd3b51" alt="npm version"](https://badge.fury.io/js/%40editorjs%2Fwarning)
- `@editorjs/link` - [data:image/s3,"s3://crabby-images/155c1/155c1dcb75b438531990592d0d36b204872ba661" alt="npm version"](https://badge.fury.io/js/%40editorjs%2Flink)
- `@editorjs/marker` - [data:image/s3,"s3://crabby-images/0fae3/0fae378252ea66c77e337a03da39aebf39421c8c" alt="npm version"](https://badge.fury.io/js/%40editorjs%2Fmarker)
- `@editorjs/attaches` - [data:image/s3,"s3://crabby-images/d0756/d07565b3e2dd440679d7f1d85f1f25f864b94f39" alt="npm version"](https://badge.fury.io/js/%40editorjs%2Fattaches)
- `@editorjs/table` - [data:image/s3,"s3://crabby-images/e31f6/e31f6eb8e2f47bf423368a50c9ed0c60271035f6" alt="npm version"](https://badge.fury.io/js/%40editorjs%2Ftable)> #### ⚠️ Note (for plugin configuration)
>
> Usually in examples for Editor.js you will see tool names starts with lowercase, but for bypass potential conflicts i use uppercase.# Installation
```bash
pip install django-editorjs
```# Simple example
```python
# models.py
from django.db import models
from django_editorjs import EditorJsFieldclass Post(models.Model):
title = models.CharField(max_length=255)
body = EditorJsField()def __str__(self):
return self.title
```# How to configure
You can provide field specific configuration options to `EditorJsField` by argument `editorjs_config`.
#### Example
```python
class Post(models.Model):
title = models.TextField()
body = EditorJsField(
editorjs_config={
"tools": {
"Table": {
"disabled": False,
"inlineToolbar": True,
"config": {"rows": 2, "cols": 3,},
}
}
}
)```
## Config schema
- `tools`
- `Image` - (`dict`) configuration for tool `ImageTool`. (_For more info see official documentation for tool_).
- `Header` - (`dict`) configuration for tool `Header`. (_For more info see official documentation for tool_).
- `Checklist` - (`dict`) configuration for tool `Checklist`. (_For more info see official documentation for tool_).
- `List` - (`dict`) configuration for tool `List`. (_For more info see official documentation for tool_).
- `Quote` - (`dict`) configuration for tool `Quote`. (_For more info see official documentation for tool_).
- `Raw` - (`dict`) configuration for tool `RawTool`. (_For more info see official documentation for tool_).
- `Embed` - (`dict`) configuration for tool `Embed`. (_For more info see official documentation for tool_).
- `Delimiter` - (`dict`) configuration for tool `Delimiter`. (_For more info see official documentation for tool_).
- `Warning` - (`dict`) configuration for tool `Warning`. (_For more info see official documentation for tool_).
- `Link` - (`dict`) configuration for tool `LinkTool`. (_For more info see official documentation for tool_).
- `Marker` - (`dict`) configuration for tool `Marker`. (_For more info see official documentation for tool_).
- `Attaches` - (`dict`) configuration for tool `AttachesTool`. (_For more info see official documentation for tool_).
- `Table` - (`dict`) configuration for tool `Table`. (_For more info see official documentation for tool_).# API
- `EditorJsField`
Extends `TextField` and use `EditorJsWidget` as widget + have additional argument in constructor: `editorjs_config`.
- `EditorJsWidget`
Widget that you can to use for using Editor.js in Django.
# TODO
- load tool on demand
- more examples in README.md
- view-function for file uploading
- view-function for image uploading
- view-function for link info crawler