django-table2 -> как получить многострочную ячейку - PullRequest
0 голосов
/ 31 января 2019

У меня есть один столбец в моей таблице (основанный на классе, а не на классе модели), который является объектом Python Dict, я хотел бы, чтобы ячейки в этом столбце отображались как одна строка для каждой записи dict.

класс, который я отображаю:

class MegaDatapoint:

def __init__(self, id=None,
             name=None,
             display_name=None,
             description=None,
             enum_dict=None,

             ):

    self.id = id
    self.name = name
    self.display_name = display_name
    self.description = description
    self.enum_dict = enum_dict

в моем файле tables.py У меня есть следующее:

class DictColumn(tables.Column):
    def render(self, value):

        if type(value) is dict:
            v = ""
            for d in value:
                v += f"{d}->{value[d]}\n\r"
        else:
            v = "--"
        return v


class MegaTable(tables.Table):

    name = tables.Column()
    display_name = tables.Column()
    description = tables.Column()
    enum_dict = DictColumn(attrs={'td': {' white-space':'pre-wrap'} })

шаблон "megadatapoint_table2.html":

{% extends "base.html" %}
{% load render_table from django_tables2 %}
{% block title %}{{ block.super }}Projects{% endblock %}
{% block container %}
    <div>
        <title>List of Datapoints</title>
        <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" />
    </div>
    <div>
        {% render_table table %}
    </div>
{% endblock %}

И, наконец, представление:

class MegadatapointTableView(SingleTableView):
table_class = MegaDatapointTable
template_name = 'megadatapoint_table2.html'


def get_queryset(self):

    """
    Return the product features for this product
    """
    self.enums = Enumeration.objects.all().order_by('enumeration_group')
    self.enum_values_dict = {}
    for enum in self.enums:

        if enum.enumeration_group.id not in self.enum_values_dict:
            self.enum_values_dict[enum.enumeration_group.id] = {}
        self.enum_values_dict[enum.enumeration_group.id][enum.ordinal] = enum.name
    self.m_dp_list = []

    for dp in Datapoint.objects.all():
        dp_enum_dict = None
        if dp.enumeration_group is not None:
            if dp.enumeration_group.id in self.enum_values:
                dp_enum_dict = self.enum_values_dict[dp.enumeration_group.id]
            else:
                dp_enum = f"opps, no enumeration in DB->{dp.enumeration_group.id}"
        else:
            dp_enum = ""

        mdp = MegaDatapoint(id=dp.id,
                            name=dp.name,
                            display_name=dp.display_name,
                            description=dp.description,
                            enum_dict=dp_enum_dict,

                            )
        self.m_dp_list.append(mdp)

    return self.m_dp_list

атрибуты столбцов отображаются в HTML, но не отображаются для получения нескольких строк.

Любые подсказки или помощь будут оценены ...

1 Ответ

0 голосов
/ 31 января 2019

нашел решение, откажитесь от пользовательского столбца, используйте «TemplateColumn» с «{{record.enum | linebreaksbr}}» в качестве шаблона.И, на мой взгляд, используйте вместо dict строку с '\ n' между записями dict.

Таким образом, новый enum gen в представлении:

    self.enums = Enumeration.objects.all().order_by('enumeration_group','ordinal')
    self.enum_values = {}
    for enum in self.enums:

        if enum.enumeration_group.id in self.enum_values:
            self.enum_values[enum.enumeration_group.id] += f"\n{enum.ordinal}->{enum.name }"
        else:
            self.enum_values[enum.enumeration_group.id] = f"{enum.ordinal}->{enum.name }"

И новыйТаблица:

class MegaDatapointTable(tables.Table):

   name = tables.Column(linkify=("fele:datapoints_detail", {"pk": tables.A("id")}))
   display_name = tables.Column()
   description = tables.Column()
   enum_group = tables.TemplateColumn("{{record.enum_group|linebreaksbr }}")

Я думаю, что это немного чище ....

...