Косметические правки

This commit is contained in:
Ivan
2021-04-27 17:05:55 +03:00
parent c9610f7765
commit 3e307506e9
2 changed files with 34 additions and 33 deletions

View File

@@ -1,4 +1,4 @@
import numpy as np
import random
from user import User
@@ -22,15 +22,9 @@ print("Appending list...")
scroll = user.appendUserList(title="a new list!")
print_lists(user.fetchUserLists())
# Remove user list by id:
i = user.lists_[0].id
print(f"Removing {i}...")
user.removeUserList(i)
print_lists(user.fetchUserLists())
# Modify list 0:
print("Modifyng list...")
user.lists_[0].modify(title=f"A new title {np.random.random()}")
user.lists_[0].modify(title=f"A new title {random.random()}")
print_lists(user.fetchUserLists())
# Append item to list:
@@ -43,7 +37,13 @@ print("Modifyng appended item...")
item.modify(finished=True, text="this is an updated item")
print_lists(user.fetchUserLists())
# Removing item at 0
print("Removing last item from last list...")
# Removing item at from last list
print("Removing the last item from the last list...")
user.lists_[-1].remove(-1)
print_lists(user.fetchUserLists())
# Remove user list by id:
i = user.lists_[0].id
print(f"Removing {i}...")
user.removeUserList(i)
print_lists(user.fetchUserLists())

View File

@@ -1,8 +1,8 @@
import os
import random
from datetime import datetime
import numpy as np
from api import UserApi
@@ -17,15 +17,21 @@ def bad_arguments(x, d):
return list((set(x) - set(d)))
def date_or_str(inpt):
if type(inpt) is datetime:
return inpt
elif type(inpt) is str:
return datetime.strptime(inpt, DATETIME_STR)
else:
return datetime.now()
class ToDoList(object):
def __init__(self, id, title, created_at=None, items=None, parent=None, user=None):
self.id = id
self.title = title
self.items_ = [] if items is None else items
if type(created_at) is datetime:
self.created_at = created_at
else:
self.created_at = datetime.strptime(created_at, DATETIME_STR)
self.created_at = date_or_str(created_at)
self.user = user
def __iter__(self):
@@ -57,7 +63,7 @@ class ToDoList(object):
Add a new item to db
"""
if "DEBUG" in os.environ:
created_item = ToDoItem(id=np.random.randint(100, 1000), text=text, user=self.user)
created_item = ToDoItem(id=random.randint(100, 1000), text=text, user=self.user)
else:
created_item = self.user.todo_items_create(parent=self.id, text=text)
created_item = ToDoItem(**created_item, user=self.user)
@@ -92,10 +98,7 @@ class ToDoItem(object):
self.id = id
self.text = text
self.finished = finished
if type(created_at) is datetime:
self.created_at = created_at
else:
self.created_at = datetime.strptime(created_at, DATETIME_STR)
self.created_at = date_or_str(created_at)
self.parent = parent
self.user = user
@@ -105,7 +108,6 @@ class ToDoItem(object):
def modify(self, **argv):
bad = bad_arguments(argv.keys(), TODO_ITEM_UPDATEBLE)
if len(bad) > 0:
print(argv)
raise RuntimeError(UPDATE_ERROR.format(bad[0]))
for key, value in argv.items():
setattr(self, key, value)
@@ -117,7 +119,6 @@ class ToDoItem(object):
return
self.user.todo_items_delete(self.id)
# ToDo
def sync(self):
print(f"Item '{self}' is being synchronized...")
if "DEBUG" in os.environ:
@@ -164,17 +165,17 @@ class User(UserApi):
return self.lists_
user_lists = self.lists_list()["results"]
user_items = self.todo_items_list()["results"]
toDoLists = {x["id"]: ToDoList(**x, user=self) for x in user_lists}
toDoItems = [ToDoItem(**x, user=self) for x in user_items]
for toDoItem in toDoItems:
todo_lists = {x["id"]: ToDoList(**x, user=self) for x in user_lists}
todo_items = [ToDoItem(**x, user=self) for x in user_items]
for todo_item in todo_items:
# Catching stray items
if not hasattr(toDoItem, "parent"):
toDoItem.dispose()
continue
toDoLists[toDoItem.parent].items_.append(toDoItem)
for toDoList in toDoLists.values():
toDoList.items_ = sorted(toDoList.items_, key=lambda x: x.created_at)
self.lists_ = sorted(toDoLists.values(), key=lambda x: x.created_at)
# if not hasattr(toDoItem, "parent"):
# toDoItem.dispose()
# continue
todo_lists[todo_item.parent].items_.append(todo_item)
for todo_list in todo_lists.values():
todo_list.items_ = sorted(todo_list.items_, key=lambda x: x.created_at)
self.lists_ = sorted(todo_lists.values(), key=lambda x: x.created_at)
return self.lists_
def removeUserList(self, id):
@@ -194,7 +195,7 @@ class User(UserApi):
returns: created item
"""
if "DEBUG" in os.environ:
item = ToDoList(id=np.random.randint(100, 1000), title=title, created_at=datetime.now())
item = ToDoList(id=random.randint(100, 1000), title=title, created_at=datetime.now())
self.lists_.append(item)
return item
created_list = self.lists_create(title=title)