3

Django 管理パネルにアップロードした写真を、パスではなくサムネイルとして表示しようとしています。私は sorl をインストールしており、ビューに表示されるサムネイルを作成できます。

実装しようとした2 つのスニペット ( http://www.djangosnippets.org/snippets/579/http://www.djangosnippets.org/snippets/934/ ) を見つけましたが、どちらの試みも失敗しました。貧弱なドキュメントと、Django フレームワークに対する私のまだ浅い理解。

誰かがこれを機能させる方法のステップバイステップガイドを提供してもらえますか?

ありがとう!

4

2 に答える 2

15

これが古い投稿であることは承知していますが、上記の管理テンプレートのオーバーライド方法よりも短い方法を見つけた可能性があると思います (これは非常に素晴らしい解決策ですが、別の状況で使用する必要があります)。これは、sorl 関数を直接呼び出してサムネイルを生成するだけです。

myapp/admin.py 内

from myapp import models
from sorl.thumbnail import default
ADMIN_THUMBS_SIZE = '60x60'

class MyModelAdmin(admin.ModelAdmin):
    model = models.MyModel
    list_display = ['my_image_thumb', 'my_other_field1', 'my_other_field2', ]

    def my_image_thumb(self, obj):
        if obj.image:
            thumb = default.backend.get_thumbnail(obj.image.file, ADMIN_THUMBS_SIZE)
            return u'<img width="%s" src="%s" />' % (thumb.width, thumb.url)
        else:
            return "No Image" 
    my_image_thumb.short_description = 'My Thumbnail'
    my_image_thumb.allow_tags = True

これは次の質問に基づいていますが、sorl 機能を追加しました。

Django 管理者とサムネイル画像の表示

于 2010-11-30T00:46:06.570 に答える
4

ええ:)私はできます;)

まず、サムネイルを処理するカスタムテンプレートタグを作成する必要があります。

from django.template import Library
from django.utils.safestring import mark_safe
from django.contrib.admin.templatetags.admin_list import result_headers

register = Library()

def results(cl):
    out = []
    for item in cl.result_list:
        url = cl.url_for_result(item)
        code = '<a href="%(url)s">%(img)s</a> <div><a href="%(url)s">%(title)s</a></div>' % {
            'url': url,
            'img': item.preview.thumbnail_tag,
            'title': item.title,
        }
        out.append(mark_safe(code))

    return out

def gallery_result_list(cl):    
    return {'cl': cl,
            'result_headers': list(result_headers(cl)),
            'results': results(cl)}
result_list = register.inclusion_tag("admin/app_name/model/change_list_results.html")(gallery_result_list)

ここで、item.preview.thumbnail_tagは、sorlによって作成されたサムネイルです:)[デフォルトのテンプレートタグから元のコードを取得しました]

次に、モデルのテンプレート(新しいカスタムテンプレートタグを使用)を作成する必要があります。このテンプレートは、次のディレクトリスキーマにある必要があります:templates_dir / admin / app_name / model / change_list.html

次のコードがあります。

{% extends "admin/change_list.html" %}
{% load adminmedia admin_list my_admin_tags i18n %}

{% block result_list %}
    {% if action_form and actions_on_top and cl.full_result_count %}{% admin_actions %}{% endif %}
    {% gallery_result_list cl %}
    {% if action_form and actions_on_bottom and cl.full_result_count %}{% admin_actions %}{% endif %}
{% endblock %}

タグ関数でわかるように、画像を正しく表示するには、もう1つのテンプレート(change_list_result.htmlと呼ばれる)を作成する必要があります。

<style>
td.page { text-align: center; }
td.page a { font-weight: bold; }
</style>
{% if results %}
<table cellspacing="0">
<tbody>
<tr>
{% for result in results %}
    <td class="page">
        {{ result }}
    </td>
    {% if forloop.counter|divisibleby:3 %}
</tr><tr>
    {% endif %}
{% endfor %}
</tr>
</tbody>
</table>
{% endif %}

したがって、最後に3つのファイルがあります。

  1. テンプレート_dir/admin / app_name / model_name / change_list.html
  2. template_dir / admin / app_name / model_name / change_list_result.html
  3. your_project / app_name / templatetags / my_admin_tags.py

そしてもちろん、テンプレートタグは設定でINSTALLED_APPに追加する必要があります;)

これがすべてです;)これがお役に立てば幸いです。

于 2010-02-01T18:30:31.153 に答える