diff --git a/.idea/.gitignore b/.idea/.gitignore new file mode 100644 index 0000000..26d3352 --- /dev/null +++ b/.idea/.gitignore @@ -0,0 +1,3 @@ +# Default ignored files +/shelf/ +/workspace.xml diff --git a/.idea/inspectionProfiles/profiles_settings.xml b/.idea/inspectionProfiles/profiles_settings.xml new file mode 100644 index 0000000..105ce2d --- /dev/null +++ b/.idea/inspectionProfiles/profiles_settings.xml @@ -0,0 +1,6 @@ + + + + \ No newline at end of file diff --git a/.idea/misc.xml b/.idea/misc.xml new file mode 100644 index 0000000..fb54e78 --- /dev/null +++ b/.idea/misc.xml @@ -0,0 +1,10 @@ + + + + + + + + + \ No newline at end of file diff --git a/.idea/modules.xml b/.idea/modules.xml new file mode 100644 index 0000000..48581fe --- /dev/null +++ b/.idea/modules.xml @@ -0,0 +1,8 @@ + + + + + + + + \ No newline at end of file diff --git a/.idea/objectiva_pro2.iml b/.idea/objectiva_pro2.iml new file mode 100644 index 0000000..8b8c395 --- /dev/null +++ b/.idea/objectiva_pro2.iml @@ -0,0 +1,12 @@ + + + + + + + + + + \ No newline at end of file diff --git a/objectiva1/db.sqlite3 b/objectiva1/db.sqlite3 new file mode 100644 index 0000000..e8a47e3 Binary files /dev/null and b/objectiva1/db.sqlite3 differ diff --git a/objectiva1/manage.py b/objectiva1/manage.py new file mode 100644 index 0000000..0a59311 --- /dev/null +++ b/objectiva1/manage.py @@ -0,0 +1,22 @@ +#!/usr/bin/env python +"""Django's command-line utility for administrative tasks.""" +import os +import sys + + +def main(): + """Run administrative tasks.""" + os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'objectiva1.settings') + try: + from django.core.management import execute_from_command_line + except ImportError as exc: + raise ImportError( + "Couldn't import Django. Are you sure it's installed and " + "available on your PYTHONPATH environment variable? Did you " + "forget to activate a virtual environment?" + ) from exc + execute_from_command_line(sys.argv) + + +if __name__ == '__main__': + main() diff --git a/objectiva1/objectiva/__init__.py b/objectiva1/objectiva/__init__.py new file mode 100644 index 0000000..e69de29 diff --git a/objectiva1/objectiva/__pycache__/__init__.cpython-39.pyc b/objectiva1/objectiva/__pycache__/__init__.cpython-39.pyc new file mode 100644 index 0000000..123d517 Binary files /dev/null and b/objectiva1/objectiva/__pycache__/__init__.cpython-39.pyc differ diff --git a/objectiva1/objectiva/__pycache__/admin.cpython-39.pyc b/objectiva1/objectiva/__pycache__/admin.cpython-39.pyc new file mode 100644 index 0000000..ad3440d Binary files /dev/null and b/objectiva1/objectiva/__pycache__/admin.cpython-39.pyc differ diff --git a/objectiva1/objectiva/__pycache__/apps.cpython-39.pyc b/objectiva1/objectiva/__pycache__/apps.cpython-39.pyc new file mode 100644 index 0000000..1d72116 Binary files /dev/null and b/objectiva1/objectiva/__pycache__/apps.cpython-39.pyc differ diff --git a/objectiva1/objectiva/__pycache__/models.cpython-39.pyc b/objectiva1/objectiva/__pycache__/models.cpython-39.pyc new file mode 100644 index 0000000..47a30a7 Binary files /dev/null and b/objectiva1/objectiva/__pycache__/models.cpython-39.pyc differ diff --git a/objectiva1/objectiva/__pycache__/urls.cpython-39.pyc b/objectiva1/objectiva/__pycache__/urls.cpython-39.pyc new file mode 100644 index 0000000..6ab5931 Binary files /dev/null and b/objectiva1/objectiva/__pycache__/urls.cpython-39.pyc differ diff --git a/objectiva1/objectiva/__pycache__/views.cpython-39.pyc b/objectiva1/objectiva/__pycache__/views.cpython-39.pyc new file mode 100644 index 0000000..480293c Binary files /dev/null and b/objectiva1/objectiva/__pycache__/views.cpython-39.pyc differ diff --git a/objectiva1/objectiva/admin.py b/objectiva1/objectiva/admin.py new file mode 100644 index 0000000..00af562 --- /dev/null +++ b/objectiva1/objectiva/admin.py @@ -0,0 +1,7 @@ +from django.contrib import admin +from .models import activity,activity_name + +admin.site.register(activity) +admin.site.register(activity_name) + +# Register your models here. diff --git a/objectiva1/objectiva/apps.py b/objectiva1/objectiva/apps.py new file mode 100644 index 0000000..770c746 --- /dev/null +++ b/objectiva1/objectiva/apps.py @@ -0,0 +1,6 @@ +from django.apps import AppConfig + + +class ObjectivaConfig(AppConfig): + default_auto_field = 'django.db.models.BigAutoField' + name = 'objectiva' diff --git a/objectiva1/objectiva/migrations/0001_initial.py b/objectiva1/objectiva/migrations/0001_initial.py new file mode 100644 index 0000000..ffb47d0 --- /dev/null +++ b/objectiva1/objectiva/migrations/0001_initial.py @@ -0,0 +1,21 @@ +# Generated by Django 3.2.9 on 2021-11-22 00:37 + +from django.db import migrations, models + + +class Migration(migrations.Migration): + + initial = True + + dependencies = [ + ] + + operations = [ + migrations.CreateModel( + name='activity', + fields=[ + ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), + ('activity_name', models.CharField(max_length=50)), + ], + ), + ] diff --git a/objectiva1/objectiva/migrations/0002_auto_20211129_1315.py b/objectiva1/objectiva/migrations/0002_auto_20211129_1315.py new file mode 100644 index 0000000..5ba935c --- /dev/null +++ b/objectiva1/objectiva/migrations/0002_auto_20211129_1315.py @@ -0,0 +1,38 @@ +# Generated by Django 3.2.9 on 2021-11-29 12:15 + +import datetime +from django.db import migrations, models +import django.utils.timezone + + +class Migration(migrations.Migration): + + dependencies = [ + ('objectiva', '0001_initial'), + ] + + operations = [ + migrations.AddField( + model_name='activity', + name='description', + field=models.TextField(default='The activity will surely be a success', max_length=100000), + ), + migrations.AddField( + model_name='activity', + name='endingTime', + field=models.DateTimeField(), + preserve_default=False, + ), + migrations.AddField( + model_name='activity', + name='notificationMode', + field=models.IntegerField(default=1, max_length=5), + preserve_default=False, + ), + migrations.AddField( + model_name='activity', + name='startingTime', + field=models.DateTimeField(), + preserve_default=False, + ), + ] diff --git a/objectiva1/objectiva/migrations/0003_auto_20211204_1137.py b/objectiva1/objectiva/migrations/0003_auto_20211204_1137.py new file mode 100644 index 0000000..a081800 --- /dev/null +++ b/objectiva1/objectiva/migrations/0003_auto_20211204_1137.py @@ -0,0 +1,52 @@ +# Generated by Django 3.2.9 on 2021-12-04 10:37 + +from django.conf import settings +from django.db import migrations, models +import django.db.models.deletion + + +class Migration(migrations.Migration): + + dependencies = [ + migrations.swappable_dependency(settings.AUTH_USER_MODEL), + ('objectiva', '0002_auto_20211129_1315'), + ] + + operations = [ + migrations.RemoveField( + model_name='activity', + name='activity_name', + ), + migrations.AddField( + model_name='activity', + name='activityName', + field=models.CharField(default='none', max_length=100), + preserve_default=False, + ), + migrations.AddField( + model_name='activity', + name='user', + field=models.ForeignKey(max_length=100, null=True, on_delete=django.db.models.deletion.CASCADE, related_name='activity', to=settings.AUTH_USER_MODEL), + ), + migrations.AlterField( + model_name='activity', + name='description', + field=models.TextField(default='These activity will surely be a success', max_length=100000), + ), + migrations.AlterField( + model_name='activity', + name='notificationMode', + field=models.IntegerField(default=1), + ), + migrations.CreateModel( + name='activity_name', + fields=[ + ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), + ('activityName', models.CharField(default='none ', max_length=200)), + ('description', models.TextField(default='These activity will surely be a success', max_length=100000)), + ('notificationMode', models.IntegerField(default=1)), + ('complete', models.BooleanField()), + ('activity', models.ForeignKey(default='none ', on_delete=django.db.models.deletion.CASCADE, to='objectiva.activity')), + ], + ), + ] diff --git a/objectiva1/objectiva/migrations/0004_auto_20211204_2017.py b/objectiva1/objectiva/migrations/0004_auto_20211204_2017.py new file mode 100644 index 0000000..b817a00 --- /dev/null +++ b/objectiva1/objectiva/migrations/0004_auto_20211204_2017.py @@ -0,0 +1,42 @@ +# Generated by Django 3.2.9 on 2021-12-04 19:17 + +import datetime +from django.conf import settings +from django.db import migrations, models +import django.db.models.deletion + + +class Migration(migrations.Migration): + + dependencies = [ + migrations.swappable_dependency(settings.AUTH_USER_MODEL), + ('objectiva', '0003_auto_20211204_1137'), + ] + + operations = [ + migrations.AddField( + model_name='activity', + name='complete', + field=models.BooleanField(default=False), + ), + migrations.AddField( + model_name='activity', + name='create_time', + field=models.DateTimeField(default=datetime.datetime.now), + ), + migrations.AlterField( + model_name='activity', + name='notificationMode', + field=models.IntegerField(default=5), + ), + migrations.AlterField( + model_name='activity', + name='user', + field=models.ForeignKey(blank=True, max_length=100, null=True, on_delete=django.db.models.deletion.CASCADE, related_name='activity_name', to=settings.AUTH_USER_MODEL), + ), + migrations.AlterField( + model_name='activity_name', + name='notificationMode', + field=models.IntegerField(default=False), + ), + ] diff --git a/objectiva1/objectiva/migrations/0005_auto_20211205_0059.py b/objectiva1/objectiva/migrations/0005_auto_20211205_0059.py new file mode 100644 index 0000000..523ef32 --- /dev/null +++ b/objectiva1/objectiva/migrations/0005_auto_20211205_0059.py @@ -0,0 +1,43 @@ +# Generated by Django 3.2.9 on 2021-12-04 23:59 + +from django.conf import settings +from django.db import migrations, models +import django.db.models.deletion + + +class Migration(migrations.Migration): + + dependencies = [ + migrations.swappable_dependency(settings.AUTH_USER_MODEL), + ('objectiva', '0004_auto_20211204_2017'), + ] + + operations = [ + migrations.RenameField( + model_name='activity_name', + old_name='activity', + new_name='Activity', + ), + migrations.RemoveField( + model_name='activity_name', + name='activityName', + ), + migrations.RemoveField( + model_name='activity_name', + name='description', + ), + migrations.RemoveField( + model_name='activity_name', + name='notificationMode', + ), + migrations.AlterField( + model_name='activity', + name='user', + field=models.ForeignKey(blank=True, max_length=100, null=True, on_delete=django.db.models.deletion.CASCADE, related_name='Activity', to=settings.AUTH_USER_MODEL), + ), + migrations.AlterField( + model_name='activity_name', + name='complete', + field=models.BooleanField(default=False), + ), + ] diff --git a/objectiva1/objectiva/migrations/0006_auto_20211205_2309.py b/objectiva1/objectiva/migrations/0006_auto_20211205_2309.py new file mode 100644 index 0000000..86febec --- /dev/null +++ b/objectiva1/objectiva/migrations/0006_auto_20211205_2309.py @@ -0,0 +1,23 @@ +# Generated by Django 3.2.9 on 2021-12-05 22:09 + +from django.db import migrations, models + + +class Migration(migrations.Migration): + + dependencies = [ + ('objectiva', '0005_auto_20211205_0059'), + ] + + operations = [ + migrations.AlterField( + model_name='activity', + name='endingTime', + field=models.DateTimeField(blank=True, default='2021-12-05 23:09:37', null=True), + ), + migrations.AlterField( + model_name='activity', + name='startingTime', + field=models.DateTimeField(blank=True, default='2021-12-05 23:09:37', null=True), + ), + ] diff --git a/objectiva1/objectiva/migrations/0007_auto_20211205_2354.py b/objectiva1/objectiva/migrations/0007_auto_20211205_2354.py new file mode 100644 index 0000000..b50e2ed --- /dev/null +++ b/objectiva1/objectiva/migrations/0007_auto_20211205_2354.py @@ -0,0 +1,23 @@ +# Generated by Django 3.2.9 on 2021-12-05 22:54 + +from django.db import migrations, models + + +class Migration(migrations.Migration): + + dependencies = [ + ('objectiva', '0006_auto_20211205_2309'), + ] + + operations = [ + migrations.AlterField( + model_name='activity', + name='endingTime', + field=models.DateTimeField(blank=True, default='2021-12-05 23:53:50', null=True), + ), + migrations.AlterField( + model_name='activity', + name='startingTime', + field=models.DateTimeField(), + ), + ] diff --git a/objectiva1/objectiva/migrations/0008_alter_activity_endingtime.py b/objectiva1/objectiva/migrations/0008_alter_activity_endingtime.py new file mode 100644 index 0000000..d2407a9 --- /dev/null +++ b/objectiva1/objectiva/migrations/0008_alter_activity_endingtime.py @@ -0,0 +1,18 @@ +# Generated by Django 3.2.9 on 2021-12-05 23:05 + +from django.db import migrations, models + + +class Migration(migrations.Migration): + + dependencies = [ + ('objectiva', '0007_auto_20211205_2354'), + ] + + operations = [ + migrations.AlterField( + model_name='activity', + name='endingTime', + field=models.DateTimeField(), + ), + ] diff --git a/objectiva1/objectiva/migrations/__init__.py b/objectiva1/objectiva/migrations/__init__.py new file mode 100644 index 0000000..e69de29 diff --git a/objectiva1/objectiva/migrations/__pycache__/0001_initial.cpython-39.pyc b/objectiva1/objectiva/migrations/__pycache__/0001_initial.cpython-39.pyc new file mode 100644 index 0000000..b75ac67 Binary files /dev/null and b/objectiva1/objectiva/migrations/__pycache__/0001_initial.cpython-39.pyc differ diff --git a/objectiva1/objectiva/migrations/__pycache__/0002_auto_20211129_1315.cpython-39.pyc b/objectiva1/objectiva/migrations/__pycache__/0002_auto_20211129_1315.cpython-39.pyc new file mode 100644 index 0000000..1d4bd28 Binary files /dev/null and b/objectiva1/objectiva/migrations/__pycache__/0002_auto_20211129_1315.cpython-39.pyc differ diff --git a/objectiva1/objectiva/migrations/__pycache__/0003_auto_20211204_1137.cpython-39.pyc b/objectiva1/objectiva/migrations/__pycache__/0003_auto_20211204_1137.cpython-39.pyc new file mode 100644 index 0000000..eaaffee Binary files /dev/null and b/objectiva1/objectiva/migrations/__pycache__/0003_auto_20211204_1137.cpython-39.pyc differ diff --git a/objectiva1/objectiva/migrations/__pycache__/0004_auto_20211204_2017.cpython-39.pyc b/objectiva1/objectiva/migrations/__pycache__/0004_auto_20211204_2017.cpython-39.pyc new file mode 100644 index 0000000..96febf1 Binary files /dev/null and b/objectiva1/objectiva/migrations/__pycache__/0004_auto_20211204_2017.cpython-39.pyc differ diff --git a/objectiva1/objectiva/migrations/__pycache__/0005_auto_20211205_0059.cpython-39.pyc b/objectiva1/objectiva/migrations/__pycache__/0005_auto_20211205_0059.cpython-39.pyc new file mode 100644 index 0000000..d8e2ca5 Binary files /dev/null and b/objectiva1/objectiva/migrations/__pycache__/0005_auto_20211205_0059.cpython-39.pyc differ diff --git a/objectiva1/objectiva/migrations/__pycache__/0006_auto_20211205_2309.cpython-39.pyc b/objectiva1/objectiva/migrations/__pycache__/0006_auto_20211205_2309.cpython-39.pyc new file mode 100644 index 0000000..3863b89 Binary files /dev/null and b/objectiva1/objectiva/migrations/__pycache__/0006_auto_20211205_2309.cpython-39.pyc differ diff --git a/objectiva1/objectiva/migrations/__pycache__/0007_auto_20211205_2354.cpython-39.pyc b/objectiva1/objectiva/migrations/__pycache__/0007_auto_20211205_2354.cpython-39.pyc new file mode 100644 index 0000000..0defad9 Binary files /dev/null and b/objectiva1/objectiva/migrations/__pycache__/0007_auto_20211205_2354.cpython-39.pyc differ diff --git a/objectiva1/objectiva/migrations/__pycache__/0008_alter_activity_endingtime.cpython-39.pyc b/objectiva1/objectiva/migrations/__pycache__/0008_alter_activity_endingtime.cpython-39.pyc new file mode 100644 index 0000000..40796b2 Binary files /dev/null and b/objectiva1/objectiva/migrations/__pycache__/0008_alter_activity_endingtime.cpython-39.pyc differ diff --git a/objectiva1/objectiva/migrations/__pycache__/__init__.cpython-39.pyc b/objectiva1/objectiva/migrations/__pycache__/__init__.cpython-39.pyc new file mode 100644 index 0000000..1047ea6 Binary files /dev/null and b/objectiva1/objectiva/migrations/__pycache__/__init__.cpython-39.pyc differ diff --git a/objectiva1/objectiva/models.py b/objectiva1/objectiva/models.py new file mode 100644 index 0000000..77a2df4 --- /dev/null +++ b/objectiva1/objectiva/models.py @@ -0,0 +1,30 @@ +import time + +from django.db import models +from django.contrib.auth.models import User +import datetime +from datetime import datetime +# Create your models here. +class activity(models.Model): + user = models.ForeignKey(User, max_length=100, on_delete=models.CASCADE, related_name='Activity', null=True, + blank=True) + activityName = models.CharField(max_length=100) + description = models.TextField(max_length=100000, default='These activity will surely be a success') + startingTime = models.DateTimeField() + endingTime = models.DateTimeField() + complete = models.BooleanField( default=False) + notificationMode = models.IntegerField(default=5) + create_time= models.DateTimeField( default=datetime.now) + + def _str_(self): + return self.notificationMode + class meta: + odering=['complete'] + + +class activity_name(models.Model): + Activity = models.ForeignKey(activity,default='none ' ,on_delete=models.CASCADE) + complete = models.BooleanField(default=False) + def _str_(self): + return self.activity + diff --git a/objectiva1/objectiva/static/images/activityIcon.png b/objectiva1/objectiva/static/images/activityIcon.png new file mode 100644 index 0000000..ec8db19 Binary files /dev/null and b/objectiva1/objectiva/static/images/activityIcon.png differ diff --git a/objectiva1/objectiva/static/images/doneActivty.png b/objectiva1/objectiva/static/images/doneActivty.png new file mode 100644 index 0000000..16342c9 Binary files /dev/null and b/objectiva1/objectiva/static/images/doneActivty.png differ diff --git a/objectiva1/objectiva/static/images/menu_icon.png b/objectiva1/objectiva/static/images/menu_icon.png new file mode 100644 index 0000000..7984b95 Binary files /dev/null and b/objectiva1/objectiva/static/images/menu_icon.png differ diff --git a/objectiva1/objectiva/static/images/notDoneActivity.png b/objectiva1/objectiva/static/images/notDoneActivity.png new file mode 100644 index 0000000..d27bb90 Binary files /dev/null and b/objectiva1/objectiva/static/images/notDoneActivity.png differ diff --git a/objectiva1/objectiva/static/images/postActivity1.png b/objectiva1/objectiva/static/images/postActivity1.png new file mode 100644 index 0000000..2e41382 Binary files /dev/null and b/objectiva1/objectiva/static/images/postActivity1.png differ diff --git a/objectiva1/objectiva/static/images/postActivityIcon.png b/objectiva1/objectiva/static/images/postActivityIcon.png new file mode 100644 index 0000000..9f10384 Binary files /dev/null and b/objectiva1/objectiva/static/images/postActivityIcon.png differ diff --git a/objectiva1/objectiva/static/images/pp_image.png b/objectiva1/objectiva/static/images/pp_image.png new file mode 100644 index 0000000..a52ac67 Binary files /dev/null and b/objectiva1/objectiva/static/images/pp_image.png differ diff --git a/objectiva1/objectiva/static/images/timeIcon.png b/objectiva1/objectiva/static/images/timeIcon.png new file mode 100644 index 0000000..8dc1d61 Binary files /dev/null and b/objectiva1/objectiva/static/images/timeIcon.png differ diff --git a/objectiva1/objectiva/templates/objectiva/about.html b/objectiva1/objectiva/templates/objectiva/about.html new file mode 100644 index 0000000..7379553 --- /dev/null +++ b/objectiva1/objectiva/templates/objectiva/about.html @@ -0,0 +1,148 @@ + + +{% load static %} + + + + objectiva home + + + +
+
+
+ + +

About

+ +
+
+
+
+

+ welcome to objectiva app +

+
+

Objectiva was created in december 20201 by K.Michel Leroi

+ pp +

shalli leroi

+

shalli's blogs

+

CHITECHMA

+

CHITECHMA.COM

+

Afayi Tech

+

AfayiTech.com

+ +
+ + +
+
+ +
+ + \ No newline at end of file diff --git a/objectiva1/objectiva/templates/objectiva/activity.html b/objectiva1/objectiva/templates/objectiva/activity.html new file mode 100644 index 0000000..767cab4 --- /dev/null +++ b/objectiva1/objectiva/templates/objectiva/activity.html @@ -0,0 +1,187 @@ + + +{% load static %} + + + + objectiva home + + + +
+
+
+ + +

Your Activties

+ +
+
+
+
+

+ welcome to objectiva app +

+ {% block content %} +{% for activity in user.Activity.all %} + + +
+
+ {{ activity.activityName }} +
+

Activity Description :
{{ activity.description }}

+ +
+
+ +
+

Start Date/Time : {{ activity.startingTime }}


+

Ending Date/Time : {{ activity.endingTime }}

+
+

Check if Notification was send

+
+ + {% endfor %} +{% endblock %} +
+ + + +
+
+
+ +
+ + \ No newline at end of file diff --git a/objectiva1/objectiva/templates/objectiva/activity_form.html b/objectiva1/objectiva/templates/objectiva/activity_form.html new file mode 100644 index 0000000..6158969 --- /dev/null +++ b/objectiva1/objectiva/templates/objectiva/activity_form.html @@ -0,0 +1,59 @@ + +{% load static %} + + + + create an activity + + + +
+
+ + icon +

Fill The Form To
Create An Activity

+
+
+
+ +
+ + + \ No newline at end of file diff --git a/objectiva1/objectiva/templates/objectiva/contact.html b/objectiva1/objectiva/templates/objectiva/contact.html new file mode 100644 index 0000000..b65e4f8 --- /dev/null +++ b/objectiva1/objectiva/templates/objectiva/contact.html @@ -0,0 +1,142 @@ + + +{% load static %} + + + + objectiva home + + + +
+
+
+ + +

Contacts

+ +
+
+
+
+

+ welcome to objectiva app +

+
+

Contact : 698734670

+

Email Me here

+

shalli leroi

+

shalli's blogs

+

CHITECHMA

+

CHITECHMA.COM

+

Afayi Tech

+

AfayiTech.com

+ +
+ + +
+
+ +
+ + \ No newline at end of file diff --git a/objectiva1/objectiva/templates/objectiva/done_activity.html b/objectiva1/objectiva/templates/objectiva/done_activity.html new file mode 100644 index 0000000..42c0430 --- /dev/null +++ b/objectiva1/objectiva/templates/objectiva/done_activity.html @@ -0,0 +1,147 @@ + + +{% load static %} + + + + objectiva home + + + +
+
+
+ + +

Done activities

+ +
+
+
+
+

+ Accomplished Activities +

+{% for activity in user.Activity.all %} +
+ {% block content %} +{% if complet %} +
+

already accomplished :{{ activity.activityName }}

+
+{% endif %} + + +{% endblock %} +
+{% endfor %} +
+
+ +
+ + \ No newline at end of file diff --git a/objectiva1/objectiva/templates/objectiva/home_index1.html b/objectiva1/objectiva/templates/objectiva/home_index1.html new file mode 100644 index 0000000..d3f77b1 --- /dev/null +++ b/objectiva1/objectiva/templates/objectiva/home_index1.html @@ -0,0 +1,130 @@ + + +{% load static %} + + + + objectiva home + + + +
+
+
+ + +

welcome to objectiva

+ +
+
+
+
+

+ welcome to objectiva app +

+

+ Click The Menu icon
and go to the activity
page and create your activity
or activities and get started +

+ +
+
+ +
+ + \ No newline at end of file diff --git a/objectiva1/objectiva/templates/objectiva/login_page.html b/objectiva1/objectiva/templates/objectiva/login_page.html new file mode 100644 index 0000000..3738ca0 --- /dev/null +++ b/objectiva1/objectiva/templates/objectiva/login_page.html @@ -0,0 +1,45 @@ + + + + + sign Up + + + +
+
+

Sign Up

+
+
+
+
+ {% for message in messages %} +

{{message}}

+ {% endfor %} +
+ {% csrf_token %} + + +

User Name :

+

password :

+

+
+
+
+ + + \ No newline at end of file diff --git a/objectiva1/objectiva/templates/objectiva/manage_page.html b/objectiva1/objectiva/templates/objectiva/manage_page.html new file mode 100644 index 0000000..a5f93c4 --- /dev/null +++ b/objectiva1/objectiva/templates/objectiva/manage_page.html @@ -0,0 +1,141 @@ + + +{% load static %} + + + + objectiva home + + + +
+
+
+ + +

Manage Account Here

+ +
+
+
+
+

+ Manage your account here +

+ + + + +

Create New Account

Change Account

Log Out

+ +
+
+ +
+ + \ No newline at end of file diff --git a/objectiva1/objectiva/templates/objectiva/not_done.html b/objectiva1/objectiva/templates/objectiva/not_done.html new file mode 100644 index 0000000..4cf2b2c --- /dev/null +++ b/objectiva1/objectiva/templates/objectiva/not_done.html @@ -0,0 +1,147 @@ + + +{% load static %} + + + + objectiva home + + + +
+
+
+ + +

unaccomplished activities

+ +
+
+
+
+ +

+ welcome to objectiva app +

+

This was not accomplished

+ +
+ {% for activity in user.Activity.all %} +
+ {% block content %} + +

Not accomplished :{{ activity.activityName }}

+ + +{% endblock %} + +
+{% endfor %} +
+ +
+ + \ No newline at end of file diff --git a/objectiva1/objectiva/templates/objectiva/notify_page.html b/objectiva1/objectiva/templates/objectiva/notify_page.html new file mode 100644 index 0000000..66a2c93 --- /dev/null +++ b/objectiva1/objectiva/templates/objectiva/notify_page.html @@ -0,0 +1,10 @@ + + + + + Notification + + +

email sent successfully to : {{ recipient }}

+ + \ No newline at end of file diff --git a/objectiva1/objectiva/templates/objectiva/references.html b/objectiva1/objectiva/templates/objectiva/references.html new file mode 100644 index 0000000..912c6cc --- /dev/null +++ b/objectiva1/objectiva/templates/objectiva/references.html @@ -0,0 +1,140 @@ + + +{% load static %} + + + + objectiva home + + + +
+
+
+ + +

References

+ +
+
+
+
+

+ welcome to objectiva app +

+
+

shalli leroi

+

shalli's blogs

+

CHITECHMA

+

CHITECHMA.COM

+

Afayi Tech

+

AfayiTech.com

+ +
+ + +
+
+ +
+ + \ No newline at end of file diff --git a/objectiva1/objectiva/templates/objectiva/sign_up.html b/objectiva1/objectiva/templates/objectiva/sign_up.html new file mode 100644 index 0000000..cbc2cc7 --- /dev/null +++ b/objectiva1/objectiva/templates/objectiva/sign_up.html @@ -0,0 +1,56 @@ + + + + + sign Up + + + +
+
+

Sign Up

+
+
+
+
+ {% for message in messages %} +

{{message}}

+ {% endfor %} +
+ {% csrf_token %} + + +

User Name :

+

Email :

+

password :

+

Confirm password :

+ +
+
+
+ + + \ No newline at end of file diff --git a/objectiva1/objectiva/tests.py b/objectiva1/objectiva/tests.py new file mode 100644 index 0000000..7ce503c --- /dev/null +++ b/objectiva1/objectiva/tests.py @@ -0,0 +1,3 @@ +from django.test import TestCase + +# Create your tests here. diff --git a/objectiva1/objectiva/urls.py b/objectiva1/objectiva/urls.py new file mode 100644 index 0000000..14b4b3b --- /dev/null +++ b/objectiva1/objectiva/urls.py @@ -0,0 +1,24 @@ +from django.conf import settings +from django.conf.urls.static import static +from django.urls import path +from . import views + + +urlpatterns=[ + path('',views.home1,name='home_index1'), + path('activity',views.home2,name='activity'), + path('done_activity',views.done_a,name='done_activity'), + path('not_done',views.not_d,name='not_done'), + path('manage_page',views.manage_p,name='manage_page'), + path('activity_form', views.activity_frm1, name='activity_form'), + path('about',views.about1,name='about'), + path('contact',views.contact1,name='contact'), + path('reference',views.reference1,name='references'), + path('sign_up',views.sign_up1,name='sign_up'), + path('login_page',views.login1,name='login_page'), + path('logout',views.logout1,name='logout'), + path('change_account',views.change_account,name='change_account'), + path('notify_page',views.notify_user,name='notify_page') + +] +static(settings.STATIC_URL,document_root=settings.STATIC_ROOT) \ No newline at end of file diff --git a/objectiva1/objectiva/views.py b/objectiva1/objectiva/views.py new file mode 100644 index 0000000..0f97a3c --- /dev/null +++ b/objectiva1/objectiva/views.py @@ -0,0 +1,138 @@ +from django.shortcuts import render,redirect +from django.contrib.auth.models import User, auth +from django.contrib import messages +from .models import activity, activity_name +import datetime +from datetime import datetime, timedelta +from django.utils.timezone import utc +import pytz + +from objectiva1.settings import EMAIL_HOST_USER +from django.core.mail import send_mail +import socket +import os +import smtplib + +# socket .getaddrinfo('localhost',8080) +# HOST = "debep.net" +# REAL_HOST = HOST.replace("http://","").replace("https://","").split(":")[0] +# PORT = 8080 +# server = socket.socket(socket.AF_INET,socket.SOCK_STREAM) +# server.connect((REAL_HOST,PORT)) +# +# print("REAL_HOST: ",REAL_HOST) +# print(server) + + +def home1(request): + + return render (request,'objectiva/home_index1.html') +def home2(request): + activity1=activity.objects.all() + user1=User.objects.all() + return render(request,'objectiva/activity.html',{'activity1': activity1,'users':user1} ) +def activity_frm1(request): + if request.method == 'POST': + activity1=activity() + activity1.activityName = request.POST.get('activity_name') + activity1.description = request.POST.get('description1') + activity1.startingTime = request.POST.get('start_date') + activity1.endingTime = request.POST.get('end_date') + activity1.notificationMode = request.POST.get('notificationMode') + activity1.save(); + request.user.Activity.add(activity1) + # request.user.Activity.add(activity1.description) + # request.user.Activity.add(activity1.notificationMode) + return redirect('activity') + return render(request,'objectiva/activity_form.html') + + +def done_a(request): + complete=activity.complete + return render(request,'objectiva/done_activity.html',{'complet':complete}) +def not_d(request): + + return render (request,'objectiva/not_done.html') +def manage_p(request): + + return render(request,'objectiva/manage_page.html') +def about1(request): + + return render(request,'objectiva/about.html') +def contact1(request): + + return render(request,'objectiva/contact.html') +def reference1(request): + + return render(request,'objectiva/references.html') + +def sign_up1(request): + if request.method== 'POST': + username = request.POST['userName'] + email = request.POST['email'] + password = request.POST['password'] + password1 = request.POST['password1'] + + if password == password1: + if User.objects.filter(username=username).exists(): + messages.info(request,'User name already in use. ') + return redirect('sign_up') + elif User.objects.filter(email=email).exists(): + messages.info(request,'Email already used ') + return redirect('sign_up') + else: + user=User.objects.create_user(username=username,email=email,password=password) + user.save(); + return redirect('login_page') + else: + messages.info(request,'passwords not matched') + else: + return render(request, 'objectiva/sign_up.html') + + +def login1(request): + if request.method=='POST': + username=request.POST['userName'] + password=request.POST['password'] + user=auth.authenticate(username=username,password=password) + if user is not None : + auth.login(request,user) + return redirect('/') + else: + messages.info(request,'Invalid credentials') + else: + return render(request, 'objectiva/login_page.html') +def logout1(request): + auth.logout(request) + + return redirect('login_page') +def change_account(request): + auth.logout(request) + return redirect('sign_up') + +def notify_user(request): + + if notify_time == datetime.datetime.now: + activity.objects = True + # subject = 'Activity notification' + # message = 'The activity {% activity.activityName %} is about to begin' + Emails = User.objects.filter(is_active=True).exclude(email='').values_list('email', flat=True) + recipient = str(Emails) + # send_mail(subject,message,EMAIL_HOST_USER,[recipient],fail_silently=False) + + with smtplib.SMTP('smtp.gmail.com', 587) as smtp: + smtp.echlo() + smtp.startls() + smtp.echlo() + + # smtp.login( ' ', ' ') + + Email_subject = 'Activity notification' + Email_body = 'The activity {% activity.activityName %} is about to begin' + msg = f'subject:{Email_subject}\n\n{Email_body}' + smtp.sendmail('shallileroi@gmail.com', recipient, msg) + return render(request, 'objectiva/notify.html', + {'recipient': recipient}) + + + diff --git a/objectiva1/objectiva1/__init__.py b/objectiva1/objectiva1/__init__.py new file mode 100644 index 0000000..e69de29 diff --git a/objectiva1/objectiva1/__pycache__/__init__.cpython-39.pyc b/objectiva1/objectiva1/__pycache__/__init__.cpython-39.pyc new file mode 100644 index 0000000..1a1347d Binary files /dev/null and b/objectiva1/objectiva1/__pycache__/__init__.cpython-39.pyc differ diff --git a/objectiva1/objectiva1/__pycache__/settings.cpython-39.pyc b/objectiva1/objectiva1/__pycache__/settings.cpython-39.pyc new file mode 100644 index 0000000..935a6cc Binary files /dev/null and b/objectiva1/objectiva1/__pycache__/settings.cpython-39.pyc differ diff --git a/objectiva1/objectiva1/__pycache__/urls.cpython-39.pyc b/objectiva1/objectiva1/__pycache__/urls.cpython-39.pyc new file mode 100644 index 0000000..1684778 Binary files /dev/null and b/objectiva1/objectiva1/__pycache__/urls.cpython-39.pyc differ diff --git a/objectiva1/objectiva1/__pycache__/wsgi.cpython-39.pyc b/objectiva1/objectiva1/__pycache__/wsgi.cpython-39.pyc new file mode 100644 index 0000000..d05d22f Binary files /dev/null and b/objectiva1/objectiva1/__pycache__/wsgi.cpython-39.pyc differ diff --git a/objectiva1/objectiva1/asgi.py b/objectiva1/objectiva1/asgi.py new file mode 100644 index 0000000..408f6f6 --- /dev/null +++ b/objectiva1/objectiva1/asgi.py @@ -0,0 +1,16 @@ +""" +ASGI config for objectiva1 project. + +It exposes the ASGI callable as a module-level variable named ``application``. + +For more information on this file, see +https://docs.djangoproject.com/en/3.2/howto/deployment/asgi/ +""" + +import os + +from django.core.asgi import get_asgi_application + +os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'objectiva1.settings') + +application = get_asgi_application() diff --git a/objectiva1/objectiva1/settings.py b/objectiva1/objectiva1/settings.py new file mode 100644 index 0000000..3601c16 --- /dev/null +++ b/objectiva1/objectiva1/settings.py @@ -0,0 +1,142 @@ +""" +Django settings for objectiva1 project. + +Generated by 'django-admin startproject' using Django 3.2.9. + +For more information on this file, see +https://docs.djangoproject.com/en/3.2/topics/settings/ + +For the full list of settings and their values, see +https://docs.djangoproject.com/en/3.2/ref/settings/ +""" + +from pathlib import Path +import os + +# Build paths inside the project like this: BASE_DIR / 'subdir'. +BASE_DIR = Path(__file__).resolve().parent.parent + + +# Quick-start development settings - unsuitable for production +# See https://docs.djangoproject.com/en/3.2/howto/deployment/checklist/ + +# SECURITY WARNING: keep the secret key used in production secret! +SECRET_KEY = 'django-insecure-*!kn6yazd%xv_&6((ig49hwqcungx2b&_xrb&ugu@%k4vb2-#*' + +# SECURITY WARNING: don't run with debug turned on in production! +DEBUG = True + +ALLOWED_HOSTS = [] + + +# Application definition + +INSTALLED_APPS = [ + 'objectiva.apps.ObjectivaConfig', + 'django.contrib.admin', + 'django.contrib.auth', + 'django.contrib.contenttypes', + 'django.contrib.sessions', + 'django.contrib.messages', + 'django.contrib.staticfiles', +] + +MIDDLEWARE = [ + 'django.middleware.security.SecurityMiddleware', + 'django.contrib.sessions.middleware.SessionMiddleware', + 'django.middleware.common.CommonMiddleware', + 'django.middleware.csrf.CsrfViewMiddleware', + 'django.contrib.auth.middleware.AuthenticationMiddleware', + 'django.contrib.messages.middleware.MessageMiddleware', + 'django.middleware.clickjacking.XFrameOptionsMiddleware', +] + +ROOT_URLCONF = 'objectiva1.urls' + +TEMPLATES = [ + { + 'BACKEND': 'django.template.backends.django.DjangoTemplates', + 'DIRS': [BASE_DIR/'templates/objectiva'], + 'APP_DIRS': True, + 'OPTIONS': { + 'context_processors': [ + 'django.template.context_processors.debug', + 'django.template.context_processors.request', + 'django.contrib.auth.context_processors.auth', + 'django.contrib.messages.context_processors.messages', + ], + }, + }, +] + +WSGI_APPLICATION = 'objectiva1.wsgi.application' + + +# Database +# https://docs.djangoproject.com/en/3.2/ref/settings/#databases + +DATABASES = { + 'default': { + 'ENGINE': 'django.db.backends.sqlite3', + 'NAME': BASE_DIR / 'db.sqlite3', + } +} + + +# Password validation +# https://docs.djangoproject.com/en/3.2/ref/settings/#auth-password-validators + +AUTH_PASSWORD_VALIDATORS = [ + { + 'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator', + }, + { + 'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator', + }, + { + 'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator', + }, + { + 'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator', + }, +] + + +# Internationalization +# https://docs.djangoproject.com/en/3.2/topics/i18n/ + +LANGUAGE_CODE = 'en-us' + +TIME_ZONE = 'UTC' + +USE_I18N = True + +USE_L10N = True + +USE_TZ = True + + +# Static files (CSS, JavaScript, Images) +# https://docs.djangoproject.com/en/3.2/howto/static-files/ + +STATIC_URL = '/static/' +STATICFILES_DIRS =[ + BASE_DIR /"static", + 'objectiva/static/images', +] + +# Default primary key field type +# https://docs.djangoproject.com/en/3.2/ref/settings/#default-auto-field + +DEFAULT_AUTO_FIELD = 'django.db.models.BigAutoField' +#DataFlair #Email + +#sending emails through Django +EMAIL_BACKEND = 'django.core.mail.backends.smtp.EmailBackend' +EMAIL_HOST = 'smpt.gmail.com' +EMAIL_HOST_USER = 'smpt.shallileroi@gmail.com' # admin sender +EMAIL_HOST_PASSWORD = 'H-Tensae@' +EMAIL_PORT = 587 +EMAIL_USE_TLS = True +EMAIL_USE_SSL = False +ACCOUNT_EMAIL_VERIFICATION = 'none' diff --git a/objectiva1/objectiva1/urls.py b/objectiva1/objectiva1/urls.py new file mode 100644 index 0000000..4f2f552 --- /dev/null +++ b/objectiva1/objectiva1/urls.py @@ -0,0 +1,22 @@ +"""objectiva1 URL Configuration + +The `urlpatterns` list routes URLs to views. For more information please see: + https://docs.djangoproject.com/en/3.2/topics/http/urls/ +Examples: +Function views + 1. Add an import: from my_app import views + 2. Add a URL to urlpatterns: path('', views.home, name='home') +Class-based views + 1. Add an import: from other_app.views import Home + 2. Add a URL to urlpatterns: path('', Home.as_view(), name='home') +Including another URLconf + 1. Import the include() function: from django.urls import include, path + 2. Add a URL to urlpatterns: path('blog/', include('blog.urls')) +""" +from django.contrib import admin +from django.urls import path,include + +urlpatterns = [ + path('admin/', admin.site.urls), + path('',include('objectiva.urls')) +] diff --git a/objectiva1/objectiva1/wsgi.py b/objectiva1/objectiva1/wsgi.py new file mode 100644 index 0000000..72a7f30 --- /dev/null +++ b/objectiva1/objectiva1/wsgi.py @@ -0,0 +1,16 @@ +""" +WSGI config for objectiva1 project. + +It exposes the WSGI callable as a module-level variable named ``application``. + +For more information on this file, see +https://docs.djangoproject.com/en/3.2/howto/deployment/wsgi/ +""" + +import os + +from django.core.wsgi import get_wsgi_application + +os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'objectiva1.settings') + +application = get_wsgi_application()