Плагин Django-CMS не отображается в доступных плагинах

#python #django #django-cms

#python #django #django-cms

Вопрос:

Я пытался написать плагин Django CMS, но он не отображается в разделе «Доступные плагины» на странице редактирования, и я очень не уверен, почему, поскольку я прочитал источник еще нескольких плагинов, пытаясь понять, что я сделал не так. Как будто Django-CMS не зарегистрировал плагин.

Структура каталогов:

 /linkrotator
  __init__.py
  admin.py
  cms_plugins.py
  links.html
  models.py
  tests.py
  views.py
  

cms_plugins.py

 from cms.plugin_base import CMSPluginBase
from cms.plugin_pool import plugin_pool
from linkrator.models import LinksPlugin as LinksPluginModel

class LinkListPlugin(CMSPluginBase):
    text_enabled = True
    model = LinkListPluginModel
    render_template = "linkrotator/links.html"

    def render(self, context, instance, placeholder):
        context.update({'instance':instance})
        return context

plugin_pool.register_plugin(LinkListPlugin)
  

models.py

 from django.db import models
from cms.models import CMSPlugin

class LinkListPlugin(CMSPlugin):
    linklist = models.ForeignKey('linkrotator.LinkListList', related_name='plugins')

    def __unicode__( self ):
        return self.linklist.name

class Link(models.Model):
    name = models.CharField( max_length = 140 )
    in_list = models.ForeignKey( 'linkrotator.LinkList' )
    link = models.URLField()

    def __unicode__(self):
        return self.name

class LinkList(models.Model):
    name = models.CharField( max_length = 140 )
    in_list = models.ForeignKey('linkrotator.LinkListList', blank = True, null = True, on_delete=models.SET_NULL)

    def __unicode__(self):
        return self.name

class LinkListList(models.Model):
    name = models.CharField( max_length = 140 )
    number_of_links = models.IntegerField()

    def __unicode__(self):
        return self.name
  

settings.py

 # -*- coding: utf-8 -*-
import os

gettext = lambda s: s

PROJECT_DIR = os.path.abspath(os.path.dirname(__file__))

DEBUG = True
TEMPLATE_DEBUG = DEBUG

ADMINS = (
    # ('Your Name', 'your_email@domain.com'),
)

MANAGERS = ADMINS

LANGUAGES = [('en', 'en')]
DEFAULT_LANGUAGE = 0

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': os.path.join(PROJECT_DIR, 'mycms.db'),
    }
}

# Local time zone for this installation. Choices can be found here:
# http://en.wikipedia.org/wiki/List_of_tz_zones_by_name
# although not all choices may be available on all operating systems.
# On Unix systems, a value of None will cause Django to use the same
# timezone as the operating system.
# If running in a Windows environment this must be set to the same as your
# system time zone.
TIME_ZONE = 'America/Chicago'

# Language code for this installation. All choices can be found here:
# http://www.i18nguy.com/unicode/language-identifiers.html
LANGUAGE_CODE = 'en-us'

SITE_ID = 1

# If you set this to False, Django will make some optimizations so as not
# to load the internationalization machinery.
USE_I18N = True

# If you set this to False, Django will not format dates, numbers and
# calendars according to the current locale
USE_L10N = True

# Absolute filesystem path to the directory that will hold user-uploaded files.
# Example: "/home/media/media.lawrence.com/"
MEDIA_ROOT = os.path.join(PROJECT_DIR, 'media')

# URL that handles the media served from MEDIA_ROOT. Make sure to use a
# trailing slash if there is a path component (optional in other cases).
# Examples: "http://media.lawrence.com", "http://example.com/media/"
MEDIA_URL = '/media/'

# URL prefix for admin media -- CSS, JavaScript and images. Make sure to use a
# trailing slash.
# Examples: "http://foo.com/media/", "/media/".
ADMIN_MEDIA_PREFIX = '/media/admin/'

# Make this unique, and don't share it with anybody.
SECRET_KEY = '0r6%7gip5tmez*vygfv u14h@4lbt^8e2^26o#5_f_#b7%cm)u'

# List of callables that know how to import templates from various sources.
TEMPLATE_LOADERS = (
    'django.template.loaders.filesystem.Loader',
    'django.template.loaders.app_directories.Loader',
)

MIDDLEWARE_CLASSES = (
    'django.middleware.common.CommonMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'cms.middleware.page.CurrentPageMiddleware',
    'cms.middleware.user.CurrentUserMiddleware',
    'cms.middleware.toolbar.ToolbarMiddleware',
    'cms.middleware.media.PlaceholderMediaMiddleware',
)

TEMPLATE_CONTEXT_PROCESSORS = (
    'django.core.context_processors.auth',
    'django.core.context_processors.i18n',
    'django.core.context_processors.request',
    'django.core.context_processors.media',
    'cms.context_processors.media',
)

CMS_TEMPLATES = (
    ('example.html', 'Example Template'),
)

ROOT_URLCONF = 'urls'

TEMPLATE_DIRS = (
    os.path.join(PROJECT_DIR, 'templates'),
)

INSTALLED_APPS = (
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.sites',
    'django.contrib.messages',
    'django.contrib.admin',
    'cms',
    'menus',
    'mptt',
    'appmedia',
    'south',
    'cms.plugins.text',
    'cms.plugins.picture',
    'cms.plugins.link',
    'cms.plugins.file',
    'cms.plugins.snippet',
    'cms.plugins.googlemap',
    'snippetology',
    'linkrotator'
)
  

Комментарии:

1. можете ли вы также вставить свой файл настроек?

2. @ojii — Добавлено, хотя я ничего не сделал с базовым плагином django-cms, кроме добавления двух плагинов (моего и другого).

Ответ №1:

Проблема заключается в ошибке импорта в вашем cms_plugins.py . У вас есть from linkrator.models import LinksPlugin as LinkListPluginModel , так и должно быть from linkrotator.models import LinkListPluginModel . Вы также должны задать имя в LinkListPlugin, иначе имя будет пустым, когда оно появится в разделе доступные плагины. Предоставляя нам:

 from linkrotator.models import LinkListPluginModel

class LinkListPlugin(CMSPluginBase):
    name = 'Link rotator'
    text_enabled = True
    model = LinkListPluginModel
    render_template = "linkrotator/links.html"

    def render(self, context, instance, placeholder):
        context.update({'instance':instance})
        return context
  

Вообще говоря, если у вас возникли проблемы с загрузкой плагинов, откройте оболочку Django и попробуйте импортировать cms_plugins.py модуль из приложения вызывает проблемы.

Комментарии:

1. Я обнаружил другую проблему после того, как исправил импорт и обновил ваш пост. Спасибо за помощь. 🙂

2. Наконец, я нахожу этот ответ после нескольких часов отладки. Было бы неплохо, если бы плагины CMS лучше сообщали об ошибках.

3. Грррррр. Код, который беззвучно проглатывает ошибки исключений, должен быть вынесен наружу и удален.

Ответ №2:

Я думаю, что ваш шаблон должен быть в папке

 linkrotator/templates/linkrotator/links.html
  

ваша структура будет выглядеть следующим образом

 linkrotator
    templates
        linkrotator
            links.html
    __init__.py
    admin.py
    cms_plugins.py
    models.py
    tests.py
    views.py
  

Также я думаю, что вашему плагину нужен атрибут namehttp://django-cms.readthedocs.org/en/2.1.3/extending_cms/custom_plugins.html#cms-plugins-py

Комментарии:

1. отсутствие шаблонов не приведет к тому, что плагин не будет зарегистрирован

2. Ого! вероятно, вы правы. Более вероятно, что он выдаст исключение.