| | 1 | = Admin Básico = |
| | 2 | |
| | 3 | Para exibir uma classe de modelo no Admin (aplicação de administração do site), |
| | 4 | você deve seguir os seguintes passos: |
| | 5 | |
| | 6 | 1. Supondo que sua aplicação se chama "minha_app" que contenha as classes |
| | 7 | "Produto" e "Categoria", edite o arquivo "settings.py" de seu projeto e |
| | 8 | acrescente a seguinte linha à setting INSTALLED_APPS:: |
| | 9 | |
| | 10 | 'django.contrib.admin', |
| | 11 | |
| | 12 | 2. Edite agora o arquivo "urls.py" e remova os comentários (#) das seguintes |
| | 13 | linhas:: |
| | 14 | |
| | 15 | from django.contrib import admin |
| | 16 | admin.autodiscover() |
| | 17 | |
| | 18 | isso irá fazer com que o Django procure por arquivos "admin.py" em todas as |
| | 19 | aplicações de seu projeto automaticamente. Remova os comentários também |
| | 20 | destas linhas:: |
| | 21 | |
| | 22 | (r'^admin/doc/', include('django.contrib.admindocs.urls')), |
| | 23 | (r'^admin/(.*)', admin.site.root), |
| | 24 | |
| | 25 | isso fará com que seu projeto tenha URLs para o sistema de documentação do |
| | 26 | admin e do próprio admin, respectivamente. |
| | 27 | |
| | 28 | 3. Agora crie um arquivo "admin.py" na pasta de sua aplicação e importe o |
| | 29 | módulo do Admin da seguinte maneira:: |
| | 30 | |
| | 31 | from django.contrib import admin |
| | 32 | |
| | 33 | 4. Importe em seguida a(s) classe(s) desejada(s) para ser reconhecida no admin, |
| | 34 | como abaixo:: |
| | 35 | |
| | 36 | from models import Produto, Categoria |
| | 37 | |
| | 38 | 5. Por fim, é preciso registrar a classe de modelo ao site do Admin:: |
| | 39 | |
| | 40 | admin.site.register(Produto) |
| | 41 | admin.site.register(Categoria) |
| | 42 | |
| | 43 | 6. Pronto! Agora rode o "manage.py runserver" e carregue o seu projeto nas URLs |
| | 44 | "/admin/doc/ e "/admin/" para notar que haverá uma seção com o nome de sua |
| | 45 | aplicação contendo ali links para administração das classes registradas. |
| | 46 | |
| | 47 | 7. Agora, para modificar as colunas exibidas para a classe "Produto", vamos |
| | 48 | supor que essa classe possui os campos "descricao", "referencia" e "categoria". |
| | 49 | Portanto edite novamente o arquivo "admin.py" e adicione as seguintes linhas:: |
| | 50 | |
| | 51 | from django.contrib.admin.options import ModelAdmin |
| | 52 | |
| | 53 | class AdminProduto(ModelAdmin): |
| | 54 | list_display = ('descricao', 'referencia', 'categoria') |
| | 55 | |
| | 56 | e modifique a linha de registro da classe:: |
| | 57 | |
| | 58 | admin.site.register(Produto, AdminProduto) |
| | 59 | |
| | 60 | 8. Basta salvar e rodar o site para carregar a página de listagem de produtos |
| | 61 | para verificar que agora as colunas informadas no código serão exibidas na |
| | 62 | ordem especificada. |
| | 63 | |
| | 64 | ---- |
| | 65 | Tire outras dúvidas em nosso [wiki:CookBookPortugues CookBook em Português |