Расширение страницы с помощью tinyMCE django-cms

Привет всем, я создаю расширение страницы, используя документацию Django CMS и работаю отлично,

Теперь у меня есть две text_area на моей странице расширения, я хочу включить библиотеку TinyMCE в мою text_area

для этого у меня есть это в моем models.py

from django.db import models
from cms.extensions import PageExtension
from cms.extensions.extension_pool import extension_pool


class IconExtension(PageExtension):

  image = models.ImageField(upload_to='icons', blank=True)
  description_short = models.TextField(blank=True, null=True, verbose_name="Short Description")
  description_large = models.TextField(blank=True, null=True, verbose_name="Large Description")

extension_pool.register(IconExtension)

и мой admin.py есть это

# from django.forms import *
from django.forms import ModelForm 
from django import forms
from django.db.models import *
from django.contrib import admin
from cms.extensions import PageExtensionAdmin
from tinymce.widgets import TinyMCE


from .models import IconExtension

class IconExtensionForm(forms.ModelForm):
  some_field = forms.CharField(widget=TinyMCE(attrs={'cols': 80, 'rows': 10}))

  class Meta:
    model = IconExtension
    fields = '__all__'


class IconExtensionAdmin(PageExtensionAdmin):
  form = IconExtensionForm

admin.site.register(IconExtension, IconExtensionAdmin)

сейчас я получаю эту ошибку

jquery.tinymce.min.js:1 Uncaught TypeError: Cannot read property 'fn' of undefined(anonymous function) @ jquery.tinymce.min.js:1(anonymous function) @ jquery.tinymce.min.js:1
init_tinymce.js:16 Uncaught ReferenceError: tinyMCE is not defined

мой файл setting.py имеет эту конфигурацию

TINYMCE_JS_URL = os.path.join(STATIC_URL, "tinymce/jquery.tinymce.min.js")
TINYMCE_JS_ROOT = '/static/js/tinymce/'
TINYMCE_DEFAULT_CONFIG = {
    'plugins': "table,spellchecker,paste,searchreplace",
    'theme': "advanced",
}
TINYMCE_SPELLCHECKER = True 

Я ищу решение в интернете, и все говорят, что я загружаю библиотеку jquery раньше... в моем случае мое поле с TinyMCE находится внутри всплывающего окна, страница загружается, всплывающее окно имеет библиотеку jquery во второй раз. первый.

Когда я проверяю элемент внутри всплывающего окна, моя библиотека загрузки

<head>
<title>
Change icon extension | Django site admin</title>
<link rel="stylesheet" type="text/css" href="/static/admin/css/base.css">
<link rel="stylesheet" type="text/css" href="/static/admin/css/forms.css">
<!--[if lte IE 7]><link rel="stylesheet" type="text/css" href="/static/admin/css/ie.css" /><![endif]-->

<script type="text/javascript">window.__admin_media_prefix__ = "/static/admin/";</script>
<script type="text/javascript">window.__admin_utc_offset__ = "\u002D18000";</script>

<meta name="viewport" content="width=device-width,initial-scale=1">
<link rel="stylesheet" type="text/css" href="/static/djangocms_admin_style/css/djangocms-admin.css">

    <script src="/static/djangocms_admin_style/js/dist/bundle.adminstyle.min.js"></script>


    <script type="text/javascript" src="/en/admin/jsi18n/"></script>
    <script type="text/javascript" src="/static/admin/js/core.js"></script>
    <script type="text/javascript" src="/static/admin/js/jquery.js"></script>
    <script type="text/javascript" src="/static/admin/js/jquery.init.js"></script>
    <script type="text/javascript" src="/static/admin/js/admin/RelatedObjectLookups.js"></script>
    <script type="text/javascript" src="/static/admin/js/actions.js"></script>
    <script type="text/javascript" src="/static/tinymce/jquery.tinymce.min.js"></script>
    <script type="text/javascript" src="/static/django_tinymce/jquery-1.9.1.min.js"></script>
    <script type="text/javascript" src="/static/django_tinymce/init_tinymce.js"></script>

    <meta name="robots" content="NONE,NOARCHIVE">
    </head>

Любая идея, как включить tinyMCE в расширение страницы, я в правильном направлении?

1 ответ

Решение

Если нет особых требований к использованию TinyMCE, я бы рекомендовал использовать интеграцию, которая уже встроена в текстовый модуль Django CMS ( CKEditor).

# models.py 

class Model1(models.Model):
    text = HTMLField(configuration='CKEDITOR_SETTINGS_MODEL1')

class Model2(models.Model):
    text = HTMLField(configuration='CKEDITOR_SETTINGS_MODEL2')

# settings.py

CKEDITOR_SETTINGS_MODEL1 = {
    'toolbar_HTMLField': [
        ['Undo', 'Redo'],
        ['ShowBlocks'],
        ['Format', 'Styles'],
        ['Bold', 'Italic', 'Underline', '-', 'Subscript', 'Superscript', '-', 'RemoveFormat'],
    ]
}

CKEDITOR_SETTINGS_MODEL2 = {
    'toolbar_HTMLField': [
        ['Undo', 'Redo'],
        ['Bold', 'Italic', 'Underline', '-', 'Subscript', 'Superscript', '-', 'RemoveFormat'],
    ]
}
Другие вопросы по тегам