Python Django CMS插件是';t显示在可用的插件中
我一直在尝试写一个Django CMS插件,但它没有出现在页面编辑的“可用插件”中,我非常不确定为什么,因为我已经阅读了另外几个插件的源代码,试图看看我做错了什么。就好像Django CMS没有注册插件一样 目录结构:Python Django CMS插件是';t显示在可用的插件中,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\u plugins.py from cms.plugin_base
/linkrotator
__init__.py
admin.py
cms_plugins.py
links.html
models.py
tests.py
views.py
cms\u 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)
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
# -*- 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'
)
models.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)
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
# -*- 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'
)
settings.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)
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
# -*- 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'
)
我认为你的模板需要放在一个文件夹里
linkrotator/templates/linkrotator/links.html
你的结构看起来像
linkrotator
templates
linkrotator
links.html
__init__.py
admin.py
cms_plugins.py
models.py
tests.py
views.py
另外,我认为你的插件需要一个name属性,问题是你的cms_plugins.py中有一个导入错误。如果从linkrator.models导入LinksPlugin作为LinkListPluginModel,则应从linkrotator.models导入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 shell,然后尝试从应用程序中导入cms_plugins.py模块,从而导致问题。您也可以粘贴设置文件吗?@ojii-添加,但除了添加两个插件(我的和另一个)之外,我还没有对基本的Django cms模块做任何操作。缺少模板不会导致插件未注册。ddoh!你可能是对的。更可能引发异常。在更正导入并更新您的帖子后,我发现了另一个问题。谢谢你的帮助。:)经过数小时的调试,我终于找到了这个答案。如果CMS插件在报告错误方面做得更好,那就太好了。无声地吞咽异常错误的代码应该被带到外面拍摄。