Skip to main content

integration for Inline HTML editor

Project description

coop HTML Editor

What is coop_html_editor good for?

coop_html_editor is a backend for using inline HTML editor into a Django site. It enables inline editing for your HTML content. It includes a django Form and a Widget helper. It supports Aloha Editor and CK Editor

Quick start

In settings.py, add ‘coop_html_editor’ to the INSTALLED_APPS In urls.py add (r'^html-editor/', include('coop_html_editor.urls')) to your urlpatterns

Then create a form. For example something like

import floppyforms.__future__ as floppyforms
from models import Note
from coop_html_editor.widgets import get_inline_html_widget

class NoteForm(floppyforms.ModelForm):
    class Meta:
        model = Note
        fields = ('text',)
        widgets = {
            'text': get_inline_html_widget(),
        }

Let’s assume that you’ve a form variable pointing on an instance of a NoteForm. In the template file, call the form and don’t forget to put {{form.media}} in the headers.

Settings

The following constants can be set in your django project settings.py

You can choose between 2 HTML editors : Aloha editor or CkEditor. We recommend to use CkEditor but keep Aloha by default for compatibility. Add one the 2 lines below in your settings.py

In settings:

COOP_HTML_EDITOR = 'aloha'
COOP_HTML_EDITOR = 'ck-editor'

You can tune your editor by changing the settings below. The values in this README correspond to defaults

For both, we package a default version than can be overriden by copying your own version folder in ste static files and define the new version by

In settings:

ALOHA_VERSION = "aloha.0.23.26"
CKEDITOR_VERSION = "ckeditor.4.6.2"

The initialisation code of the editor is set in a javascript file. You can change the file to use by seetings

In settings:

ALOHA_INIT_JS_TEMPLATE = "html_editor/aloha_init.js"
CKEDITOR_INIT_JS_TEMPLATE = "html_editor/ckeditor-init.js"

If you choose CkEditor, you can add your own styles

In settings:

CKEDITOR_CSS_CLASSES = [
     "{name: 'Highlight', element: 'span', attributes: {'class': 'highlight'}}",
     "{name: 'Red Title', element: 'h3', styles: {color: '#880000'}}",
]

InlineHtmlInput has a “provider” that allows you to add local links to your models (articles, contacts, whatever) easily, through an autocomplete field that will search for objects based on rules you defined for each model :

  • search this kind of models using get_absolute_url()

  • search this kind of models using another method

  • search this kind of models using a specified model field

You can set the HTML_EDITOR_LINK_MODELS setting in your settings.py to tell which django models will be available in the auto-complete field of the “add link” widget like this

HTML_EDITOR_LINK_MODELS = ('coop_local.Article', 'calendar.Event', )

djaloha requires jquery and is provided by default with jquery.1.7.2. You can change the jquery version if needed

HTML_EDITOR_JQUERY = 'js/jquery.1.7.2.js'

Aloha has a nice plugin architecture. coop_html_editor includes by default the main Aloha plugins. You may want to have a different set of plugins. Please refer to the Aloha docs for more information on plugins

ALOHA_PLUGINS = (
    "common/format",
    "common/highlighteditables",
    "common/list",
    "common/link",
    "common/undo",
    "common/paste",
    "common/commands",
    "common/image",
    "common/align",
    "extra/attributes",
    "common/characterpicker",
    "common/abbr",
    "common/horizontalruler",
    "common/table",
    "extra/browser",
)

Please note that the ALOHA_PLUGINS setting is a global setting. If you need to change the set of plugins for a specific form field, you can pass a similar tuple in the aloha_plugins attribute of your coop_html_editor widget. The extra_aloha_plugins attribute will add additional plugins to the default set.

HTML_EDITOR_INIT_URL setting make possible to overload the aloha init file of djaloha. html_editor_init_url attribute of InlineHtmlInput can also be used to overload it for a specific form field.

License

coop_html_editor is based on apidev-djaloha is a fork from credis/djaloha (see http://github.com/credis/djaloha)

coop_html_editor uses the BSD license. see license.txt

Djaloha development was funded by CREDIS, FSE (European Social Fund) and Conseil Regional d’Auvergne.

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

coop_html_editor-1.4.1.tar.gz (1.1 MB view details)

Uploaded Source

Built Distribution

coop_html_editor-1.4.1-py3-none-any.whl (1.4 MB view details)

Uploaded Python 3

File details

Details for the file coop_html_editor-1.4.1.tar.gz.

File metadata

  • Download URL: coop_html_editor-1.4.1.tar.gz
  • Upload date:
  • Size: 1.1 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.9

File hashes

Hashes for coop_html_editor-1.4.1.tar.gz
Algorithm Hash digest
SHA256 d771d75fdb516638f70a256803b3b7e87fbb1639c525701f7aff5633e0584ae6
MD5 40de4f95055658c9411087644a2f3d60
BLAKE2b-256 693d1de7d1fc284c09c0c8cb73e7c6aefff47655664f32ac93e608ff9e83a140

See more details on using hashes here.

File details

Details for the file coop_html_editor-1.4.1-py3-none-any.whl.

File metadata

File hashes

Hashes for coop_html_editor-1.4.1-py3-none-any.whl
Algorithm Hash digest
SHA256 842227c3036ba48f5790a1cfdd8832e3ff98d1262d751d3af705d42fd7a33bdc
MD5 36abb0c85156f4ec154532f671f4b751
BLAKE2b-256 39d3e5bacf808d601ec86a4677eb7b3e06e2f179114b0026635da9f52af60159

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page