Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Draft] Add Events Module #169

Open
wants to merge 17 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions corpus/corpus/settings.py
Original file line number Diff line number Diff line change
Expand Up @@ -66,6 +66,7 @@
"robotrix.apps.RobotrixConfig",
"farewell.apps.FarewellConfig",
"virtual_expo.apps.VirtualExpoConfig",
"events.apps.EventsConfig",
"blog",
]

Expand Down
1 change: 1 addition & 0 deletions corpus/corpus/urls.py
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,7 @@
path("virtual_expo/", include("virtual_expo.urls")),
path("blog/", include("blog.urls")),
path("athenaeum/", include("athenaeum.urls")),
path("events/", include("events.urls")),
]

if settings.DEBUG:
Expand Down
Empty file added corpus/events/__init__.py
Empty file.
8 changes: 8 additions & 0 deletions corpus/events/admin.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
from django.contrib import admin
from .models import *
# Register your models here.
admin.site.register(Event)
admin.site.register(Volunteer)
admin.site.register(Budget)
admin.site.register(Report)
admin.site.register(EventCategory)
6 changes: 6 additions & 0 deletions corpus/events/apps.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
from django.apps import AppConfig


class EventsConfig(AppConfig):
default_auto_field = 'django.db.models.BigAutoField'
name = 'events'
39 changes: 39 additions & 0 deletions corpus/events/forms.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
from django import forms
from corpus.forms import CorpusModelForm
from .models import Event

class EventForm(CorpusModelForm):
required_css_class = 'required-field'

def __init__(self, *args, **kwargs):
super().__init__(*args, **kwargs)
# Add an asterisk (*) to the labels of required fields
for field_name, field in self.fields.items():
if field.required:
if field.label:
field.label = f"{field.label} *"
else:
field.label = "*"

def clean(self):
cleaned_data = super().clean()
start_time = cleaned_data.get('start_time')
end_time = cleaned_data.get('end_time')

if start_time and end_time and start_time > end_time:
raise forms.ValidationError("Start time cannot be later than end time!")

class Meta:
model = Event
fields = "__all__"
exclude = ["created_by"]
widgets = {
yukitya-1811 marked this conversation as resolved.
Show resolved Hide resolved
'start_time': forms.DateTimeInput(attrs={'type': 'datetime-local'}),
'end_time': forms.DateTimeInput(attrs={'type': 'datetime-local'}),
'poc': forms.SelectMultiple(attrs={
'class': 'form-multiselect',
}),
'society': forms.SelectMultiple(attrs={
'class': 'form-multiselect',
}),
}
96 changes: 96 additions & 0 deletions corpus/events/migrations/0001_initial.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,96 @@
# Generated by Django 4.2.7 on 2024-10-27 06:23

from django.db import migrations, models
import django.db.models.deletion
import django.utils.timezone


class Migration(migrations.Migration):

initial = True

dependencies = [
('accounts', '0007_alter_executivemember_date_joined'),
('config', '0004_sig_society_sigs'),
]

operations = [
migrations.CreateModel(
name='Event',
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('title', models.CharField(max_length=128)),
('description', models.TextField()),
('start_time', models.DateTimeField()),
('end_time', models.DateTimeField()),
('registration_url', models.URLField(blank=True)),
('meeting_url', models.URLField(blank=True)),
('instagram_url', models.URLField(blank=True)),
('linkedin_url', models.URLField(blank=True)),
('location', models.CharField(max_length=32)),
('visibility', models.CharField(choices=[('INTERNAL', 'Internal'), ('EXTERNAL', 'External')])),
('created_at', models.DateTimeField(default=django.utils.timezone.localtime)),
],
),
migrations.CreateModel(
name='EventCategory',
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('name', models.CharField(max_length=200)),
],
options={
'verbose_name_plural': 'Event Categories',
},
),
migrations.CreateModel(
name='Volunteer',
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('event', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='events.event')),
('exec_member', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='accounts.executivemember')),
],
),
migrations.CreateModel(
name='Report',
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('objective', models.CharField(max_length=128)),
('description', models.TextField()),
('resources', models.JSONField(null=True)),
('student_turnout', models.IntegerField()),
('faculty_turnout', models.IntegerField(null=True)),
('photo_1', models.ImageField(upload_to='')),
('photo_2', models.ImageField(upload_to='')),
('iic_report_url', models.URLField(null=True)),
('dsw_report_url', models.URLField(null=True)),
('created_at', models.DateTimeField()),
('event', models.OneToOneField(on_delete=django.db.models.deletion.CASCADE, to='events.event')),
],
),
migrations.AddField(
model_name='event',
name='category',
field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='events.eventcategory'),
),
migrations.AddField(
model_name='event',
name='poc',
field=models.ManyToManyField(related_name='events', to='accounts.executivemember'),
),
migrations.AddField(
model_name='event',
name='society',
field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='config.society'),
),
migrations.CreateModel(
name='Budget',
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('item', models.CharField(max_length=255)),
('description', models.TextField()),
('cost', models.DecimalField(decimal_places=2, max_digits=12)),
('source', models.URLField()),
('event', models.OneToOneField(on_delete=django.db.models.deletion.CASCADE, to='events.event')),
],
),
]
Original file line number Diff line number Diff line change
@@ -0,0 +1,60 @@
# Generated by Django 4.2.7 on 2024-12-06 19:15

from django.db import migrations, models
import django.db.models.deletion


class Migration(migrations.Migration):

dependencies = [
('config', '0004_sig_society_sigs'),
('accounts', '0007_alter_executivemember_date_joined'),
('events', '0001_initial'),
]

operations = [
migrations.AddField(
model_name='event',
name='created_by',
field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='created_events', to='accounts.executivemember'),
),
migrations.AddField(
model_name='event',
name='parent_event',
field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, related_name='sub_events', to='events.event'),
),
migrations.AddField(
model_name='event',
name='updated_at',
field=models.DateTimeField(auto_now=True),
),
migrations.AddField(
model_name='report',
name='created_by',
field=models.ForeignKey(null=True, on_delete=django.db.models.deletion.DO_NOTHING, related_name='report_creator', to='accounts.executivemember'),
),
migrations.AlterField(
model_name='event',
name='created_at',
field=models.DateTimeField(auto_now_add=True),
),
migrations.RemoveField(
model_name='event',
name='society',
),
migrations.AlterField(
model_name='event',
name='title',
field=models.CharField(max_length=200),
),
migrations.AlterField(
model_name='event',
name='visibility',
field=models.CharField(choices=[('i', 'Internal'), ('e', 'External')], max_length=8),
),
migrations.AddField(
model_name='event',
name='society',
field=models.ManyToManyField(to='config.society'),
),
]
Empty file.
68 changes: 68 additions & 0 deletions corpus/events/models.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,68 @@
from django.db import models
from config.models import Society
from accounts.models import ExecutiveMember
from django.utils import timezone

# Create your models here.
class EventCategory(models.Model):
name = models.CharField(max_length=200, null=False)

def __str__(self):
return f"{self.name}"

class Meta:
verbose_name_plural = "Event Categories"

class Event(models.Model):
VISIBILITIES = [
("i", "Internal"),
("e", "External"),
]
title = models.CharField(max_length=200, blank=False)
description = models.TextField(null=False)
start_time = models.DateTimeField(null=False)
end_time = models.DateTimeField(null=False)
registration_url = models.URLField(blank=True)
meeting_url = models.URLField(blank=True)
instagram_url = models.URLField(blank=True)
linkedin_url = models.URLField(blank=True)
location = models.CharField(null=False, max_length=32)
category = models.ForeignKey(EventCategory, null=False, on_delete=models.CASCADE)
society = models.ManyToManyField(Society)
visibility = models.CharField(max_length=8, choices=VISIBILITIES)
poc = models.ManyToManyField(ExecutiveMember, related_name="events")
yukitya-1811 marked this conversation as resolved.
Show resolved Hide resolved
created_at = models.DateTimeField(null=False, auto_now_add=True)
updated_at = models.DateTimeField(null=False, auto_now=True)
parent_event = models.ForeignKey('self', null=True, blank=True, related_name="sub_events", on_delete=models.CASCADE)
created_by = models.ForeignKey(ExecutiveMember, null=True, blank=True, related_name='created_events', on_delete=models.SET_NULL)

def __str__(self):
return f"{self.title} | {self.society.first().name}"

class Report(models.Model):
yukitya-1811 marked this conversation as resolved.
Show resolved Hide resolved
event = models.OneToOneField(Event, null=False, on_delete=models.CASCADE)
objective = models.CharField(max_length=128, null=False)
description = models.TextField(null=False)
resources = models.JSONField(null=True)
student_turnout = models.IntegerField(null=False)
faculty_turnout = models.IntegerField(null=True)
photo_1 = models.ImageField(null=False)
photo_2 = models.ImageField(null=False)
iic_report_url = models.URLField(null=True)
dsw_report_url = models.URLField(null=True)
created_at = models.DateTimeField(null=False)
created_by = models.ForeignKey(ExecutiveMember, null=True, on_delete=models.DO_NOTHING, related_name="report_creator")


class Volunteer(models.Model):
event = models.ForeignKey(Event, null=False, on_delete=models.CASCADE)
exec_member = models.ForeignKey(ExecutiveMember, null=False, on_delete=models.CASCADE)


class Budget(models.Model):
event = models.OneToOneField(Event, null=False, on_delete=models.CASCADE)
item = models.CharField(null=False, max_length=255)
description = models.TextField()
cost = models.DecimalField(max_digits=12, decimal_places=2, null=False)
source = models.URLField()
yukitya-1811 marked this conversation as resolved.
Show resolved Hide resolved

3 changes: 3 additions & 0 deletions corpus/events/tests.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
from django.test import TestCase

# Create your tests here.
17 changes: 17 additions & 0 deletions corpus/events/urls.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
from django.urls import path
from django.conf import settings
from django.conf.urls.static import static
from . import views

urlpatterns = [
path("", views.dashboard, name="events_dashboard"),
path("core_dashboard", views.core_dashboard, name="events_core_dashboard"),
path("new", views.new, name="new"),
path("manage_event/<int:pk>", views.manage_event, name="manage_event"),
path("delete_event/<int:pk>", views.delete_event, name="delete_event"),
path("show_event/<int:pk>", views.show_event, name="show_event"),
path("report/<int:pk>", views.report, name="report"),
]

if settings.DEBUG:
urlpatterns += static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)
Loading
Loading