Skip to content

Commit

Permalink
NEW: added script with command line task manager
Browse files Browse the repository at this point in the history
  • Loading branch information
patrikmnich committed May 15, 2024
1 parent d913213 commit d0f2007
Showing 1 changed file with 160 additions and 0 deletions.
160 changes: 160 additions & 0 deletions main.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,160 @@
import sys
from dataclasses import dataclass
import datetime
from enum import Enum
from typing import List


class Priority(Enum):
HIGH = 0
MEDIUM = 1
LOW = 2

def __str__(self):
return self.name


@dataclass
class Task:
name: str
priority: Priority
due_date: datetime or None

def serialize(self):
if self.due_date:
due_date = self.due_date.strftime('%d-%m-%Y')
else:
due_date = None

return f"{self.name},{self.priority.value},{due_date}\n"


def create_task_from_string(string: str):
name, priority, due_date = string.strip().split(",")
if due_date != "None":
due_date = datetime.datetime.strptime(due_date, "%d-%m-%Y")
else:
due_date = None
return Task(name, Priority(int(priority)), due_date)


class TaskManager:
def __init__(self):
self.task_list: List[Task] = []

def add_task(self):
task_name = input("Task name: ")

priority = Priority(Priority.LOW)
while True:
priority_input = input("Priority (high=0, medium=1, low=2): ")
if priority_input.lower() not in ["0", "1", "2"]:
print("Invalid choice.")
continue

priority = Priority(int(priority_input))
break

due_date = None
while True:
inp = input("Does it have due date? (Y/N) ")
if inp.lower() not in ["y", "n"]:
print("Invalid choice.")
continue

if inp.lower() == "y":
while True:
date_input = input("Due date (dd-MM-YYYY): ")
try:
due_date = datetime.datetime.strptime(date_input, "%d-%m-%Y")
break
except:
print("Invalid input. Please enter date in format dd-MM-YYYY.")
continue
break

task = Task(task_name, priority, due_date)
self.task_list.append(task)

def complete_task(self):
if len(self.task_list) == 0:
print("No active tasks.")
return

task_name = input("Enter name of task you want to complete >> ")

matched_task = None
for task in self.task_list:
if task_name.lower() == task.name.lower():
matched_task = task

if matched_task:
self.task_list.remove(matched_task)
print(f"Task {matched_task.name} completed.")
else:
print("This task does not exist.")

def show_tasks(self):
if len(self.task_list) == 0:
print("No active tasks.")
return

for task in self.task_list:
due_date: datetime = None
if task.due_date:
due_date = task.due_date.strftime("%d-%m-%Y")

print(f"Task: {task.name}, priority: {task.priority}, due date: {due_date}")

def save_tasks(self):
with open("tasks.txt", "w") as file:
file.writelines([task.serialize() for task in self.task_list])
print("Tasks saved.")

def load_tasks(self):
try:
with open("tasks.txt", "r") as file:
tasks = file.readlines()
self.task_list = [create_task_from_string(task) for task in tasks]

print("Tasks loaded.")
except IOError:
open("tasks.txt")

def start_manager(self):
print(f'''
Welcome to task manager
Type number and hit enter to perform action
Options:
1 - add task
2 - show tasks
3 - complete task
4 - save tasks
5 - load tasks
6 - quit
''')

while True:
option = input("Enter your choice >> ")

match option:
case "1":
self.add_task()
case "2":
self.show_tasks()
case "3":
self.complete_task()
case "4":
self.save_tasks()
case "5":
self.load_tasks()
case "6":
print("Goodbye.")
sys.exit()
case _:
print("Invalid choice.")


if __name__ == '__main__':
task_manager = TaskManager()
task_manager.start_manager()

0 comments on commit d0f2007

Please sign in to comment.