refactor to make way for dockerization
This commit is contained in:
52
app/templates/base.html
Normal file
52
app/templates/base.html
Normal file
@@ -0,0 +1,52 @@
|
||||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<!-- Required meta tags -->
|
||||
<meta charset="utf-8">
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
|
||||
|
||||
<!-- Bootstrap CSS -->
|
||||
<link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css" integrity="sha384-ggOyR0iXCbMQv3Xipma34MD+dH/1fQ784/j6cY/iJTQUOhcWr7x9JvoRxT2MZw1T" crossorigin="anonymous">
|
||||
<title>{% block title %} {% endblock %} - BellScheduler</title>
|
||||
|
||||
</head>
|
||||
<body>
|
||||
<nav class="navbar navbar-expand-md navbar-light bg-light">
|
||||
<a class="navbar-brand" href="{{ url_for('index') }}">BellScheduler</a>
|
||||
<button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarNav" aria-controls="navbarNav" aria-expanded="false" aria-label="Toggle navigation">
|
||||
<span class="navbar-toggler-icon"></span>
|
||||
</button>
|
||||
<div class="collapse navbar-collapse" id="navbarNav">
|
||||
<ul class="navbar-nav">
|
||||
<li class="nav-item">
|
||||
<a class="nav-link" href="/events">Events</a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a class="nav-link" href="/tasks">Tasks</a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a class="nav-link" href="/periods">Periods</a>
|
||||
</li>
|
||||
</ul>
|
||||
</div>
|
||||
<div class="float-right">
|
||||
{% if current_user.is_authenticated %}
|
||||
<a href="{{ url_for('logout') }}" class="nav-link"> Logout {{current_user.userName}} </a>
|
||||
{% endif %}
|
||||
{% if not current_user.is_authenticated %}
|
||||
<a href="{{ url_for('login') }}" class="nav-link"> Login </a>
|
||||
{% endif %}
|
||||
</div>
|
||||
</nav>
|
||||
<hr>
|
||||
<div class="container">
|
||||
{% block content %} {% endblock %}
|
||||
</div>
|
||||
|
||||
<!-- Optional JavaScript -->
|
||||
<!-- jQuery first, then Popper.js, then Bootstrap JS -->
|
||||
<script src="https://code.jquery.com/jquery-3.3.1.slim.min.js" integrity="sha384-q8i/X+965DzO0rT7abK41JStQIAqVgRVzpbzo5smXKp4YfRvH+8abtTE1Pi6jizo" crossorigin="anonymous"></script>
|
||||
<script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.7/umd/popper.min.js" integrity="sha384-UO2eT0CpHqdSJQ6hJty5KVphtPhzWj9WO1clHTMGa3JDZwrnQq4sF86dIHNDz0W1" crossorigin="anonymous"></script>
|
||||
<script src="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.min.js" integrity="sha384-JjSmVgyd0p3pXB1rRibZUAYoIIy6OrQ6VrjIEaFf/nJGzIxFDsf4x0xIM+B07jRM" crossorigin="anonymous"></script>
|
||||
</body>
|
||||
</html>
|
34
app/templates/createAccount.html
Normal file
34
app/templates/createAccount.html
Normal file
@@ -0,0 +1,34 @@
|
||||
{% extends "base.html" %}
|
||||
|
||||
{% block content %}
|
||||
<span><h1>{% block title %} Create Account {% endblock %}</h1></span>
|
||||
{% with messages = get_flashed_messages() %}
|
||||
{% if messages %}
|
||||
<div class="notification is-danger">
|
||||
{{ messages[0] }}. Go to <a href="{{ url_for('login') }}">login page</a>.
|
||||
</div>
|
||||
{% endif %}
|
||||
{% endwith %}
|
||||
<form method="post">
|
||||
{{ form.csrf_token }}
|
||||
<p>
|
||||
{{ form.userName.label }}
|
||||
{{ form.userName }}
|
||||
</p>
|
||||
<p>
|
||||
{{ form.password.label }}
|
||||
{{ form.password }}
|
||||
</p>
|
||||
<p>
|
||||
{{ form.realName.label }}
|
||||
{{ form.realName }}
|
||||
</p>
|
||||
<p>
|
||||
{{ form.email.label }}
|
||||
{{ form.email }}
|
||||
</p>
|
||||
<p>
|
||||
<button class="btn btn-primary" type="submit">Submit</button>
|
||||
</p>
|
||||
</form>
|
||||
{% endblock %}
|
27
app/templates/editEvent.html
Normal file
27
app/templates/editEvent.html
Normal file
@@ -0,0 +1,27 @@
|
||||
{% extends 'base.html' %}
|
||||
|
||||
{% block content %}
|
||||
<span><h1>{% block title %} Edit Event {% endblock %}</h1></span>
|
||||
<p>
|
||||
<b>Period {{ event.period.period }}</b> <br> Time: {{ event.period.periodTime.strftime("%I:%M %p") }}
|
||||
</p>
|
||||
{% if event.task_id != None %}
|
||||
<p>
|
||||
<b><a href="/task/{{ event.tasks.id }}">
|
||||
{{ event.tasks.title }}
|
||||
</a></b> <br> {{ event.tasks.description }}
|
||||
</p>
|
||||
{% else %}
|
||||
<div><p>(no task assigned... yet)</p></div>
|
||||
{% endif %}
|
||||
<form method="post">
|
||||
{{ form.csrf_token }}
|
||||
<p>
|
||||
{{ form.selectedTask.label }}
|
||||
{{ form.selectedTask }}
|
||||
</p>
|
||||
<p>
|
||||
<button class="btn btn-primary" type="submit">Submit</button>
|
||||
</p>
|
||||
</form>
|
||||
{% endblock %}
|
29
app/templates/editPeriod.html
Normal file
29
app/templates/editPeriod.html
Normal file
@@ -0,0 +1,29 @@
|
||||
{% extends 'base.html' %}
|
||||
|
||||
{% block content %}
|
||||
<span><h1>{% block title %} Edit Period {% endblock %}</h1></span>
|
||||
<p>
|
||||
<b>Period {{ period.period }}</b>
|
||||
</p>
|
||||
|
||||
<form method="post">
|
||||
{{ form.csrf_token }}
|
||||
<p>
|
||||
{{ form.periodTime.label }}
|
||||
{{ form.periodTime }}
|
||||
</p>
|
||||
<p>
|
||||
{{ form.weekendSchedule.label }}
|
||||
{{ form.weekendSchedule }}
|
||||
</p>
|
||||
<p>
|
||||
<button class="btn btn-primary" type="submit">Submit</button>
|
||||
</p>
|
||||
</form>
|
||||
<form method="post"
|
||||
action="{{url_for('delete_period',
|
||||
periodNum=period.period) }}">
|
||||
<input class="btn btn-danger" type="submit" value="Delete Period"
|
||||
onclick="return confirm('Are you sure you want to delete this period?')">
|
||||
</form>
|
||||
{% endblock %}
|
20
app/templates/edittask.html
Normal file
20
app/templates/edittask.html
Normal file
@@ -0,0 +1,20 @@
|
||||
{% extends 'base.html' %}
|
||||
|
||||
{% block content %}
|
||||
<span><h1>{% block title %} Edit Task {% endblock %}</h1></span>
|
||||
<form method="post">
|
||||
{{ form.csrf_token }}
|
||||
<p>
|
||||
{{ form.title.label }}
|
||||
{{ form.title(size=20) }}
|
||||
</p>
|
||||
|
||||
<p>
|
||||
{{ form.description.label }}
|
||||
</p>
|
||||
{{ form.description(rows=5, cols=25) }}
|
||||
<p>
|
||||
<button class="btn btn-primary" type="submit">Edit Task</button>
|
||||
</p>
|
||||
</form>
|
||||
{% endblock %}
|
31
app/templates/events.html
Normal file
31
app/templates/events.html
Normal file
@@ -0,0 +1,31 @@
|
||||
{% extends 'base.html' %}
|
||||
{% set currDay = datetime.now() %}
|
||||
{% set currDay = currDay.strftime('%m-%d-%Y') %}
|
||||
|
||||
{% block content %}
|
||||
<span><h1>{% block title %} Events {% endblock %}</h1></span>
|
||||
<b>Current Date: {{ currDay }} </b> <br> <br>
|
||||
<div>
|
||||
{% for period in periods %}
|
||||
<div>
|
||||
<p><b>Period {{ period.period }}</b> <br> Time: {{ period.periodTime.strftime("%I:%M %p") }} </p>
|
||||
{% for event in events if event.scheduled_date == currDay and event.period == period %}
|
||||
<div class="float-right"><a type="button" class="btn btn-primary" href="/event/edit/{{ event.id }}">Edit</a></div>
|
||||
{% if event.task_id != None %}
|
||||
<b>
|
||||
<a href="/task/{{ event.tasks.id }}">
|
||||
{{ event.tasks.title }}
|
||||
</a>
|
||||
</b>
|
||||
<div>
|
||||
<p>{{ event.tasks.description }}</p>
|
||||
</div>
|
||||
{% else %}
|
||||
<div><p>(no task assigned... yet)</p></div>
|
||||
{% endif %}
|
||||
{% endfor %}
|
||||
<hr>
|
||||
</div>
|
||||
{% endfor %}
|
||||
</div>
|
||||
{% endblock %}
|
4
app/templates/index.html
Normal file
4
app/templates/index.html
Normal file
@@ -0,0 +1,4 @@
|
||||
{% extends 'base.html' %}
|
||||
|
||||
{% block content %}
|
||||
{% endblock %}
|
26
app/templates/login.html
Normal file
26
app/templates/login.html
Normal file
@@ -0,0 +1,26 @@
|
||||
{% extends "base.html" %}
|
||||
|
||||
{% block content %}
|
||||
<span><h1>{% block title %} Login {% endblock %}</h1></span>
|
||||
{% with messages = get_flashed_messages() %}
|
||||
{% if messages %}
|
||||
<div class="notification is-danger">
|
||||
{{ messages[0] }}
|
||||
</div>
|
||||
{% endif %}
|
||||
{% endwith %}
|
||||
<form method="post">
|
||||
{{ form.csrf_token }}
|
||||
<p>
|
||||
{{ form.userName.label }}
|
||||
{{ form.userName }}
|
||||
</p>
|
||||
<p>
|
||||
{{ form.password.label }}
|
||||
{{ form.password }}
|
||||
</p>
|
||||
<p>
|
||||
<button class="btn btn-primary" type="submit">Submit</button>
|
||||
</p>
|
||||
</form>
|
||||
{% endblock %}
|
20
app/templates/newPeriod.html
Normal file
20
app/templates/newPeriod.html
Normal file
@@ -0,0 +1,20 @@
|
||||
{% extends 'base.html' %}
|
||||
|
||||
{% block content %}
|
||||
<span><h1>{% block title %} New Period {% endblock %}</h1></span>
|
||||
|
||||
<form method="post">
|
||||
{{ form.csrf_token }}
|
||||
<p>
|
||||
{{ form.periodTime.label }}
|
||||
{{ form.periodTime }}
|
||||
</p>
|
||||
<p>
|
||||
{{ form.weekendSchedule.label }}
|
||||
{{ form.weekendSchedule }}
|
||||
</p>
|
||||
<p>
|
||||
<button class="btn btn-primary" type="submit">Submit</button>
|
||||
</p>
|
||||
</form>
|
||||
{% endblock %}
|
20
app/templates/newtask.html
Normal file
20
app/templates/newtask.html
Normal file
@@ -0,0 +1,20 @@
|
||||
{% extends 'base.html' %}
|
||||
|
||||
{% block content %}
|
||||
<span><h1>{% block title %} Create New Task {% endblock %}</h1></span>
|
||||
<form method="post">
|
||||
{{ form.csrf_token }}
|
||||
<p>
|
||||
{{ form.title.label }}
|
||||
{{ form.title(size=20) }}
|
||||
</p>
|
||||
|
||||
<p>
|
||||
{{ form.description.label }}
|
||||
</p>
|
||||
{{ form.description(rows=5, cols=25) }}
|
||||
<p>
|
||||
<button class="btn btn-primary" type="submit">Add Task</button>
|
||||
</p>
|
||||
</form>
|
||||
{% endblock %}
|
22
app/templates/periods.html
Normal file
22
app/templates/periods.html
Normal file
@@ -0,0 +1,22 @@
|
||||
{% extends 'base.html' %}
|
||||
|
||||
{% block content %}
|
||||
<span><h1>{% block title %} Periods {% endblock %}</h1></span> <a class="btn btn-primary" href="/period/new" role="button">New Period </a> <br> <br>
|
||||
<div>
|
||||
{% for period in periods %}
|
||||
<div class="float-right">
|
||||
<form method="post"
|
||||
action="{{url_for('delete_period',
|
||||
periodNum=period.period) }}">
|
||||
<input class="btn btn-danger" type="submit" value="Delete"
|
||||
onclick="return confirm('Are you sure you want to delete this period?')">
|
||||
</form></div>
|
||||
<div class="float-right"><a type="button" class="btn btn-primary mr-1" href="/period/edit/{{ period.period }}">Edit</a>
|
||||
</div>
|
||||
<div>
|
||||
<p><b>Period {{ period.period }}</b> <br> Time: {{ period.periodTime.strftime("%I:%M %p") }} </p>
|
||||
</div>
|
||||
<hr>
|
||||
{% endfor %}
|
||||
</div>
|
||||
{% endblock %}
|
35
app/templates/task.html
Normal file
35
app/templates/task.html
Normal file
@@ -0,0 +1,35 @@
|
||||
{% extends 'base.html' %}
|
||||
{% set createdTime = datetime.fromtimestamp(task.created_timestamp) %}
|
||||
{% set createdTime = datetime.strptime(str(createdTime), '%Y-%m-%d %H:%M:%S') %}
|
||||
|
||||
{% block content %}
|
||||
<span><h1>{% block title %} {{ task.title }} {% endblock %}</h1></span>
|
||||
<div>
|
||||
<div>
|
||||
<div>
|
||||
<br>
|
||||
<p>{{ task.description }}</p>
|
||||
</div>
|
||||
<div>
|
||||
<p>Created: {{ createdTime.strftime('%Y-%m-%d %I:%M %p') }} </p>
|
||||
</div>
|
||||
<div>
|
||||
<p>Due: {{ task.due_timestamp }}</p>
|
||||
</div>
|
||||
<p>
|
||||
<a class="btn btn-primary" href="/task/{{task.id}}/edit">Edit Task</a>
|
||||
<span>
|
||||
|
||||
</span>
|
||||
</p>
|
||||
<p>
|
||||
<form method="POST"
|
||||
action="{{url_for('delete_task',
|
||||
task_id=task.id) }}">
|
||||
<input class="btn btn-danger" type="submit" value="Delete Task"
|
||||
onclick="return confirm('Are you sure you want to delete this task?')">
|
||||
</form>
|
||||
</p>
|
||||
</div>
|
||||
</div>
|
||||
{% endblock %}
|
22
app/templates/tasks.html
Normal file
22
app/templates/tasks.html
Normal file
@@ -0,0 +1,22 @@
|
||||
{% extends 'base.html' %}
|
||||
|
||||
{% block content %}
|
||||
<span><h1>{% block title %} Tasks {% endblock %}</h1></span> <a class="btn btn-primary" href="/task/new" role="button">New Task</a> <br> <br>
|
||||
<div>
|
||||
{% for task in tasks %}
|
||||
{% set createdTime = datetime.fromtimestamp(task.created_timestamp) %}
|
||||
{% set createdTime = datetime.strptime(str(createdTime), '%Y-%m-%d %H:%M:%S') %}
|
||||
<div>
|
||||
<a href="/task/{{ task.id }}">
|
||||
<p><b>{{ task.title }}</b> </p>
|
||||
</a>
|
||||
<b>
|
||||
{{ task.description }}
|
||||
</b>
|
||||
<div>
|
||||
<p>Created: {{ createdTime.strftime('%Y-%m-%d %I:%M %p') }}</p>
|
||||
</div>
|
||||
<hr>
|
||||
</div>
|
||||
{% endfor %}
|
||||
{% endblock %}
|
Reference in New Issue
Block a user