来自 cms_title 的 Django CMS 自定义插件加载数据

Django CMS custom plugin load data from cms_title

我想为 Django CMS 创建一个自定义插件。正如 guide 所示,我创建了一些示例。但现在的目标是创建一个插件,它将从 (mysql) 数据库中获取数据。它将加载属于菜单的所有标题,因为我想要一些类似于 table 的内容。

要从自定义模型中获取数据,代码如下:

从 cms.plugin_base 导入 CMSPluginBase

from cms.plugin_pool import plugin_pool

from django.utils.translation import ugettext_lazy as _
from .models import Hello

class HelloPlugin(CMSPluginBase):
    model = Hello
    name = _("Hello Plugin")
    render_template = "hello_plugin.html"
    cache = False

    def render(self, context, instance, placeholder):
        context = super(HelloPlugin, self).render(context, instance, placeholder)
        return context

plugin_pool.register_plugin(HelloPlugin)

但由于cms_title默认属于Django-CMS,这里有哪些可能的选项?在哪里可以找到名称为 Title 的 CMS 模型的定义?将其设置为 CMSPlugin 实例会不会是一种糟糕的方式?

好吧,经过几个小时的努力,我终于成功地解决了我的问题。

首先回答题中CMS模型和参数标题部分(in db: cms_title)。使用 FK to CMS title 创建一个新模型是正确的方法。 在 models.py:

class TitlePlugin(CMSPlugin):
        title = models.ForeignKey(Title)

接下来,你需要将它导入到cms_plugins.py,所以它看起来像这样:

from .models import TitlePlugin

 class MyTitlePluginClass(CMSPluginBase):
    model = TitlePlugin
    render_template = "titles.html"
    cache = False

如您所见,我们加载的模型是 TitlePlugin,我们在 models.py 中定义(它与原始 cms_title 有 FK)。

现在,渲染它:

def render(self, context, instance, placeholder):

    context = super(MyTitlePluginClass, self).render(context, instance, placeholder)
    return context

但我的目标是为了 'table of contents' 将其加载到模板中,对吗?所以我不得不改变一些东西。

我删除了 models.py 内容(不需要!)

新的 cms_plugins.py 也有修改: 第一个:

from cms.models.pagemodel import Page
#we import the Page model

和更新后的class:

class MyTitlePluginClass(CMSPluginBase):
    model = CMSPlugin
    render_template = "titles.html"
    cache = False

def render(self, context, instance, placeholder):
    pages = Page.objects.filter(in_navigation=True, publisher_is_draft=False)

    #context = {
    #'pages' : pages,
    #}
    # edit: append to 'pages' existing list!
    context['pages'] = pages

    context = super(MyTitlePluginClass, self).render(context, instance, placeholder)
    return context

plugin_pool.register_plugin(MyTitlePluginClass)

在模板中,我们简单地使用 for 循环打印它 titles.html:

{% for page in pages %}
<div class="panel callout ">
    {{ page }}
</div>
{% endfor %}