Настройка страницы индекса администратора Django для отображения объектов модели

на странице индекса администратора Django приложение и его модели обычно указан. Как объекты модели также могут быть перечислены на этой странице индекса? Вместо того, чтобы отображать только приложение, я хочу также отображать его объекты модели. Как его следует подгонять?

enter image description here

3 ответов


Я хотел ту же функциональность для моего сайта и добавил его, сделав небольшие изменения в основной системе django.

Шаг 1: Сначала нам нужен способ указать, какие модели должны иметь перечисленные свойства. Добавьте следующий код к моделям, для которых вы хотите, чтобы перечисленные экземпляры (в models.py):

class Meta:
    list_instances = True

Шаг 2: Нам нужно изменить Django, чтобы распознать и прочитать этот новый атрибут. В файле core-django: db/models/options.py, примерно в строке 22 добавьте 'list_instances' к DEFAULT_NAMES:

DEFAULT_NAMES = ('verbose_name', 'verbose_name_plural', 'db_table', 'ordering',
             'unique_together', 'permissions', 'get_latest_by',
             'order_with_respect_to', 'app_label', 'db_tablespace',
             'abstract', 'managed', 'proxy', 'auto_created', 'list_instances')

и в том же файле, примерно в строке 52, создайте поле по умолчанию для этого атрибута сразу после других атрибутов:

self.list_instances = False

Шаг 3: Нам нужно передать эту информацию вместе с шаблоном, который генерирует страницу индекса. В файле core-django: contrib/admin/sites.py, внутри метода index () и внутри части "if has_module_perms:" добавьте следующее код:

instances = []
if (model._meta.list_instances == True):
    instances = model_admin.queryset(None)

это создаст список экземпляров для отображения, но только если установлен атрибут list_instance. В том же файле, несколькими строками ниже, добавьте эти значения в конструкцию "model_dict".

model_dict = {
    'name': capfirst(model._meta.verbose_name_plural),
    'admin_url': mark_safe('%s/%s/' % (app_label, model.    __name__.lower())),
    'perms': perms,
    'list_instances':model._meta.list_instances,
    'instances': instances,
}

Шаг 4: Последним шагом является изменение шаблона для поддержки этого. Либо отредактируйте файл core-django / contrib/admin/templates/admin / index.html или скопируйте этот файл в каталог templates / admin / вашего приложения. Добавить несколько строки после стандартного кода для генерации строк для генерации "подстрок", если это применимо. Примерно в строке 40, прямо между "/tr> "и" {%endfor%}":

{% if model.list_instances %}
    {% for instance in model.instances %}
    <tr>
        <td colspan="2" style="padding-left: 2em;">{{ instance }}</td>
        {% if model.perms.change %}
            <td><a href="{{ model.admin_url }}{{ instance.id }}/" class="changelink">{% trans 'Change' %}</a></td>
        {% else %}
            <td>&nbsp;</td>
        {% endif %}
    </tr>
    {% endfor %}
{% endif %}

это приведет к тому, что элемент будет указан с именем, сгенерированным unicode() метод в модели.

Шаг 5: Глядь! Это должно выглядеть примерно так:

enter image description here

изменить: Шаг 6: Если вы хотите имена экземпляров, которые также можно щелкнуть, просто измените шаблон (индекс.HTML) и заменить:

<td colspan="2" style="padding-left: 2em;">{{ instance }}</td>

С:

<td colspan="2" style="padding-left: 2em;">        
    {% if model.perms.change %}            
        <a href="{{ model.admin_url }}{{ instance.id}}">{{ instance }}</a>
    {% else %}
        {{ instance }}
    {% endif %}
</td>

вы можете сделать это, изменив различные шаблоны администратора-корневой называется app_index.html и управляет тем, что она отображается там. Лучший способ исследовать, что происходит, - установить django-debug-toolbar, а затем посмотреть шаблоны, используемые для каждого представления, чтобы выяснить, как настроить.


обновить Setomidor ответ для django 10

всегда здорово вернуться к этому чистому решению!

Шаг 2-это вокруг линии 125 (было 52)

Шаг 3-в sites.py -обновить новый метод -

_build_app_dict

внутри цикла for : for model, model_admin in models.items():

добавить Шаг 3, Как сказано вокруг строк 430 и 460

instances = []


if (model._meta.list_instances == True):
    instances = model_admin.get_queryset(None)