Django

College Event Registration Website

CampusConnect Introduction and Setup Configuring settings file for template, static and media files Setting up Tailwind Creating Custom User Model Creating Super User for CampusConnect Registering Custom User Model Search and Filter for User Model Serving Media Files During Development Categorizing Departments Linking Department with HOD Creating Abstract Model for Event Creating Model for Workshop Customizing Admin Page for Workshop Update in Model AbstractEvent Adding Instructor for Workshop Instructor Model Admin Page Adding Poster Field in Abstract Event Providing Access to HOD Access Update for HOD Restricting HOD Access to Particular Department AbstractEvent On Spot Registration Field Creating Workshop Object Creating and Linking Home Page Displaying Workshop on Home Page Styling Home Page Adding Workshop Detail Page Link Workshop Detail Page Workshop Detail Page Styling Workshop Instructor Details Workshop Detail Contact Contact Admin Page Many to Many Field for Contact Displaying Contact on Workshop Detail Page Adding Title for Workshop Detail Page Adding Gallery for Workshop Workshop Gallery Admin Page Displaying Gallery Images on Website Through Context Displaying Gallery Images on Website through template tags Authentication for users User Registration User Registration Submission Logout Functionality For User Login Functionality for User Model For Workshop Registration Workshop Registration Admin Page Register Workshop Function Register Button in Workshop Page Validations Before Workshop Registration Workshop Registration Closed Validaiton User Already Registered for Workshop Validation Workshop Registration Report From Admin Page Export using Library in Django Admin Extending Abstract Event for Hackathons

Customize Admin Page

The Admin page can be upgraded to provide us with some more features and effectively manage the database.

Instead of just registering a model normally, we can create a class for a model and specify the action that needs to be performed, and then link that class with the particular model. This can be done as follows :

from django.contrib import admin
from .models import *

# Register your models here.

class NoteAdmin(admin.ModelAdmin):
    list_display = ('title', 'description')

admin.site.register(Note, NoteAdmin)

This will provide a result like this : alt textHere instead of just the object name that was passed in the __str__ in the model, the fields that are specified in the list_display variable are displayed on the admin page. Alternatively, the above code can also be written like this

from django.contrib import admin
from .models import *

# Register your models here.
@admin.register(Note)
class NoteAdmin(admin.ModelAdmin):
    list_display = ('title', 'description')

Both the codes will produce the same result.

Also, search fields for the models can be added as follows :

search_fields = ('title', 'description')

alt textIn this example, it will search for the title field and description field. If the search string is present in any of the title or description, then it will display those rows. The search will be case insensitive.