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
+

+
shalli leroi
+
+
CHITECHMA
+
+
Afayi Tech
+
+
+
+
+
+
+
+
+
+
+
\ 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 }}
+
+
+
+
+ {% 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
+
+
+
+
+
+
+

+
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
+
+
shalli leroi
+
+
CHITECHMA
+
+
Afayi Tech
+
+
+
+
+
+
+
+
+
+
+
\ 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
+
+
+
+
+
+
+ {% for message in messages %}
+
{{message}}
+ {% endfor %}
+
+
+
+
+
+
\ 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
+
+
+
+
+
+
+
+
+
\ 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
+
+
CHITECHMA
+
+
Afayi Tech
+
+
+
+
+
+
+
+
+
+
+
\ 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
+
+
+
+
+
+
+
+
+
+
\ 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()