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 0 and sunday is 6 weekday = datetime.today().weekday() 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