简单设置读取文件,明天将我的一天和重要功能实现!
This commit is contained in:
parent
0ae10a875c
commit
36d3d7bff9
19 changed files with 348 additions and 210 deletions
Before Width: | Height: | Size: 324 KiB After Width: | Height: | Size: 324 KiB |
Before Width: | Height: | Size: 29 KiB After Width: | Height: | Size: 29 KiB |
1
images/edit.svg
Normal file
1
images/edit.svg
Normal file
|
@ -0,0 +1 @@
|
|||
<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg t="1650371936214" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="3419" xmlns:xlink="http://www.w3.org/1999/xlink" width="200" height="200"><defs><style type="text/css"></style></defs><path d="M960.984615 145.723077l-82.707692-82.707692c-31.507692-31.507692-80.738462-31.507692-110.276923 0l-64.984615 64.984615c-7.876923 7.876923-7.876923 19.692308 0 27.569231l167.384615 167.384615c7.876923 7.876923 19.692308 7.876923 27.569231 0l64.984615-64.984615c29.538462-31.507692 29.538462-80.738462-1.969231-112.246154z m-313.107692 64.984615c-7.876923-7.876923-19.692308-7.876923-27.569231 0L106.338462 724.676923 41.353846 947.2c-5.907692 21.661538 13.784615 43.323077 35.446154 37.415385l224.492308-63.015385h-1.969231l513.969231-513.969231c7.876923-7.876923 7.876923-19.692308 0-27.569231l-165.415385-169.353846z" p-id="3420"></path></svg>
|
After Width: | Height: | Size: 1,021 B |
35
main/main.py
35
main/main.py
|
@ -4,6 +4,8 @@ from PyQt5.QtGui import *
|
|||
from PyQt5.QtWidgets import *
|
||||
from PyQt5.QtCore import Qt
|
||||
import configparser
|
||||
|
||||
from utils.BasicUtils import get_todo_list
|
||||
from utils.CreateToDo import CreateToDo
|
||||
from utils.QSSLoader import QSSLoader
|
||||
from view.ImportantView import Important
|
||||
|
@ -71,6 +73,11 @@ class MainWidget(QWidget):
|
|||
|
||||
self.system_listWidget.addItem(self.important_item)
|
||||
self.system_listWidget.setItemWidget(self.important_item, self.important_item.widget)
|
||||
load_list = get_todo_list()
|
||||
# print(load_list)
|
||||
if load_list:
|
||||
for load in load_list:
|
||||
self.load_item(load[0], load[1])
|
||||
# self.system_listWidget.addScrollBarWidget(False)
|
||||
|
||||
# 测试添加下面的
|
||||
|
@ -101,17 +108,31 @@ class MainWidget(QWidget):
|
|||
del_action.triggered.connect(self.DeleteItem)
|
||||
pop_menu.exec_(self.custom.mapToGlobal(position))
|
||||
|
||||
# 创建新的分组
|
||||
def CreateNewItem(self):
|
||||
# 创建一个没有名字的item
|
||||
new_list = '新建列表'
|
||||
create_todo = CreateToDo('ToDoList', new_list)
|
||||
item = SelfListWidgetItem(new_list)
|
||||
def load_item(self, list_name, uid):
|
||||
item = SelfListWidgetItem(list_name, 0, uid)
|
||||
item.setTextAlignment(Qt.AlignCenter)
|
||||
# 使得item是可以编辑的.
|
||||
item.setFlags(item.flags() | Qt.ItemIsEditable)
|
||||
self.system_listWidget.addItem(item)
|
||||
todo_list = ToDoList(new_list)
|
||||
todo_list = ToDoList(list_name, uid)
|
||||
# 创建后就可以编辑item,用户自己起名字.
|
||||
# self.system_listWidget.editItem(item)
|
||||
self.stackedWidget.addWidget(todo_list)
|
||||
|
||||
self.system_listWidget.setItemWidget(item, item.widget)
|
||||
|
||||
# 创建新的分组
|
||||
def CreateNewItem(self, new_list='新建列表', uid=None):
|
||||
# 创建一个没有名字的item
|
||||
# new_list = '新建列表'
|
||||
if not uid:
|
||||
create_todo_uid = CreateToDo('ToDoList', new_list)
|
||||
item = SelfListWidgetItem(new_list, 0, create_todo_uid)
|
||||
item.setTextAlignment(Qt.AlignCenter)
|
||||
# 使得item是可以编辑的.
|
||||
item.setFlags(item.flags() | Qt.ItemIsEditable)
|
||||
self.system_listWidget.addItem(item)
|
||||
todo_list = ToDoList(new_list, create_todo_uid)
|
||||
self.stackedWidget.addWidget(todo_list)
|
||||
# 创建后就可以编辑item,用户自己起名字.
|
||||
# self.system_listWidget.editItem(item)
|
||||
|
|
|
@ -18,7 +18,7 @@ home_dir = config['info']['home_dir']
|
|||
print(users_dir)
|
||||
print(name)
|
||||
print(home_dir)
|
||||
with open('test.ini', 'w') as config_file:
|
||||
with open('../utils/test.ini', 'w') as config_file:
|
||||
config.write(config_file)
|
||||
|
||||
config.add_section('Accounts')
|
||||
|
@ -27,5 +27,5 @@ config['Accounts']['name'] = 'admin'
|
|||
config['Accounts']['type'] = 'NextCloud'
|
||||
config['Accounts']['username'] = 'admin'
|
||||
|
||||
with open('test.ini', 'w') as config_file:
|
||||
with open('../utils/test.ini', 'w') as config_file:
|
||||
config.write(config_file)
|
|
@ -1,12 +1,12 @@
|
|||
import os
|
||||
|
||||
work_path = os.path.expandvars('$HOME') + '/.config/PyQtToDoList'
|
||||
work_path = os.path.expandvars('$HOME') + '/.config/PyQtToDoList/ToDoList'
|
||||
# sync_path = os.walk(work_path)
|
||||
# print(sync_path)
|
||||
|
||||
for root, dirs, files in os.walk(work_path, topdown=False):
|
||||
for name in files:
|
||||
print(os.path.join(root, name).split('/')[-1])
|
||||
for name in dirs:
|
||||
# print(os.path.join(root, name))
|
||||
print(os.path.join(root, name).split('/')[-1])
|
||||
# for name in dirs:
|
||||
# # print(os.path.join(root, name))
|
||||
# print(os.path.join(root, name).split('/')[-1])
|
||||
|
|
57
test/TestGetToDoList.py
Normal file
57
test/TestGetToDoList.py
Normal file
|
@ -0,0 +1,57 @@
|
|||
import os
|
||||
import json
|
||||
import configparser
|
||||
|
||||
from utils import BasicUtils
|
||||
|
||||
|
||||
def get_todo_list():
|
||||
config_path = BasicUtils.return_work_dir()
|
||||
todo_path = config_path + 'ToDoList/'
|
||||
# print(todo_path)
|
||||
# config = configparser.ConfigParser()
|
||||
return_todo_list = []
|
||||
|
||||
for root, dirs, files in os.walk(todo_path, topdown=False):
|
||||
for name in files:
|
||||
# print(os.path.join(root, name))
|
||||
with open(os.path.join(root, name), 'r') as f:
|
||||
# print(f.read())
|
||||
json_file = json.load(f)
|
||||
# try:
|
||||
if json_file['itemType'] == 'ToDoList':
|
||||
# print(json_file['title'], json_file['uid'], '列表')
|
||||
return_todo_list.append([json_file['title'], json_file['uid']])
|
||||
|
||||
# print(return_todo_list)
|
||||
return return_todo_list
|
||||
|
||||
|
||||
def get_to_do(todoListUid):
|
||||
config_path = BasicUtils.return_work_dir()
|
||||
todo_path = config_path + 'ToDoList/'
|
||||
# print(todo_path)
|
||||
# config = configparser.ConfigParser()
|
||||
return_todo = []
|
||||
|
||||
for root, dirs, files in os.walk(todo_path, topdown=False):
|
||||
for name in files:
|
||||
# print(os.path.join(root, name))
|
||||
with open(os.path.join(root, name), 'r') as f:
|
||||
# print(f.read())
|
||||
json_file = json.load(f)
|
||||
|
||||
# print(json_file['itemType'])
|
||||
if json_file['itemType'] == 'Todo' and json_file['todoListUid'] == todoListUid:
|
||||
# print(json_file['title'], json_file['uid'], '待办事项')
|
||||
return_todo.append([json_file['title'], json_file['uid']])
|
||||
return return_todo
|
||||
|
||||
# load_list = get_todo_list()
|
||||
|
||||
|
||||
# print(load_list)
|
||||
# if load_list:
|
||||
# for load in load_list:
|
||||
# print(load[0], load[1])
|
||||
print(get_to_do('3f1e033f-2051-4c04-b7f6-afd2eb1f54f4'))
|
148
utils/BasicUtils.py
Normal file
148
utils/BasicUtils.py
Normal file
|
@ -0,0 +1,148 @@
|
|||
import json
|
||||
import os
|
||||
import platform
|
||||
|
||||
|
||||
def return_work_dir():
|
||||
if platform.system() == 'Linux':
|
||||
work_path = os.path.expandvars('$HOME') + '/.config/'
|
||||
if not os.path.exists(work_path):
|
||||
os.mkdir(work_path)
|
||||
return os.path.expandvars('$HOME') + '/.config/PyQtToDoList/'
|
||||
elif platform.system() == 'Windows':
|
||||
work_path = os.getcwd() + '/config/'
|
||||
if not os.path.exists(work_path):
|
||||
os.mkdir(work_path)
|
||||
return work_path
|
||||
|
||||
|
||||
import configparser
|
||||
|
||||
|
||||
def read_init_file():
|
||||
config = configparser.ConfigParser()
|
||||
try:
|
||||
config.read(return_work_dir() + 'PyQtToDoList.ini')
|
||||
account = config['Account']
|
||||
if account:
|
||||
return [account['webdav_hostname'], account['webdav_login'], account['webdav_password'], account['type']]
|
||||
except KeyError as e:
|
||||
return False
|
||||
|
||||
|
||||
def get_todo_list():
|
||||
config_path = return_work_dir()
|
||||
todo_path = config_path + 'ToDoList/'
|
||||
# print(todo_path)
|
||||
return_todo_list = []
|
||||
|
||||
for root, dirs, files in os.walk(todo_path, topdown=False):
|
||||
for name in files:
|
||||
# print(os.path.join(root, name))
|
||||
with open(os.path.join(root, name), 'r') as f:
|
||||
# print(f.read())
|
||||
json_file = json.load(f)
|
||||
# try:
|
||||
if json_file['itemType'] == 'ToDoList':
|
||||
# print(json_file['title'], json_file['uid'], '列表')
|
||||
return_todo_list.append([json_file['title'], json_file['uid']])
|
||||
|
||||
# print(return_todo_list)
|
||||
return return_todo_list
|
||||
|
||||
|
||||
def get_todo(todoListUid):
|
||||
config_path = return_work_dir()
|
||||
todo_path = config_path + 'ToDoList/'
|
||||
# print(todo_path)
|
||||
# config = configparser.ConfigParser()
|
||||
return_todo = []
|
||||
|
||||
for root, dirs, files in os.walk(todo_path, topdown=False):
|
||||
for name in files:
|
||||
# print(os.path.join(root, name))
|
||||
with open(os.path.join(root, name), 'r') as f:
|
||||
# print(f.read())
|
||||
json_file = json.load(f)
|
||||
|
||||
# print(json_file['itemType'])
|
||||
if json_file['itemType'] == 'Todo' and json_file['todoListUid'] == todoListUid:
|
||||
# print(json_file['title'], json_file['uid'], '待办事项')
|
||||
return_todo.append([json_file['title'], json_file['uid']])
|
||||
return return_todo
|
||||
|
||||
# load_list = get_todo_list()
|
||||
|
||||
|
||||
def load_myday_important(item_type):
|
||||
config_path = return_work_dir()
|
||||
todo_path = config_path + 'ToDoList/'
|
||||
# print(todo_path)
|
||||
# config = configparser.ConfigParser()
|
||||
return_todo = []
|
||||
|
||||
for root, dirs, files in os.walk(todo_path, topdown=False):
|
||||
for name in files:
|
||||
# print(os.path.join(root, name))
|
||||
with open(os.path.join(root, name), 'r') as f:
|
||||
# print(f.read())
|
||||
json_file = json.load(f)
|
||||
|
||||
# print(json_file['itemType'])
|
||||
if item_type == 'MyDay':
|
||||
if json_file['itemType'] == 'Todo' and json_file['done'] and json_file['isMyDay']:
|
||||
# print(json_file['title'], json_file['uid'], '待办事项')
|
||||
return_todo.append([json_file['title'], json_file['uid']])
|
||||
return return_todo
|
||||
elif item_type == 'Important':
|
||||
if json_file['itemType'] == 'Todo' and json_file['done'] and json_file['isImportant']:
|
||||
# print(json_file['title'], json_file['uid'], '待办事项')
|
||||
return_todo.append([json_file['title'], json_file['uid']])
|
||||
return return_todo
|
||||
|
||||
def get_todo(todoListUid):
|
||||
config_path = return_work_dir()
|
||||
todo_path = config_path + 'ToDoList/'
|
||||
# print(todo_path)
|
||||
# config = configparser.ConfigParser()
|
||||
return_todo = []
|
||||
|
||||
for root, dirs, files in os.walk(todo_path, topdown=False):
|
||||
for name in files:
|
||||
# print(os.path.join(root, name))
|
||||
with open(os.path.join(root, name), 'r') as f:
|
||||
# print(f.read())
|
||||
json_file = json.load(f)
|
||||
|
||||
# print(json_file['itemType'])
|
||||
if json_file['itemType'] == 'Todo' and json_file['todoListUid'] == todoListUid:
|
||||
# print(json_file['title'], json_file['uid'], '待办事项')
|
||||
return_todo.append([json_file['title'], json_file['uid']])
|
||||
return return_todo
|
||||
|
||||
|
||||
# 用于修改某个键值对,比如更新修改时期,设置为重要,我的一天等
|
||||
def change_value(uid, key, value):
|
||||
config_path = return_work_dir()
|
||||
todo_path = config_path + 'ToDoList/'
|
||||
|
||||
# for root, dirs, files in os.walk(todo_path, topdown=False):
|
||||
# for name in files:
|
||||
# print(os.path.join(root, name))
|
||||
json_file = {}
|
||||
|
||||
with open(todo_path + '{' + uid + '}.otl', 'r') as f:
|
||||
# print(f.read())
|
||||
json_file = json.load(f)
|
||||
print(json_file)
|
||||
json_file[key] = value
|
||||
# print(json_file[key])
|
||||
with open(todo_path + '{' + uid + '}.otl', 'w') as f:
|
||||
json.dump(json_file, f, indent=4, ensure_ascii=False)
|
||||
|
||||
|
||||
#
|
||||
# print(read_init_file())
|
||||
# webdav_hostname = read_init_file()
|
||||
# print(webdav_hostname[2])
|
||||
change_value('4f52f02b-4450-405a-9fd1-2005a03006e0', 'isMyDay', False)
|
|
@ -1,7 +1,7 @@
|
|||
import configparser
|
||||
import platform
|
||||
import os
|
||||
from utils import ReturnWorkDir
|
||||
from utils import BasicUtils
|
||||
|
||||
|
||||
# todo : 用来创建软件的配置信息
|
||||
|
|
|
@ -3,7 +3,7 @@ import uuid
|
|||
import json
|
||||
from datetime import datetime
|
||||
|
||||
from utils import ReturnWorkDir
|
||||
from utils import BasicUtils
|
||||
|
||||
"""
|
||||
todo : 暂时创建单个文件存储该列表下所有待办事项,文件命名为 {uuid}.otl
|
||||
|
@ -13,23 +13,24 @@ from utils import ReturnWorkDir
|
|||
(可以尝试在待办事项添加 isMyDay属性和isImportant属性)
|
||||
"""
|
||||
|
||||
|
||||
class CreateToDo:
|
||||
# class CreateToDo:
|
||||
"""
|
||||
:param item_type: 创建的类型,为ToDo和ToDoList
|
||||
:param name: 要创建的ToDoList名字
|
||||
:param todo_list_uid : 待办事项列表的uid,可选
|
||||
"""
|
||||
|
||||
def __init__(self, item_type, name, todo_list_uid=None):
|
||||
|
||||
def CreateToDo(item_type, name, todo_list_uid=None):
|
||||
uid = str(uuid.uuid4())
|
||||
config_path = ReturnWorkDir.return_work_dir()
|
||||
todo_list_path = config_path + '{' + uid + '}'
|
||||
# if not os.path.exists(todo_list_path):
|
||||
# os.mkdir(todo_list_path)
|
||||
config_path = BasicUtils.return_work_dir()
|
||||
todo_list_path = config_path + 'ToDoList/'
|
||||
if not os.path.exists(todo_list_path):
|
||||
os.mkdir(todo_list_path)
|
||||
default_time = datetime.now().strftime('%Y-%m-%d %H:%M:%S')
|
||||
print(default_time)
|
||||
print(uid)
|
||||
if item_type == 'ToDoList':
|
||||
# print(item_type)
|
||||
try:
|
||||
"""
|
||||
createdAt : 创建时间
|
||||
|
@ -39,7 +40,7 @@ class CreateToDo:
|
|||
title : 标题
|
||||
updatedAt : 最后一次更新时间
|
||||
"""
|
||||
os.mkdir(todo_list_path)
|
||||
# os.mkdir(todo_list_path)
|
||||
out_config = {
|
||||
"createdAt": default_time,
|
||||
"dueTo": '',
|
||||
|
@ -49,14 +50,17 @@ class CreateToDo:
|
|||
"uid": uid,
|
||||
"updatedAt": default_time
|
||||
}
|
||||
library = {
|
||||
"title": name,
|
||||
"uid": uid
|
||||
}
|
||||
with open(todo_list_path + '/library.json', 'w') as f:
|
||||
f.write(json.dumps(library))
|
||||
# library = {
|
||||
# "title": name,
|
||||
# "uid": uid
|
||||
# }
|
||||
with open(todo_list_path + '{' + uid + '}.otl', 'w') as f:
|
||||
f.write(json.dumps(out_config, indent=4, ensure_ascii=False))
|
||||
# json.dump(out_config, f)
|
||||
return uid
|
||||
except IOError as e:
|
||||
print(e)
|
||||
return False
|
||||
elif item_type == 'ToDo':
|
||||
try:
|
||||
# done : 完成状态
|
||||
|
@ -67,24 +71,21 @@ class CreateToDo:
|
|||
"dueTo": '',
|
||||
"itemType": "Todo",
|
||||
"notes": "",
|
||||
"isMyDay": False,
|
||||
"isImportant": False,
|
||||
"title": name,
|
||||
"todoListUid": todo_list_uid,
|
||||
"uid": uid,
|
||||
"theme": '0',
|
||||
"updatedAt": default_time
|
||||
}
|
||||
with open(todo_list_path + '/' + uid + '.otl', 'w') as f:
|
||||
f.write(json.dumps(out_config))
|
||||
with open(todo_list_path + '{' + uid + '}.otl', 'w') as f:
|
||||
f.write(json.dumps(out_config, indent=4, ensure_ascii=False))
|
||||
return uid
|
||||
|
||||
except IOError as e:
|
||||
print(e)
|
||||
return False
|
||||
|
||||
# def get_config_path(self):
|
||||
#
|
||||
# # print(platform.system())
|
||||
# if platform.system() == 'Linux':
|
||||
# # print(os.environ['HOME'] + '/.config/PyQtToDoList')
|
||||
# # print(os.path.expandvars('~'))
|
||||
# # print(os.path.expandvars('$HOME') + '.config/PyQtToDoList')
|
||||
# return os.path.expandvars('$HOME') + '/.config/PyQtToDoList'
|
||||
# elif platform.system() == 'Windows':
|
||||
# print(os.getcwd() + 'config')
|
||||
# return os.getcwd() + 'config'
|
||||
# CreateToDo('ToDo', 'test1', '3f1e033f-2051-4c04-b7f6-afd2eb1f54f4')
|
||||
|
|
|
@ -1,36 +0,0 @@
|
|||
import os
|
||||
import platform
|
||||
|
||||
|
||||
def return_work_dir():
|
||||
if platform.system() == 'Linux':
|
||||
work_path = os.path.expandvars('$HOME') + '/.config/'
|
||||
if not os.path.exists(work_path):
|
||||
os.mkdir(work_path)
|
||||
return os.path.expandvars('$HOME') + '/.config/PyQtToDoList/'
|
||||
elif platform.system() == 'Windows':
|
||||
work_path = os.getcwd() + '/config/'
|
||||
if not os.path.exists(work_path):
|
||||
os.mkdir(work_path)
|
||||
return work_path
|
||||
|
||||
|
||||
import configparser
|
||||
|
||||
|
||||
def read_init_file():
|
||||
config = configparser.ConfigParser()
|
||||
try:
|
||||
config.read(return_work_dir() + 'PyQtToDoList.ini')
|
||||
account = config['Account']
|
||||
if account:
|
||||
return [account['webdav_hostname'], account['webdav_login'], account['webdav_password'], account['type']]
|
||||
except KeyError as e:
|
||||
return False
|
||||
|
||||
|
||||
#
|
||||
#
|
||||
# print(read_init_file())
|
||||
# webdav_hostname = read_init_file()
|
||||
# print(webdav_hostname[2])
|
|
@ -1,68 +0,0 @@
|
|||
import sys
|
||||
from PyQt5.QtCore import *
|
||||
from PyQt5.QtGui import *
|
||||
from PyQt5.QtWidgets import *
|
||||
|
||||
class TabDemo(QTabWidget):
|
||||
def __init__(self,parent=None):
|
||||
super(TabDemo, self).__init__(parent)
|
||||
|
||||
#创建3个选项卡小控件窗口
|
||||
self.tab1=QWidget()
|
||||
self.tab2=QWidget()
|
||||
self.tab3=QWidget()
|
||||
|
||||
#将三个选项卡添加到顶层窗口中
|
||||
self.addTab(self.tab1, "Tab 1")
|
||||
self.addTab(self.tab2, "Tab 2")
|
||||
self.addTab(self.tab3, "Tab 3")
|
||||
|
||||
#每个选项卡自定义的内容
|
||||
self.tab1UI()
|
||||
self.tab2UI()
|
||||
self.tab3UI()
|
||||
|
||||
def tab1UI(self):
|
||||
#表单布局
|
||||
layout=QFormLayout()
|
||||
#添加姓名,地址的单行文本输入框
|
||||
layout.addRow('姓名',QLineEdit())
|
||||
layout.addRow('地址',QLineEdit())
|
||||
#设置选项卡的小标题与布局方式
|
||||
self.setTabText(0,'联系方式')
|
||||
self.tab1.setLayout(layout)
|
||||
|
||||
def tab2UI(self):
|
||||
#zhu表单布局,次水平布局
|
||||
layout=QFormLayout()
|
||||
sex=QHBoxLayout()
|
||||
|
||||
#水平布局添加单选按钮
|
||||
sex.addWidget(QRadioButton('男'))
|
||||
sex.addWidget(QRadioButton('女'))
|
||||
|
||||
#表单布局添加控件
|
||||
layout.addRow(QLabel('性别'),sex)
|
||||
layout.addRow('生日',QLineEdit())
|
||||
|
||||
#设置标题与布局
|
||||
self.setTabText(1,'个人详细信息')
|
||||
self.tab2.setLayout(layout)
|
||||
|
||||
def tab3UI(self):
|
||||
#水平布局
|
||||
layout=QHBoxLayout()
|
||||
|
||||
#添加控件到布局中
|
||||
layout.addWidget(QLabel('科目'))
|
||||
layout.addWidget(QCheckBox('物理'))
|
||||
layout.addWidget(QCheckBox('高数'))
|
||||
|
||||
#设置小标题与布局方式
|
||||
self.setTabText(2,'教育程度')
|
||||
self.tab3.setLayout(layout)
|
||||
if __name__ == '__main__':
|
||||
app=QApplication(sys.argv)
|
||||
demo=TabDemo()
|
||||
demo.show()
|
||||
sys.exit(app.exec_())
|
|
@ -23,16 +23,14 @@ class Important(QWidget):
|
|||
head_layout = QHBoxLayout()
|
||||
|
||||
head_widget = QWidget(self)
|
||||
# head_widget.setStyleSheet('background-color:gray')
|
||||
# todo :
|
||||
# head_widget.setMinimumHeight(175)
|
||||
|
||||
self.todo_list = QListWidget()
|
||||
self.todo_list.setObjectName('todo_list')
|
||||
|
||||
# todo : 重写QLabel,实现添加功能
|
||||
# 添加ToDo的标签
|
||||
self.add_todo = AddToDoAction()
|
||||
self.add_todo.line_edit.returnPressed.connect(lambda: self.line_edit_add(self.add_todo.line_edit.text()))
|
||||
|
||||
self.add_todo.setAlignment(Qt.AlignCenter)
|
||||
# self.add_todo.setPlaceholderText('添加任务')
|
||||
|
||||
|
|
|
@ -2,7 +2,7 @@ from PyQt5.QtCore import Qt
|
|||
from PyQt5.QtGui import *
|
||||
from PyQt5.QtWidgets import *
|
||||
import configparser
|
||||
from utils.ReturnWorkDir import *
|
||||
from utils.BasicUtils import *
|
||||
|
||||
|
||||
#
|
||||
|
|
|
@ -2,7 +2,7 @@ from PyQt5.QtCore import Qt
|
|||
from PyQt5.QtGui import *
|
||||
from PyQt5.QtWidgets import *
|
||||
import configparser
|
||||
from utils.ReturnWorkDir import *
|
||||
from utils.BasicUtils import *
|
||||
|
||||
|
||||
class LoginWindow(QWidget):
|
||||
|
|
|
@ -8,11 +8,12 @@ import os
|
|||
class SelfListWidgetItem(QListWidgetItem):
|
||||
"""
|
||||
:param item_name: 列表名称
|
||||
:param uid: 当前列表的uuid
|
||||
:param todo_count: 设置剩余代办数量,默认为零
|
||||
:param show_icon: 设置显示的图标路径,默认为空
|
||||
"""
|
||||
|
||||
def __init__(self, item_name, todo_count=0, show_icon=None):
|
||||
def __init__(self, item_name, todo_count=0, uid=None, show_icon=None):
|
||||
super(SelfListWidgetItem, self).__init__()
|
||||
layout = QHBoxLayout()
|
||||
# print(show_icon)
|
||||
|
|
|
@ -9,9 +9,10 @@ class ToDoItem(QListWidgetItem):
|
|||
:param todo_name : 新建的待办事项名称
|
||||
"""
|
||||
|
||||
# todo : 参数添加uid,方便设置重要和我的一天
|
||||
def __init__(self, todo_name):
|
||||
super(ToDoItem, self).__init__()
|
||||
print('添加的新ToDo:' + todo_name)
|
||||
print('<ToDoItem> 添加的新ToDo:' + todo_name)
|
||||
|
||||
self.widget = QWidget()
|
||||
layout = QHBoxLayout()
|
||||
|
|
|
@ -1,9 +1,9 @@
|
|||
import os
|
||||
import sys
|
||||
from PyQt5.QtGui import *
|
||||
from PyQt5.QtWidgets import *
|
||||
from PyQt5.QtCore import Qt
|
||||
|
||||
from utils.BasicUtils import get_todo
|
||||
from view.AddToDoLabel import AddToDoAction
|
||||
from view.ToDoItem import ToDoItem
|
||||
|
||||
|
@ -18,7 +18,7 @@ class Menu(QMenu):
|
|||
|
||||
|
||||
class ToDoList(QWidget):
|
||||
def __init__(self, list_name):
|
||||
def __init__(self, list_name, uid):
|
||||
super(ToDoList, self).__init__()
|
||||
self.setObjectName('todolist')
|
||||
self.setAttribute(Qt.WA_StyledBackground)
|
||||
|
@ -32,15 +32,16 @@ class ToDoList(QWidget):
|
|||
head_layout = QHBoxLayout()
|
||||
|
||||
head_widget = QWidget(self)
|
||||
# todo :
|
||||
|
||||
# head_widget.setMinimumHeight(175)
|
||||
|
||||
self.todo_list = QListWidget()
|
||||
self.todo_list.setObjectName('todo_list')
|
||||
|
||||
# todo : 重写QLabel,实现添加功能
|
||||
# 添加ToDo的标签
|
||||
self.add_todo = AddToDoAction()
|
||||
self.add_todo.line_edit.returnPressed.connect(lambda: self.line_edit_add(self.add_todo.line_edit.text()))
|
||||
|
||||
self.add_todo.setAlignment(Qt.AlignCenter)
|
||||
# self.add_todo.setPlaceholderText('添加任务')
|
||||
|
||||
|
@ -139,6 +140,12 @@ class ToDoList(QWidget):
|
|||
label_action5.setText('渐变5')
|
||||
label_action5.triggered.connect(lambda: self.menu_action(5))
|
||||
self.button_menu.addAction(label_action5)
|
||||
|
||||
# 读取配置文件添加Todo
|
||||
load_todo = get_todo(uid)
|
||||
if load_todo:
|
||||
for load in load_todo:
|
||||
self.load_todo(load[0], load[1])
|
||||
# button_menu
|
||||
# for i in range(11):
|
||||
# label_action = QAction(self)
|
||||
|
@ -146,7 +153,6 @@ class ToDoList(QWidget):
|
|||
# label_action.setText(str(i))
|
||||
# label_action.triggered.connect(lambda: self.menu_action(str(i)))
|
||||
# button_menu.addAction(label_action)
|
||||
# todo : 下面的方法实现点击更换主题的功能
|
||||
|
||||
def menu_action(self, count):
|
||||
# 点击按钮
|
||||
|
@ -157,6 +163,14 @@ class ToDoList(QWidget):
|
|||
'}')
|
||||
# print('选中:' + count)
|
||||
|
||||
def load_todo(self, name, uid):
|
||||
todo_item = ToDoItem(name)
|
||||
|
||||
self.todo_list.addItem(todo_item)
|
||||
self.todo_list.setItemWidget(todo_item, todo_item.widget)
|
||||
|
||||
pass
|
||||
|
||||
def line_edit_add(self, name):
|
||||
self.add_todo.todo_name.emit(name)
|
||||
# print('添加的新ToDo:' + name)
|
||||
|
|
|
@ -5,7 +5,7 @@ from PyQt5.QtCore import Qt
|
|||
from PyQt5.QtGui import *
|
||||
from PyQt5.QtWidgets import *
|
||||
import configparser
|
||||
from utils.ReturnWorkDir import *
|
||||
from utils.BasicUtils import *
|
||||
from view.LoginWidget import LoginWidget
|
||||
|
||||
|
||||
|
|
Loading…
Reference in a new issue