2024-02-20 09:58:34 +01:00

75 lines
2.3 KiB
Python

from datetime import datetime
from flask_login import UserMixin
from db.SQLiteClient import (create_user, get_user, get_user_by_email, update_user, delete_user,
get_habitLists, get_heatmap_value)
class User(UserMixin):
def __init__(self, id: int, name: str, email: str, password: str = None, profile_image:str = None):
self.id = id
self.name = name
self.email = email
self.password = password
self.profile_image = profile_image
@staticmethod
def create(name: str, email: str, password: str):
id, profile_image = create_user(name, email, password)
return User(id=id, name=name, email=email, profile_image=profile_image)
@staticmethod
def get(id: int):
user = get_user(id)
return User(user[0], user[1], user[2], user[3], user[4]) if user else None
@staticmethod
def get_by_email(email: str):
user = get_user_by_email(email)
return User(user[0], user[1], user[2], user[3], user[4]) if user else None
# Updates: name, email, password
def update(self):
update_user(self.id, self.name, self.email, self.password if self.password else None)
# Deletes the User
def delete(self):
# calls the deletion of the users habitLists
habitLists = self.get_habitLists()
for habitList in habitLists:
habitList.delete(self.id)
# deletes the user
delete_user(self.id)
# Returns all HabitLists connected with the user
def get_habitLists(self) -> list:
from models.HabitList import HabitList
raw_habitLists = get_habitLists(self.id)
habitLists = []
for habitList in raw_habitLists:
habitList = HabitList(habitList[0], habitList[1], habitList[2])
habitLists.append(habitList)
return habitLists
# Returns all heatmap-values from the last 28 days
def get_heatmap(self) -> list:
# get current day of week as integer. monday is 1 and sunday is 7
weekday = datetime.today().weekday() + 1
heatmap = []
# append the heatmap values of the current week
for day in range(0, weekday):
heatmap.append(0)
for day in range (0, 28):
value = get_heatmap_value(self.id, day)
heatmap.append(value)
return heatmap