123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743 |
- import abc
- import tkinter as tk
- import tkinter.ttk as ttk
- from tkinter.filedialog import askdirectory, askopenfilename
- from tool.type_ import *
- from tool.tk import make_font, set_tk_disable_from_list
- from tool.login import create_uid
- from conf import Config
- from . import admin
- from . import admin_event as tk_event
- from sql.user import find_user_by_name
- from core.garbage import GarbageType
- class AdminProgram(metaclass=abc.ABCMeta):
- def __init__(self, station: "admin.AdminStation", win: Union[tk.Frame, tk.Toplevel, tk.Tk], color: str, title: str):
- self.station = station
- self.win = win
- self.color = color
- self.frame = tk.Frame(self.win)
- self.frame['bg'] = color
- self.program_title = title
- @abc.abstractmethod
- def set_disable(self):
- ...
- @abc.abstractmethod
- def reset_disable(self):
- ...
- @abc.abstractmethod
- def conf_gui(self, n: int = 1):
- ...
- def get_program_frame(self) -> Tuple[str, tk.Frame]:
- return self.program_title, self.frame
- class WelcomeProgram(AdminProgram):
- def __init__(self, station, win, color):
- super().__init__(station, win, color, "欢迎页")
- self.title = tk.Label(self.frame)
- self.info = tk.Label(self.frame)
- self.__conf_font()
- def __conf_font(self, n: int = 1):
- self.title_font_size = int(25 * n)
- self.info_font_size = int(14 * n)
- def conf_gui(self, n: int = 1):
- self.__conf_font(n)
- title_font = make_font(size=self.title_font_size, weight="bold")
- info_font = make_font(size=self.info_font_size)
- self.title['font'] = title_font
- self.title['bg'] = self.color
- self.title['text'] = '欢迎使用 HGSSystem 管理员系统\n[帮助]'
- self.info['bg'] = self.color
- self.info['font'] = info_font
- self.info['anchor'] = 'nw'
- self.info['justify'] = 'left'
- self.info['text'] = (f'''
- HGSSystem 管理者界面:
- 1) 点击菜单按钮进入子菜单或程序
- 2) 创建 菜单包含创建类的程序
- 3) 删除 菜单包含删除类的程序
- 4) 搜索 菜单包含数据分析类的程序
- 5) 更新 菜单包含数据更新类的程序
- 6) 当离开操作系统时请退出登录以确保安全
- 7) 只能使用具有管理员权限的账号登陆系统
- 8) 只有admin用户可以完成危险操作(例如删除所有垃圾袋数据)
- 程序的运行:
- 1) 在菜单中选中程序后,根据程序界面提示完成操作
- 2) 操作过程通常会显示进度条,除非任务执行迅速
- 3) 结果通常会被反馈, 且不会自动消失
- 系统登录:
- 1) 仅Manager用户可以登录
- 关于彩蛋: 存在
- '''.strip())
- self.title.place(relx=0.1, rely=0.0, relwidth=0.8, relheight=0.2)
- self.info.place(relx=0.05, rely=0.21, relwidth=0.90, relheight=0.75)
- def set_disable(self):
- pass
- def reset_disable(self):
- pass
- class AboutProgram(AdminProgram):
- def __init__(self, station, win, color):
- super().__init__(station, win, color, "关于")
- self.title = tk.Label(self.frame)
- self.info = tk.Label(self.frame)
- self.__conf_font()
- def __conf_font(self, n: int = 1):
- self.title_font_size = int(25 * n)
- self.info_font_size = int(14 * n)
- def conf_gui(self, n: int = 1):
- self.__conf_font(n)
- title_font = make_font(size=self.title_font_size, weight="bold")
- info_font = make_font(size=self.info_font_size)
- self.title['font'] = title_font
- self.title['bg'] = self.color
- self.title['text'] = '关于 HGSSystem 管理员系统'
- self.info['bg'] = self.color
- self.info['font'] = info_font
- self.info['anchor'] = 'nw'
- self.info['justify'] = 'left'
- self.info['text'] = Config.about_info
- self.title.place(relx=0.1, rely=0.0, relwidth=0.8, relheight=0.2)
- self.info.place(relx=0.05, rely=0.21, relwidth=0.90, relheight=0.75)
- def set_disable(self):
- pass
- def reset_disable(self):
- pass
- class CreateUserProgramBase(AdminProgram):
- def __init__(self, station, win, color, title: str):
- super().__init__(station, win, color, title)
- self.enter_frame = tk.Frame(self.frame)
- self.title: List[tk.Label] = [tk.Label(self.enter_frame) for _ in range(3)]
- self.enter: List[tk.Entry] = [tk.Entry(self.enter_frame) for _ in range(3)]
- self.var: List[tk.Variable] = [tk.StringVar() for _ in range(3)]
- self.btn: List[tk.Button] = [tk.Button(self.frame) for _ in range(2)]
- self._conf("#FA8072", False) # 默认颜色
- self.__conf_font()
- def _conf(self, bg_color, is_manager: bool):
- self.bg_color = bg_color
- self.is_manager = is_manager
- return self
- def __conf_font(self, n: int = 1):
- self.title_font_size = int(16 * n)
- self.btn_font_size = int(14 * n)
- def conf_gui(self, n: int = 1):
- self.__conf_font(n)
- title_font = make_font(size=self.title_font_size)
- btn_font = make_font(size=self.btn_font_size)
- self.enter_frame['bg'] = self.bg_color
- self.enter_frame['bd'] = 5
- self.enter_frame['relief'] = "ridge"
- self.enter_frame.place(relx=0.2, rely=0.3, relwidth=0.6, relheight=0.30)
- height = 0.1
- for lb, text, enter, var in zip(self.title, ["用户名:", "用户密码:", "手机号:"], self.enter, self.var):
- lb['font'] = title_font
- lb['text'] = text
- lb['bg'] = self.bg_color
- lb['anchor'] = 'e'
- enter['font'] = title_font
- enter['textvariable'] = var
- lb.place(relx=0.01, rely=height, relwidth=0.30, relheight=0.17)
- enter.place(relx=0.35, rely=height, relwidth=0.60, relheight=0.17)
- height += 0.30
- for btn, text, x, func in zip(self.btn,
- ["创建用户", "获取用户ID"],
- [0.2, 0.6],
- [lambda: self.create_by_name(), lambda: self.get_uid()]):
- btn['font'] = btn_font
- btn['text'] = text
- btn['bg'] = Config.tk_btn_bg
- btn['command'] = func
- btn.place(relx=x, rely=0.7, relwidth=0.2, relheight=0.08)
- def __get_info(self) -> Optional[Tuple[uname_t, passwd_t, str]]:
- name: uname_t = self.var[0].get()
- passwd: passwd_t = self.var[1].get()
- phone: str = self.var[2].get()
- if len(name) == 0 or len(passwd) == 0 or len(phone) != 11:
- self.station.show_msg("用户创建失败", "请再次尝试, 输入用户名, 用户密码和11位手机号")
- return None
- return name, passwd, phone
- def create_by_name(self):
- res = self.__get_info()
- if res is None:
- return
- name, passwd, phone = res
- event = tk_event.CreateUserEvent(self.station).start(name, passwd, phone, self.is_manager)
- self.station.push_event(event)
- def get_uid(self):
- res = self.__get_info()
- if res is None:
- return
- name, passwd, phone = res
- uid = create_uid(name, passwd, phone)
- self.station.show_msg("获取用户ID", f"用户名: {name}\n用户ID: {uid}")
- def set_disable(self):
- set_tk_disable_from_list(self.btn)
- set_tk_disable_from_list(self.enter)
- def reset_disable(self):
- set_tk_disable_from_list(self.btn, flat='normal')
- set_tk_disable_from_list(self.enter, flat='normal')
- class CreateNormalUserProgram(CreateUserProgramBase):
- def __init__(self, station, win, color):
- super(CreateNormalUserProgram, self).__init__(station, win, color, "创建普通用户")
- class CreateManagerUserProgram(CreateUserProgramBase):
- def __init__(self, station, win, color):
- super(CreateManagerUserProgram, self).__init__(station, win, color, "创建管理员")
- self._conf("#4b5cc4", True)
- class CreateAutoNormalUserProgram(AdminProgram):
- def __init__(self, station, win, color):
- super().__init__(station, win, color, "创建自动用户")
- self.enter_frame = tk.Frame(self.frame)
- self.title: tk.Label = tk.Label(self.enter_frame)
- self.enter: tk.Entry = tk.Entry(self.enter_frame)
- self.var: tk.Variable = tk.StringVar()
- self.btn: tk.Button = tk.Button(self.frame) # create(生成用户) try(计算uid)
- self.__conf_font()
- def __conf_font(self, n: int = 1):
- self.title_font_size = int(16 * n)
- self.btn_font_size = int(14 * n)
- def conf_gui(self, n: int = 1):
- self.__conf_font(n)
- title_font = make_font(size=self.title_font_size)
- btn_font = make_font(size=self.btn_font_size)
- self.enter_frame['bg'] = "#bce672"
- self.enter_frame['bd'] = 5
- self.enter_frame['relief'] = "ridge"
- self.enter_frame.place(relx=0.2, rely=0.3, relwidth=0.6, relheight=0.12)
- self.title['font'] = title_font
- self.title['text'] = "手机号:"
- self.title['bg'] = "#bce672"
- self.title['anchor'] = 'e'
- self.enter['font'] = title_font
- self.enter['textvariable'] = self.var
- self.title.place(relx=0.02, rely=0.25, relwidth=0.25, relheight=0.50)
- self.enter.place(relx=0.30, rely=0.25, relwidth=0.60, relheight=0.50)
- self.btn['font'] = btn_font
- self.btn['text'] = "创建用户"
- self.btn['bg'] = Config.tk_btn_bg
- self.btn['command'] = lambda: self.create_user()
- self.btn.place(relx=0.4, rely=0.7, relwidth=0.2, relheight=0.08)
- def create_user(self):
- phone = self.var.get()
- if len(phone) != 11:
- self.station.show_msg("UserInfoError", "Please, enter Phone(11)")
- event = tk_event.CreateUserEvent(self.station).start(None, None, phone, False)
- self.station.push_event(event)
- def set_disable(self):
- self.btn['state'] = 'disable'
- self.enter['state'] = 'disable'
- def reset_disable(self):
- self.btn['state'] = 'normal'
- self.enter['state'] = 'normal'
- class CreateGarbageProgram(AdminProgram):
- def __init__(self, station, win, color):
- super().__init__(station, win, color, "创建垃圾袋")
- self.enter_frame = tk.Frame(self.frame)
- self.title: List[tk.Label] = [tk.Label(self.enter_frame), tk.Label(self.enter_frame)]
- self.enter: List[tk.Entry] = [tk.Entry(self.enter_frame), tk.Entry(self.enter_frame)]
- self.var: List[tk.Variable] = [tk.StringVar(), tk.StringVar()]
- self.create_btn: tk.Button = tk.Button(self.frame)
- self.file_btn: tk.Button = tk.Button(self.frame)
- self.__conf_font()
- def __conf_font(self, n: int = 1):
- self.title_font_size = int(16 * n)
- self.btn_font_size = int(14 * n)
- def conf_gui(self, n: int = 1):
- self.__conf_font(n)
- title_font = make_font(size=self.title_font_size)
- btn_font = make_font(size=self.btn_font_size)
- self.enter_frame['bg'] = "#b69968"
- self.enter_frame['bd'] = 5
- self.enter_frame['relief'] = "ridge"
- self.enter_frame.place(relx=0.2, rely=0.3, relwidth=0.6, relheight=0.17)
- height = 0.1
- for lb, text, enter, var in zip(self.title, ["数量:", "导出位置:"], self.enter, self.var):
- lb['font'] = title_font
- lb['text'] = text
- lb['bg'] = "#b69968"
- lb['anchor'] = 'e'
- enter['font'] = title_font
- enter['textvariable'] = var
- lb.place(relx=0.01, rely=height, relwidth=0.30, relheight=0.35)
- enter.place(relx=0.35, rely=height, relwidth=0.60, relheight=0.35)
- height += 0.43
- for btn, text, x, func in zip([self.create_btn, self.file_btn],
- ["创建垃圾袋", "选择目录"],
- [0.2, 0.6],
- [lambda: self.create_garbage(), lambda: self.choose_file()]):
- btn['font'] = btn_font
- btn['text'] = text
- btn['bg'] = Config.tk_btn_bg
- btn['command'] = func
- btn.place(relx=x, rely=0.7, relwidth=0.2, relheight=0.08)
- def choose_file(self):
- path = askdirectory(title='选择二维码导出位置')
- self.var[1].set(path)
- def create_garbage(self):
- try:
- count = int(self.var[0].get())
- if count <= 0:
- raise ValueError
- except (ValueError, TypeError):
- self.station.show_msg("类型错误", "数量必须为大于0的数字")
- else:
- path = self.var[1].get()
- if len(path) == 0:
- path = None
- event = tk_event.CreateGarbageEvent(self.station).start(path, count)
- self.station.push_event(event)
- def set_disable(self):
- self.create_btn['state'] = 'disable'
- self.file_btn['state'] = 'disable'
- set_tk_disable_from_list(self.enter)
- def reset_disable(self):
- self.create_btn['state'] = 'normal'
- self.file_btn['state'] = 'normal'
- set_tk_disable_from_list(self.enter, flat='normal')
- class ExportProgramBase(AdminProgram):
- def __init__(self, station, win, color, title: str):
- super().__init__(station, win, color, title)
- self.gid_frame = tk.Frame(self.frame)
- self.gid_title: List[tk.Label] = [tk.Label(self.gid_frame), tk.Label(self.gid_frame)]
- self.gid_enter: List[tk.Entry] = [tk.Entry(self.gid_frame), tk.Entry(self.gid_frame)]
- self.gid_var: List[tk.Variable] = [tk.StringVar(), tk.StringVar()]
- self.where_frame = tk.Frame(self.frame)
- self.where_title: List[tk.Label] = [tk.Label(self.where_frame), tk.Label(self.where_frame)]
- self.where_enter: List[tk.Entry] = [tk.Entry(self.where_frame), tk.Entry(self.where_frame)]
- self.where_var: List[tk.Variable] = [tk.StringVar(), tk.StringVar()]
- self.create_btn: List[tk.Button] = [tk.Button(self.frame), tk.Button(self.frame)]
- self.file_btn: List[tk.Button] = [tk.Button(self.frame), tk.Button(self.frame)]
- self._conf("", [], [], [])
- self.__conf_font()
- def _conf(self, bg_color: str, title_id, title_where, title_command):
- self.bg_color = bg_color
- self.title_id = title_id
- self.title_where = title_where
- self.title_command = title_command
- def __conf_font(self, n: int = 1):
- self.title_font_size = int(16 * n)
- self.btn_font_size = int(14 * n)
- def conf_gui(self, n: int = 1):
- self.__conf_font(n)
- title_font = make_font(size=self.title_font_size)
- btn_font = make_font(size=self.btn_font_size)
- self.where_frame['bg'] = self.bg_color
- self.where_frame['bd'] = 5
- self.where_frame['relief'] = "ridge"
- self.where_frame.place(relx=0.2, rely=0.2, relwidth=0.6, relheight=0.17)
- self.gid_frame['bg'] = self.bg_color
- self.gid_frame['bd'] = 5
- self.gid_frame['relief'] = "ridge"
- self.gid_frame.place(relx=0.2, rely=0.6, relwidth=0.6, relheight=0.17)
- height = 0.1
- for lb, text, enter, var, lb_w, text_w, enter_w, var_w in zip(
- self.gid_title, self.title_id, self.gid_enter, self.gid_var,
- self.where_title, self.title_where, self.where_enter, self.where_var):
- lb['font'] = title_font
- lb['text'] = text
- lb['bg'] = self.bg_color
- lb['anchor'] = 'e'
- lb_w['font'] = title_font
- lb_w['text'] = text_w
- lb_w['bg'] = self.bg_color
- lb_w['anchor'] = 'e'
- enter['textvariable'] = var
- enter['font'] = title_font
- enter_w['textvariable'] = var_w
- enter_w['font'] = title_font
- lb.place(relx=0.01, rely=height, relwidth=0.30, relheight=0.35)
- enter.place(relx=0.35, rely=height, relwidth=0.60, relheight=0.35)
- lb_w.place(relx=0.01, rely=height, relwidth=0.30, relheight=0.35)
- enter_w.place(relx=0.35, rely=height, relwidth=0.60, relheight=0.35)
- height += 0.43
- for btn, text in zip(self.create_btn + self.file_btn, self.title_command):
- btn['font'] = btn_font
- btn['text'] = text
- btn['bg'] = Config.tk_btn_bg
- self.create_btn[1]['command'] = self.export_where
- self.create_btn[0]['command'] = self.export_id
- self.create_btn[1].place(relx=0.2, rely=0.39, relwidth=0.25, relheight=0.08)
- self.create_btn[0].place(relx=0.2, rely=0.79, relwidth=0.25, relheight=0.08)
- self.file_btn[1]['command'] = self.choose_file_where
- self.file_btn[0]['command'] = self.choose_file_id
- self.file_btn[1].place(relx=0.6, rely=0.39, relwidth=0.2, relheight=0.08)
- self.file_btn[0].place(relx=0.6, rely=0.79, relwidth=0.2, relheight=0.08)
- def choose_file_id(self):
- path = askdirectory(title='选择二维码导出位置')
- self.gid_var[1].set(path)
- def choose_file_where(self):
- path = askdirectory(title='选择二维码导出位置')
- self.where_var[1].set(path)
- def export_id(self):
- ...
- def export_where(self):
- ...
- def set_disable(self):
- set_tk_disable_from_list(self.gid_enter)
- set_tk_disable_from_list(self.create_btn)
- set_tk_disable_from_list(self.file_btn)
- def reset_disable(self):
- set_tk_disable_from_list(self.gid_enter, flat='normal')
- set_tk_disable_from_list(self.create_btn, flat='normal')
- set_tk_disable_from_list(self.file_btn, flat='normal')
- class ExportGarbageProgram(ExportProgramBase):
- def __init__(self, station, win, color):
- super().__init__(station, win, color, "导出垃圾袋二维码")
- self._conf("#afdfe4", ["垃圾袋ID:", "导出位置:"], ["条件:", "导出位置:"],
- ["根据垃圾袋ID导出", "根据条件导出", "选择目录", "选择目录"])
- def export_id(self):
- gid = self.gid_var[0].get()
- path = self.gid_var[1].get()
- event = tk_event.ExportGarbageByIDEvent(self.station).start(path, gid)
- self.station.push_event(event)
- def export_where(self):
- where = self.where_var[0].get()
- path = self.where_var[1].get()
- event = tk_event.ExportGarbageAdvancedEvent(self.station).start(path, where)
- self.station.push_event(event)
- class ExportUserProgram(ExportProgramBase):
- def __init__(self, station, win, color):
- super().__init__(station, win, color, "导出用户二维码")
- self._conf("#f69c9f", ["用户ID:", "导出位置:"], ["条件:", "导出位置:"],
- ["根据用户ID导出", "根据条件导出", "选择目录", "选择目录"])
- def export_id(self):
- uid = self.gid_var[0].get()
- path = self.gid_var[1].get()
- event = tk_event.ExportUserByIDEvent(self.station).start(path, uid)
- self.station.push_event(event)
- def export_where(self):
- where = self.where_var[0].get()
- path = self.where_var[1].get()
- event = tk_event.ExportUserAdvancedEvent(self.station).start(path, where)
- self.station.push_event(event)
- class CreateUserFromCSVProgram(AdminProgram):
- def __init__(self, station, win, color):
- super().__init__(station, win, color, "从CSV导入用户")
- self.auto_frame = tk.Frame(self.frame)
- self.auto_title: tk.Label = tk.Label(self.auto_frame)
- self.auto_enter: tk.Entry = tk.Entry(self.auto_frame)
- self.auto_var: tk.Variable = tk.StringVar()
- self.enter_frame = tk.Frame(self.frame)
- self.path_title: tk.Label = tk.Label(self.enter_frame)
- self.path_enter: tk.Entry = tk.Entry(self.enter_frame)
- self.path_var: tk.Variable = tk.StringVar()
- self.create_btn: List[tk.Button] = [tk.Button(self.frame), tk.Button(self.frame)]
- self.file_btn: List[tk.Button] = [tk.Button(self.frame), tk.Button(self.frame)]
- self.__conf_font()
- def __conf_font(self, n: int = 1):
- self.title_font_size = int(16 * n)
- self.btn_font_size = int(14 * n)
- def conf_gui(self, n: int = 1):
- self.__conf_font(n)
- title_font = make_font(size=self.title_font_size)
- btn_font = make_font(size=self.btn_font_size)
- self.enter_frame['bg'] = "#EEE8AA"
- self.enter_frame['bd'] = 5
- self.enter_frame['relief'] = "ridge"
- self.enter_frame.place(relx=0.2, rely=0.2, relwidth=0.6, relheight=0.12)
- self.auto_frame['bg'] = "#EEE8AA"
- self.auto_frame['bd'] = 5
- self.auto_frame['relief'] = "ridge"
- self.auto_frame.place(relx=0.2, rely=0.6, relwidth=0.6, relheight=0.12)
- self.auto_title['font'] = title_font
- self.auto_title['text'] = "CSV文件:"
- self.auto_title['bg'] = "#EEE8AA"
- self.auto_title['anchor'] = 'e'
- self.path_title['font'] = title_font
- self.path_title['text'] = "CSV文件:"
- self.path_title['bg'] = "#EEE8AA"
- self.path_title['anchor'] = 'e'
- self.auto_enter['textvariable'] = self.auto_var
- self.auto_enter['font'] = title_font
- self.path_enter['textvariable'] = self.path_var
- self.path_enter['font'] = title_font
- self.auto_title.place(relx=0.01, rely=0.25, relwidth=0.30, relheight=0.50)
- self.auto_enter.place(relx=0.35, rely=0.25, relwidth=0.60, relheight=0.50)
- self.path_title.place(relx=0.01, rely=0.25, relwidth=0.30, relheight=0.50)
- self.path_enter.place(relx=0.35, rely=0.25, relwidth=0.60, relheight=0.50)
- for btn, text in zip(self.create_btn + self.file_btn,
- ["创建用户", "创建自动用户", "选择CSV", "选择CSV"]):
- btn['font'] = btn_font
- btn['text'] = text
- btn['bg'] = Config.tk_btn_bg
- self.create_btn[0]['command'] = self.create
- self.create_btn[1]['command'] = self.create_auto
- self.create_btn[0].place(relx=0.2, rely=0.34, relwidth=0.25, relheight=0.08)
- self.create_btn[1].place(relx=0.2, rely=0.74, relwidth=0.25, relheight=0.08)
- self.file_btn[0]['command'] = self.choose_file
- self.file_btn[1]['command'] = self.choose_file_auto
- self.file_btn[0].place(relx=0.6, rely=0.34, relwidth=0.2, relheight=0.08)
- self.file_btn[1].place(relx=0.6, rely=0.74, relwidth=0.2, relheight=0.08)
- def choose_file_auto(self):
- path = askopenfilename(title='选择CSV文件', filetypes=[("CSV", ".csv")])
- self.auto_var.set(path)
- def choose_file(self):
- path = askopenfilename(title='选择CSV文件', filetypes=[("CSV", ".csv")])
- self.path_var.set(path)
- def create_auto(self):
- path = self.auto_var.get()
- event = tk_event.CreateAutoUserFromCSVEvent(self.station).start(path)
- self.station.push_event(event)
- def create(self):
- path = self.path_var.get()
- event = tk_event.CreateUserFromCSVEvent(self.station).start(path)
- self.station.push_event(event)
- def set_disable(self):
- self.auto_enter['state'] = 'disable'
- self.path_enter['state'] = 'disable'
- set_tk_disable_from_list(self.create_btn)
- set_tk_disable_from_list(self.file_btn)
- def reset_disable(self):
- self.auto_enter['state'] = 'normal'
- self.path_enter['state'] = 'normal'
- set_tk_disable_from_list(self.create_btn, flat='normal')
- set_tk_disable_from_list(self.file_btn, flat='normal')
- class DeleteUserProgram(AdminProgram):
- def __init__(self, station, win, color):
- super().__init__(station, win, color, "删除用户")
- self.uid_frame = tk.Frame(self.frame)
- self.uid_title: tk.Label = tk.Label(self.uid_frame)
- self.uid_enter: tk.Entry = tk.Entry(self.uid_frame)
- self.uid_var: tk.Variable = tk.StringVar()
- self.name_frame = tk.Frame(self.frame)
- self.name_title: List[tk.Label] = [tk.Label(self.name_frame) for _ in range(2)]
- self.name_enter: List[tk.Entry] = [tk.Entry(self.name_frame) for _ in range(2)]
- self.name_var: List[tk.Variable] = [tk.StringVar() for _ in range(2)]
- self.btn: List[tk.Button] = [tk.Button(self.frame) for _ in range(2)] # uid-del, name-passwd-del
- self.__conf_font()
- def __conf_font(self, n: int = 1):
- self.title_font_size = int(16 * n)
- self.btn_font_size = int(14 * n)
- def conf_gui(self, n: int = 1):
- self.__conf_font(n)
- title_font = make_font(size=self.title_font_size)
- btn_font = make_font(size=self.btn_font_size)
- self.uid_frame['bg'] = "#FA8072"
- self.uid_frame['bd'] = 5
- self.uid_frame['relief'] = "ridge"
- self.uid_frame.place(relx=0.2, rely=0.20, relwidth=0.6, relheight=0.10)
- self.name_frame['bg'] = "#FA8072"
- self.name_frame['bd'] = 5
- self.name_frame['relief'] = "ridge"
- self.name_frame.place(relx=0.2, rely=0.48, relwidth=0.6, relheight=0.25)
- height = 0.17
- for lb, text, enter, var in zip(self.name_title, ["用户名:", "密码:"], self.name_enter, self.name_var):
- lb['font'] = title_font
- lb['text'] = text
- lb['bg'] = "#FA8072"
- lb['anchor'] = 'e'
- enter['font'] = title_font
- enter['textvariable'] = var
- lb.place(relx=0.01, rely=height, relwidth=0.30, relheight=0.20)
- enter.place(relx=0.35, rely=height, relwidth=0.60, relheight=0.20)
- height += 0.45
- self.uid_title['font'] = title_font
- self.uid_title['text'] = "用户ID:"
- self.uid_title['bg'] = "#FA8072"
- self.uid_title['anchor'] = 'e'
- self.uid_enter['font'] = title_font
- self.uid_enter['textvariable'] = self.uid_var
- self.uid_title.place(relx=0.01, rely=0.25, relwidth=0.30, relheight=0.50)
- self.uid_enter.place(relx=0.35, rely=0.25, relwidth=0.60, relheight=0.50)
- for btn, text, func in zip(self.btn,
- ["通过用户ID删除", "通过用户名删除"],
- [lambda: self.del_by_uid(), lambda: self.del_by_name()]):
- btn['font'] = btn_font
- btn['text'] = text
- btn['bg'] = Config.tk_btn_bg
- btn['command'] = func
- self.btn[0].place(relx=0.6, rely=0.32, relwidth=0.2, relheight=0.08)
- self.btn[1].place(relx=0.6, rely=0.75, relwidth=0.2, relheight=0.08)
- def del_by_uid(self):
- uid = self.uid_var.get()
- if len(uid) != 32:
- self.station.show_warning("用户ID错误", "用户ID必须为32位")
- return
- event = tk_event.DelUserEvent(self.station).start(uid)
- self.station.push_event(event)
- def del_by_name(self):
- name = self.name_var[0].get()
- passwd = self.name_var[1].get()
- if len(name) == 0 or len(passwd) == 0:
- self.station.show_warning("用户名或密码错误", "请输入用户名和密码")
- return
- uid = create_uid(name, passwd)
- event = tk_event.DelUserEvent(self.station).start(uid)
- self.station.push_event(event)
- def set_disable(self):
- set_tk_disable_from_list(self.btn)
- set_tk_disable_from_list(self.name_enter)
- self.uid_enter['state'] = 'disable'
- def reset_disable(self):
- set_tk_disable_from_list(self.btn, flat='normal')
- set_tk_disable_from_list(self.name_enter, flat='normal')
- self.uid_enter['state'] = 'normal'
- class DeleteUsersProgram(AdminProgram):
- def __init__(self, station, win, color):
- super().__init__(station, win, color, "删除多个用户")
- self.enter_frame = tk.Frame(self.frame)
- self.title: tk.Label = tk.Label(self.enter_frame)
- self.enter: tk.Entry = tk.Entry(self.enter_frame)
- self.var: tk.Variable = tk.StringVar()
- self.btn: List[tk.Button] = [tk.Button(self.frame) for _ in range(2)] # del, scan
- self.__conf_font()
- def __conf_font(self, n: int = 1):
- self.title_font_size = int(16 * n)
- self.btn_font_size = int(14 * n)
- def conf_gui(self, n: int = 1):
- self.__conf_font(n)
- title_font = make_font(size=self.title_font_size)
- btn_font = make_font(size=self.btn_font_size)
- self.enter_frame['bg'] = "#48c0a3"
- self.enter_frame['bd'] = 5
- self.enter_frame['relief'] = "ridge"
- self.enter_frame.place(relx=0.2, rely=0.30, relwidth=0.6, relheight=0.10)
- self.title['font'] = title_font
- self.title['text'] = "条件:"
- self.title['anchor'] = 'e'
- self.title['bg'] = "#48c0a3"
- self.enter['font'] = title_font
- self.enter['textvariable'] = self.var
- self.title.place(relx=0.01, rely=0.25, relwidth=0.30, relheight=0.50)
- self.enter.place(relx=0.35, rely=0.25, relwidth=0.60, relheight=0.50)
- for btn, text, x, func in zip(self.btn,
- ["删除", "扫描"],
- [0.2, 0.6],
- [lambda: self.delete_user(), lambda: self.scan_user()]):
- btn['font'] = btn_font
- btn['text'] = text
- btn['bg'] = Config.tk_btn_bg
- btn['command'] = func
- btn.place(relx=x, rely=0.6, relwidth=0.2, relheight=0.08)
- def delete_user(self):
- where = self.var.get()
- if len(where) == 0:
- self.station.show_warning("条件错误", "条件必须为正确的SQL语句")
- return
- event = tk_event.DelUserFromWhereEvent(self.station).start(where)
- self.station.push_event(event)
- def scan_user(self):
- where = self.var.get()
- if len(where) == 0:
- self.station.show_warning("条件错误", "条件必须为正确的SQL语句")
- return
- event = tk_event.DelUserFromWhereScanEvent(self.station).start(where)
- self.station.push_event(event)
- def set_disable(self):
- set_tk_disable_from_list(self.btn)
- self.enter['state'] = 'disable'
- def reset_disable(self):
- set_tk_disable_from_list(self.btn, flat='normal')
- self.enter['state'] = 'normal'
- class DeleteGarbageProgramBase(AdminProgram):
- def __init__(self, station, win, color, title: str):
- super().__init__(station, win, color, title)
- self.enter_frame = tk.Frame(self.frame)
- self.title: tk.Label = tk.Label(self.enter_frame)
- self.enter: tk.Entry = tk.Entry(self.enter_frame)
- self.var: tk.Variable = tk.StringVar()
- self.int_var: tk.Variable = tk.IntVar()
- self.int_var.set(0)
- self.radio: List[tk.Radiobutton] = [tk.Radiobutton(self.frame) for _ in range(4)]
- self.btn: tk.Button = tk.Button(self.frame)
- self.__conf_font()
- self._conf()
- def _conf(self, title: str = "垃圾袋ID:", color: str = "#b69968", support_del_all: bool = True):
- self.frame_title = title
- self.frame_color = color
- self.support_del_all = support_del_all
- def __conf_font(self, n: int = 1):
- self.title_font_size = int(16 * n)
- self.btn_font_size = int(14 * n)
- def conf_gui(self, n: int = 1):
- self.__conf_font(n)
- title_font = make_font(size=self.title_font_size)
- btn_font = make_font(size=self.btn_font_size)
- self.enter_frame['bg'] = self.frame_color
- self.enter_frame['bd'] = 5
- self.enter_frame['relief'] = "ridge"
- self.enter_frame.place(relx=0.2, rely=0.30, relwidth=0.6, relheight=0.10)
- self.title['font'] = title_font
- self.title['text'] = self.frame_title
- self.title['bg'] = self.frame_color
- self.title['anchor'] = 'e'
- self.enter['font'] = title_font
- self.enter['textvariable'] = self.var
- self.title.place(relx=0.01, rely=0.25, relwidth=0.30, relheight=0.50)
- self.enter.place(relx=0.35, rely=0.25, relwidth=0.60, relheight=0.50)
- for i in range(4):
- radio = self.radio[i]
- radio['font'] = btn_font
- radio['text'] = ['均可', '仅未使用', '仅待检测', '仅已检测'][i]
- radio['bg'] = self.color
- radio['value'] = i
- radio['variable'] = self.int_var
- radio['anchor'] = 'w'
- if not self.support_del_all:
- self.int_var.set(1)
- self.radio[0]['state'] = 'disable'
- self.radio[0].place(relx=0.20, rely=0.43, relwidth=0.20, relheight=0.1)
- self.radio[1].place(relx=0.60, rely=0.43, relwidth=0.20, relheight=0.1)
- self.radio[2].place(relx=0.20, rely=0.55, relwidth=0.20, relheight=0.1)
- self.radio[3].place(relx=0.60, rely=0.55, relwidth=0.20, relheight=0.1)
- self.btn['font'] = btn_font
- self.btn['text'] = '删除'
- self.btn['bg'] = Config.tk_btn_bg
- self.btn['command'] = lambda: self.delete_garbage()
- self.btn.place(relx=0.4, rely=0.68, relwidth=0.2, relheight=0.08)
- def delete_garbage(self):
- ...
- def set_disable(self):
- self.enter['state'] = 'disable'
- self.btn['state'] = 'disable'
- def reset_disable(self):
- self.enter['state'] = 'normal'
- self.btn['state'] = 'normal'
- class DeleteGarbageProgram(DeleteGarbageProgramBase):
- def __init__(self, station, win, color):
- super(DeleteGarbageProgram, self).__init__(station, win, color, "删除垃圾袋")
- def delete_garbage(self):
- where = self.int_var.get()
- assert where in [0, 1, 2, 3]
- gid = self.var.get()
- if len(gid) == 0:
- self.station.show_warning("垃圾袋ID错误", "请输入正确的垃圾袋ID")
- return
- event = tk_event.DelGarbageEvent(self.station).start(gid, where)
- self.station.push_event(event)
- class DeleteGarbageMoreProgram(DeleteGarbageProgramBase):
- def __init__(self, station, win, color):
- super(DeleteGarbageMoreProgram, self).__init__(station, win, color, "删除多个垃圾袋")
- self.scan_btn = tk.Button(self.frame)
- self._conf("条件:", "#f58f98", False)
- def conf_gui(self, n: int = 1):
- super(DeleteGarbageMoreProgram, self).conf_gui(n)
- self.btn.place_forget()
- self.btn.place(relx=0.2, rely=0.68, relwidth=0.2, relheight=0.08)
- self.scan_btn['font'] = make_font(size=self.btn_font_size)
- self.scan_btn['text'] = '扫描'
- self.scan_btn['bg'] = Config.tk_btn_bg
- self.scan_btn['command'] = self.scan_garbage
- self.scan_btn.place(relx=0.6, rely=0.68, relwidth=0.2, relheight=0.08)
- def set_disable(self):
- super(DeleteGarbageMoreProgram, self).set_disable()
- self.scan_btn['state'] = 'disable'
- def reset_disable(self):
- super(DeleteGarbageMoreProgram, self).reset_disable()
- self.scan_btn['state'] = 'normal'
- def delete_garbage(self):
- where = self.int_var.get()
- assert where in [1, 2, 3]
- where_sql = self.var.get()
- if len(where_sql) == 0:
- self.station.show_warning("条件错误", "条件必须为正确的SQL语句")
- return
- event = tk_event.DelGarbageWhereEvent(self.station).start(where, where_sql)
- self.station.push_event(event)
- def scan_garbage(self):
- where = self.int_var.get()
- assert where in [1, 2, 3]
- where_sql = self.var.get()
- if len(where_sql) == 0:
- self.station.show_warning("条件错误", "条件必须为正确的SQL语句")
- return
- event = tk_event.DelGarbageWhereScanEvent(self.station).start(where, where_sql)
- self.station.push_event(event)
- class DeleteAllGarbageProgram(AdminProgram):
- def __init__(self, station, win, color):
- super().__init__(station, win, color, "删除所有垃圾袋")
- self.dangerous: tk.Label = tk.Label(self.frame)
- self.enter_frame = tk.Frame(self.frame)
- self.title: tk.Label = tk.Label(self.enter_frame)
- self.enter: tk.Entry = tk.Entry(self.enter_frame)
- self.var: tk.Variable = tk.StringVar()
- self.btn: List[tk.Button] = [tk.Button(self.frame) for _ in range(2)] # del, scan
- self.__conf_font()
- def __conf_font(self, n: int = 1):
- self.danger_font_size = int(20 * n)
- self.title_font_size = int(16 * n)
- self.btn_font_size = int(14 * n)
- def conf_gui(self, n: int = 1):
- self.__conf_font(n)
- danger_font = make_font(size=self.danger_font_size, weight="bold", underline=1)
- title_font = make_font(size=self.title_font_size)
- btn_font = make_font(size=self.btn_font_size)
- danger_btn_font = make_font(size=self.btn_font_size, weight="bold", overstrike=1)
- self.dangerous['bg'] = self.color
- self.dangerous['font'] = danger_font
- self.dangerous['fg'] = "#f20c00"
- self.dangerous['text'] = ("确定要从数据库删除所有垃圾袋吗?\n"
- "请输入[admin]用户的密码再继续操作.\n"
- "只有[admin]用户具有该操作的权限.\n"
- "这是相当危险的操作.\n"
- "操作后数据库可能无法恢复原数据.\n"
- "SuperHuan和程序的缔造者不会对\n"
- "此操作负责.\n"
- "删库跑路可不是一件好事.\n"
- "请遵守当地法律法规.")
- self.dangerous.place(relx=0.05, rely=0.03, relwidth=0.9, relheight=0.53)
- self.enter_frame['bg'] = "#f20c00"
- self.enter_frame['bd'] = 5
- self.enter_frame['relief'] = "ridge"
- self.enter_frame.place(relx=0.2, rely=0.60, relwidth=0.6, relheight=0.10)
- self.title['font'] = title_font
- self.title['text'] = "密码:"
- self.title['bg'] = "#f20c00"
- self.title['anchor'] = 'e'
- self.enter['font'] = title_font
- self.enter['textvariable'] = self.var
- self.title.place(relx=0.01, rely=0.25, relwidth=0.30, relheight=0.50)
- self.enter.place(relx=0.35, rely=0.25, relwidth=0.60, relheight=0.50)
- for btn, text, x in zip(self.btn, ["删除", "扫描"], [0.2, 0.6]):
- btn['text'] = text
- btn.place(relx=x, rely=0.78, relwidth=0.2, relheight=0.08)
- self.btn[0]['font'] = danger_btn_font
- self.btn[0]['bg'] = "#f20c00"
- self.btn[0]['command'] = lambda: self.delete_garbage()
- self.btn[1]['font'] = btn_font
- self.btn[1]['bg'] = Config.tk_btn_bg
- self.btn[1]['command'] = lambda: self.scan_garbage()
- def scan_garbage(self):
- event = tk_event.DelAllGarbageScanEvent(self.station) # 不需要start
- self.station.push_event(event)
- def delete_garbage(self):
- passwd = self.var.get()
- if len(passwd) == 0:
- self.station.show_warning("密码错误", "请输入正确的[admin]用户密码")
- user = find_user_by_name('admin', passwd, self.station.get_db())
- if user is None or not user.is_manager():
- self.station.show_warning("密码错误", "请输入正确的[admin]用户密码")
- return
- event = tk_event.DelAllGarbageEvent(self.station) # 不需要start
- self.station.push_event(event)
- def set_disable(self):
- set_tk_disable_from_list(self.btn)
- self.enter['state'] = 'disable'
- def reset_disable(self):
- set_tk_disable_from_list(self.btn, flat='normal')
- self.enter['state'] = 'normal'
- class SearchProgramBase(AdminProgram, metaclass=abc.ABCMeta):
- def __init__(self, station, win, color, title: str):
- super().__init__(station, win, color, title)
- self.view_frame = tk.Frame(self.frame)
- self.view = ttk.Treeview(self.view_frame)
- self.y_scroll = tk.Scrollbar(self.view_frame)
- self.x_scroll = tk.Scrollbar(self.view_frame)
- def conf_view_gui(self, columns: list, relx, rely, relwidth, relheight,
- x_scroll=0.05, y_scroll=0.02, color: str = "#FA8072"):
- self.view_frame['bg'] = color
- self.view_frame['bd'] = 2
- self.view_frame['relief'] = "ridge"
- self.view_frame.place(relx=relx, rely=rely, relwidth=relwidth, relheight=relheight)
- self.view['columns'] = columns
- self.view['show'] = 'headings'
- self.view['selectmode'] = 'none'
- for i in columns:
- self.view.column(i, anchor="c")
- self.view.heading(i, text=i)
- self.y_scroll['orient'] = 'vertical'
- self.y_scroll['command'] = self.view.yview
- self.view['yscrollcommand'] = self.y_scroll.set
- self.x_scroll['orient'] = 'horizontal'
- self.x_scroll['command'] = self.view.xview
- self.view['xscrollcommand'] = self.x_scroll.set
- self.view.place(relx=0.0, rely=0.0, relwidth=1 - y_scroll, relheight=1 - x_scroll)
- self.y_scroll.place(relx=0.98, rely=0.0, relwidth=y_scroll, relheight=1.0)
- self.x_scroll.place(relx=0.0, rely=1 - x_scroll, relwidth=1 - y_scroll, relheight=x_scroll)
- class SearchUserProgram(SearchProgramBase):
- def __init__(self, station, win, color):
- super().__init__(station, win, color, "搜索用户")
- self.enter_frame = tk.Frame(self.frame)
- self.title: List[tk.Label] = [tk.Label(self.enter_frame) for _ in range(3)]
- self.enter: List[tk.Entry] = [tk.Entry(self.enter_frame) for _ in range(3)]
- self.var: List[tk.Variable] = [tk.StringVar() for _ in range(3)]
- self.check: List[Tuple[tk.Checkbutton, tk.Variable]] = [(tk.Checkbutton(self.enter_frame), tk.IntVar())
- for _ in range(3)]
- self.btn: tk.Button = tk.Button(self.frame)
- self._columns = ["UserID", "Name", "Phone", "Score", "Reputation", "IsManager"]
- self._columns_ch = ["用户ID[UserID]", "用户名[Name]", "手机号[Phone]",
- "积分[Score]", "垃圾分类信用[Reputation]", "是否管理员[IsManager]"]
- self.__conf_font()
- def __conf_font(self, n: int = 1):
- self.title_font_size = int(16 * n)
- self.btn_font_size = int(14 * n)
- def conf_gui(self, n: int = 1):
- self.__conf_font(n)
- title_font = make_font(size=self.title_font_size)
- btn_font = make_font(size=self.btn_font_size)
- self.enter_frame['bg'] = "#FA8072"
- self.enter_frame['bd'] = 5
- self.enter_frame['relief'] = "ridge"
- self.enter_frame.place(relx=0.2, rely=0.0, relwidth=0.6, relheight=0.30)
- height = 0.1
- for lb, text, enter, var, check in zip(self.title,
- ["用户ID:", "用户名:", "手机号:"],
- self.enter, self.var, self.check):
- lb['font'] = title_font
- lb['text'] = text
- lb['bg'] = "#FA8072"
- lb['anchor'] = 'e'
- enter['font'] = title_font
- enter['textvariable'] = var
- check[0]['font'] = title_font
- check[0]['text'] = ''
- check[0]['bg'] = "#FA8072"
- check[0]['variable'] = check[1]
- check[1].set(1)
- lb.place(relx=0.01, rely=height, relwidth=0.30, relheight=0.17)
- enter.place(relx=0.35, rely=height, relwidth=0.55, relheight=0.17)
- check[0].place(relx=0.92, rely=height, relwidth=0.04, relheight=0.17)
- height += 0.30
- self.btn['font'] = btn_font
- self.btn['text'] = "搜索"
- self.btn['bg'] = Config.tk_btn_bg
- self.btn['command'] = self.search_user
- self.btn.place(relx=0.4, rely=0.9, relwidth=0.2, relheight=0.08)
- self.conf_view_gui(self._columns_ch, relx=0.05, rely=0.32, relwidth=0.9, relheight=0.55)
- def search_user(self):
- use_uid = self.check[0][1].get()
- use_name = self.check[1][1].get()
- use_phone = self.check[2][1].get()
- uid = None
- name = None
- phone = None
- if use_uid:
- uid = self.var[0].get()
- if len(uid) == 0:
- uid = None
- if use_name:
- name = self.var[1].get()
- if len(name) == 0:
- name = None
- if use_phone:
- phone = self.var[2].get()
- if len(phone) == 0:
- phone = None
- event = tk_event.SearchUserEvent(self.station).start(self._columns, uid, name, phone, self)
- self.station.push_event(event)
- def set_disable(self):
- self.btn['state'] = 'disable'
- set_tk_disable_from_list(self.enter)
- def reset_disable(self):
- self.btn['state'] = 'normal'
- set_tk_disable_from_list(self.enter, flat='normal')
- class SearchAdvancedProgramBase(SearchProgramBase, metaclass=abc.ABCMeta):
- def __init__(self, station, win, color, title: str):
- super().__init__(station, win, color, title)
- self.enter_frame = tk.Frame(self.frame)
- self.title: tk.Label = tk.Label(self.enter_frame)
- self.enter: tk.Entry = tk.Entry(self.enter_frame)
- self.var: tk.Variable = tk.StringVar()
- self.btn: tk.Button = tk.Button(self.frame)
- self._conf([], [], "#FA8072") # 默认颜色
- self.__conf_font()
- def _conf(self, columns: list, columns_ch: list, bg_color):
- self.bg_color = bg_color
- self._columns = columns
- self._columns_ch = columns_ch
- return self
- def __conf_font(self, n: int = 1):
- self.title_font_size = int(16 * n)
- self.btn_font_size = int(14 * n)
- def conf_gui(self, n: int = 1):
- self.__conf_font(n)
- title_font = make_font(size=self.title_font_size)
- btn_font = make_font(size=self.btn_font_size)
- self.enter_frame['bg'] = self.bg_color
- self.enter_frame['bd'] = 5
- self.enter_frame['relief'] = "ridge"
- self.enter_frame.place(relx=0.2, rely=0.00, relwidth=0.6, relheight=0.10)
- self.title['font'] = title_font
- self.title['bg'] = self.bg_color
- self.title['text'] = "条件:"
- self.title['anchor'] = 'e'
- self.enter['font'] = title_font
- self.enter['textvariable'] = self.var
- self.title.place(relx=0.01, rely=0.25, relwidth=0.30, relheight=0.50)
- self.enter.place(relx=0.35, rely=0.25, relwidth=0.60, relheight=0.50)
- self.btn['text'] = "搜索"
- self.btn['font'] = btn_font
- self.btn['bg'] = Config.tk_btn_bg
- self.btn['command'] = self.search
- self.btn.place(relx=0.4, rely=0.9, relwidth=0.2, relheight=0.08)
- self.conf_view_gui(self._columns_ch, relx=0.05, rely=0.12, relwidth=0.9, relheight=0.76)
- def search(self):
- ...
- def set_disable(self):
- self.btn['state'] = 'disable'
- self.enter['state'] = 'disable'
- def reset_disable(self):
- self.btn['state'] = 'normal'
- self.enter['state'] = 'normal'
- class SearchUserAdvancedProgram(SearchAdvancedProgramBase):
- def __init__(self, station, win, color):
- super(SearchUserAdvancedProgram, self).__init__(station, win, color, "高级搜索-用户")
- columns = ["UserID", "Name", "Phone", "Score", "Reputation", "IsManager"]
- columns_ch = ["用户ID[UserID]", "用户名[Name]", "手机号[Phone]",
- "积分[Score]", "垃圾分类信用[Reputation]", "是否管理员[IsManager]"]
- self._conf(columns, columns_ch, '#48c0a3')
- def search(self):
- where = self.var.get()
- event = tk_event.SearchUserAdvancedEvent(self.station).start(self._columns, where, self)
- self.station.push_event(event)
- class SearchGarbageProgram(SearchProgramBase):
- def __init__(self, station, win, color):
- super().__init__(station, win, color, "搜索垃圾袋")
- self.enter_frame = tk.Frame(self.frame)
- self.title: List[tk.Label] = [tk.Label(self.enter_frame) for _ in range(8)]
- self.enter: List[tk.Entry] = [tk.Entry(self.enter_frame) for _ in range(8)]
- self.var: List[tk.Variable] = [tk.StringVar() for _ in range(8)]
- self.check: List[Tuple[tk.Checkbutton, tk.Variable]] = [(tk.Checkbutton(self.enter_frame), tk.IntVar())
- for _ in range(8)]
- self._columns = ["GarbageID", "UserID", "CheckerID", "CreateTime", "UseTime", "Location", "GarbageType",
- "CheckResult"]
- self._columns_zh = ["垃圾袋ID[GarbageID]", "使用者ID[UserID]", "检测者ID[CheckerID]", "创建时间[CreateTime]",
- "使用时间[UseTime]", "使用地点[Location]", "垃圾类型[GarbageType]", "检测结果[CheckResult]"]
- self.btn: tk.Button = tk.Button(self.frame)
- self.__conf_font()
- def __conf_font(self, n: int = 1):
- self.title_font_size = int(16 * n)
- self.btn_font_size = int(14 * n)
- def conf_gui(self, n: int = 1):
- self.__conf_font(n)
- title_font = make_font(size=self.title_font_size)
- btn_font = make_font(size=self.btn_font_size)
- self.enter_frame['bg'] = "#7bbfea"
- self.enter_frame['bd'] = 5
- self.enter_frame['relief'] = "ridge"
- self.enter_frame.place(relx=0.2, rely=0.0, relwidth=0.6, relheight=0.47)
- height = 0.02
- for lb, text, enter, var, check in zip(self.title,
- ["垃圾袋ID:", "使用者ID:", "检查者ID:", "创建时间:", "使用时间:",
- "使用地点:", "垃圾类型:", "检测结果:"],
- self.enter, self.var, self.check):
- lb['font'] = title_font
- lb['text'] = text
- lb['bg'] = "#7bbfea"
- lb['anchor'] = 'e'
- enter['font'] = title_font
- enter['textvariable'] = var
- check[0]['font'] = title_font
- check[0]['bg'] = "#7bbfea"
- check[0]['text'] = ''
- check[0]['variable'] = check[1]
- check[1].set(1)
- lb.place(relx=0.01, rely=height, relwidth=0.30, relheight=0.10)
- enter.place(relx=0.35, rely=height, relwidth=0.55, relheight=0.10)
- check[0].place(relx=0.92, rely=height, relwidth=0.04, relheight=0.10)
- height += 0.121
- self.btn['font'] = btn_font
- self.btn['bg'] = Config.tk_btn_bg
- self.btn['text'] = "Search"
- self.btn['command'] = self.search_user
- self.btn.place(relx=0.4, rely=0.9, relwidth=0.2, relheight=0.08)
- self.conf_view_gui(self._columns_zh, relx=0.05, rely=0.49, relwidth=0.9, relheight=0.38, x_scroll=0.07)
- def search_user(self):
- keys = ["gid", "uid", "cuid", "create_time", "use_time", "loc", "type_", "check"]
- key_values = {}
- for i, key in enumerate(keys):
- ck = self.check[i][1].get()
- if ck:
- res = self.enter[i].get()
- if len(res) > 0:
- key_values[key] = res
- continue
- key_values[key] = None
- event = tk_event.SearchGarbageEvent(self.station).start(self._columns, key_values, self)
- self.station.push_event(event)
- def set_disable(self):
- self.btn['state'] = 'disable'
- set_tk_disable_from_list(self.enter)
- def reset_disable(self):
- self.btn['state'] = 'normal'
- set_tk_disable_from_list(self.enter, flat='normal')
- class SearchGarbageAdvancedProgram(SearchAdvancedProgramBase):
- def __init__(self, station, win, color):
- super(SearchGarbageAdvancedProgram, self).__init__(station, win, color, "高级搜索-垃圾袋")
- columns = ["GarbageID", "UserID", "CheckerID", "CreateTime", "UseTime", "Location", "GarbageType",
- "CheckResult"]
- columns_zh = ["垃圾袋ID[GarbageID]", "使用者ID[UserID]", "检测者ID[CheckerID]", "创建时间[CreateTime]",
- "使用时间[UseTime]", "使用地点[Location]", "垃圾类型[GarbageType]", "检测结果[CheckResult]"]
- self._conf(columns, columns_zh, '#d1923f')
- def search(self):
- where = self.var.get()
- event = tk_event.SearchGarbageAdvancedEvent(self.station).start(self._columns, where, self)
- self.station.push_event(event)
- class SearchAdvancedProgram(SearchAdvancedProgramBase):
- def __init__(self, station, win, color):
- super(SearchAdvancedProgram, self).__init__(station, win, color, "高级搜索")
- columns = ["GarbageID", "UserID", "UserName", "UserPhone", "UserScore",
- "UserReputation", "CheckerID", "CheckerName", "CheckerPhone",
- "CreateTime", "UseTime", "Location", "GarbageType", "CheckResult"]
- columns_zh = ["垃圾袋ID[GarbageID]", "使用者ID[UserID]", "使用者名[UserName]", "使用者手机号[UserPhone]",
- "使用者积分[UserScore]", "使用者垃圾分类信用[UserReputation]", "检测者ID[CheckerID]",
- "检测这名[CheckerName]", "检测者手机号[CheckerPhone]", "创建时间[CreateTime]", "使用时间[UseTime]",
- "使用地点[Location]", "垃圾类型[GarbageType]", "检测结果[CheckResult]"]
- self._conf(columns, columns_zh, '#426ab3')
- def search(self):
- where = self.var.get()
- event = tk_event.SearchAdvancedEvent(self.station).start(self._columns, where, self)
- self.station.push_event(event)
- class UpdateUserProgramBase(AdminProgram):
- def __init__(self, station, win, color, title: str):
- super().__init__(station, win, color, title)
- self.enter_frame = tk.Frame(self.frame)
- self.title: List[tk.Label] = [tk.Label(self.enter_frame) for _ in range(2)]
- self.enter: List[tk.Entry] = [tk.Entry(self.enter_frame) for _ in range(2)]
- self.var: List[tk.Variable] = [tk.StringVar() for _ in range(2)]
- self.where_frame = tk.Frame(self.frame)
- self.where_title: List[tk.Label] = [tk.Label(self.where_frame) for _ in range(2)]
- self.where_enter: List[tk.Entry] = [tk.Entry(self.where_frame) for _ in range(2)]
- self.where_var: List[tk.Variable] = [tk.StringVar() for _ in range(2)]
- self.btn: List[tk.Button] = [tk.Button(self.frame), tk.Button(self.frame)]
- self._conf(["", ""], "#FA8072")
- self.__conf_font()
- def _conf(self, title: List[str], bg_color: str):
- self.bg_color = bg_color
- self.bg_color_where = bg_color
- self.enter_title = title
- def __conf_font(self, n: int = 1):
- self.title_font_size = int(16 * n)
- self.btn_font_size = int(14 * n)
- def conf_gui(self, n: int = 1):
- self.__conf_font(n)
- title_font = make_font(size=self.title_font_size)
- btn_font = make_font(size=self.btn_font_size)
- self.where_frame['bg'] = self.bg_color_where
- self.where_frame['bd'] = 5
- self.where_frame['relief'] = "ridge"
- self.where_frame.place(relx=0.2, rely=0.20, relwidth=0.6, relheight=0.17)
- self.enter_frame['bg'] = self.bg_color
- self.enter_frame['bd'] = 5
- self.enter_frame['relief'] = "ridge"
- self.enter_frame.place(relx=0.2, rely=0.58, relwidth=0.6, relheight=0.17)
- height = 0.1
- for lb, text, enter, var, lb_w, text_w, enter_w, var_w in (
- zip(self.title, self.enter_title, self.enter, self.var,
- self.where_title, ["条件:", self.enter_title[1]], self.where_enter, self.where_var)):
- lb['font'] = title_font
- lb['text'] = text
- lb['bg'] = self.bg_color
- lb['anchor'] = 'e'
- lb_w['font'] = title_font
- lb_w['text'] = text_w
- lb_w['bg'] = self.bg_color_where
- lb_w['anchor'] = 'e'
- enter['font'] = title_font
- enter['textvariable'] = var
- enter_w['font'] = title_font
- enter_w['textvariable'] = var_w
- lb.place(relx=0.01, rely=height, relwidth=0.30, relheight=0.35)
- enter.place(relx=0.35, rely=height, relwidth=0.60, relheight=0.35)
- lb_w.place(relx=0.01, rely=height, relwidth=0.30, relheight=0.35)
- enter_w.place(relx=0.35, rely=height, relwidth=0.60, relheight=0.35)
- height += 0.43
- for btn, text, func in zip(self.btn,
- ["通过条件更新", "通过用户ID更新"],
- [self.update_by_where, self.update_by_uid]):
- btn['font'] = btn_font
- btn['text'] = text
- btn['bg'] = Config.tk_btn_bg
- btn['command'] = func
- self.btn[0].place(relx=0.55, rely=0.40, relwidth=0.25, relheight=0.08)
- self.btn[1].place(relx=0.55, rely=0.78, relwidth=0.25, relheight=0.08)
- def update_by_uid(self):
- ...
- def update_by_where(self):
- ...
- def set_disable(self):
- set_tk_disable_from_list(self.btn)
- set_tk_disable_from_list(self.enter)
- def reset_disable(self):
- set_tk_disable_from_list(self.btn, flat='normal')
- set_tk_disable_from_list(self.enter, flat='normal')
- class UpdateUserScoreBase(UpdateUserProgramBase):
- def __init__(self, station, win, color):
- super(UpdateUserScoreBase, self).__init__(station, win, color, "更新用户-积分")
- self._conf(["用户ID:", "积分:"], "#afdfe4")
- def update_by_uid(self):
- uid = self.enter[0].get()
- score = int(self.enter[1].get())
- event = tk_event.UpdateUserScoreEvent(self.station).start(score, f"UserID='{uid}'")
- self.station.push_event(event)
- def update_by_where(self):
- where = self.where_enter[0].get()
- score = int(self.where_enter[1].get())
- event = tk_event.UpdateUserScoreEvent(self.station).start(score, where)
- self.station.push_event(event)
- class UpdateUserReputationBase(UpdateUserProgramBase):
- def __init__(self, station, win, color):
- super(UpdateUserReputationBase, self).__init__(station, win, color, "更新用户-垃圾分类信用")
- self._conf(["用户ID:", "垃圾分类信用:"], "#f8aba6")
- def update_by_uid(self):
- uid = self.enter[0].get()
- reputation = int(self.enter[1].get())
- event = tk_event.UpdateUserReputationEvent(self.station).start(reputation, f"UserID='{uid}'")
- self.station.push_event(event)
- def update_by_where(self):
- where = self.where_enter[0].get()
- reputation = int(self.where_enter[1].get())
- event = tk_event.UpdateUserReputationEvent(self.station).start(reputation, where)
- self.station.push_event(event)
- class UpdateGarbageTypeProgram(AdminProgram):
- def __init__(self, station, win, color):
- super().__init__(station, win, color, "更新垃圾袋-垃圾类型")
- self.enter_frame = tk.Frame(self.frame)
- self.title: tk.Label = tk.Label(self.enter_frame)
- self.enter: tk.Entry = tk.Entry(self.enter_frame)
- self.type: List[tk.Radiobutton] = [tk.Radiobutton(self.frame) for _ in range(4)]
- self.var: List[tk.Variable] = [tk.StringVar, tk.IntVar()]
- self.where_frame = tk.Frame(self.frame)
- self.where_title: tk.Label = tk.Label(self.where_frame)
- self.where_enter: tk.Entry = tk.Entry(self.where_frame)
- self.where_type: List[tk.Radiobutton] = [tk.Radiobutton(self.frame) for _ in range(4)]
- self.where_var: List[tk.Variable] = [tk.StringVar, tk.IntVar()]
- self.btn: List[tk.Button] = [tk.Button(self.frame), tk.Button(self.frame)]
- self.__conf_font()
- def __conf_font(self, n: int = 1):
- self.title_font_size = int(16 * n)
- self.btn_font_size = int(14 * n)
- def conf_gui(self, n: int = 1):
- self.__conf_font(n)
- title_font = make_font(size=self.title_font_size)
- btn_font = make_font(size=self.btn_font_size)
- self.where_frame['bg'] = "#fdb933"
- self.where_frame['bd'] = 5
- self.where_frame['relief'] = "ridge"
- self.where_frame.place(relx=0.2, rely=0.20, relwidth=0.6, relheight=0.10)
- self.enter_frame['bg'] = "#fdb933"
- self.enter_frame['bd'] = 5
- self.enter_frame['relief'] = "ridge"
- self.enter_frame.place(relx=0.2, rely=0.60, relwidth=0.6, relheight=0.10)
- for lb, enter, radios, var, y, text in zip([self.title, self.where_title],
- [self.enter, self.where_enter],
- [self.type, self.where_type],
- [self.var, self.where_var],
- [0.32, 0.72],
- ["垃圾袋ID:", "条件:"]):
- lb['font'] = title_font
- lb['text'] = text
- lb['bg'] = "#fdb933"
- lb['anchor'] = 'e'
- enter['font'] = title_font
- enter['textvariable'] = var[0]
- for i, radio in enumerate(radios):
- radio['font'] = btn_font
- radio['bg'] = self.color
- radio['text'] = GarbageType.GarbageTypeStrList_ch[i + 1]
- radio['value'] = i + 1
- radio['variable'] = var[1]
- radio['anchor'] = 'w'
- var[1].set(1)
- radios[0].place(relx=0.20, rely=y + 0.00, relwidth=0.20, relheight=0.04)
- radios[1].place(relx=0.60, rely=y + 0.00, relwidth=0.20, relheight=0.04)
- radios[2].place(relx=0.20, rely=y + 0.05, relwidth=0.20, relheight=0.04)
- radios[3].place(relx=0.60, rely=y + 0.05, relwidth=0.20, relheight=0.04)
- lb.place(relx=0.02, rely=0.2, relwidth=0.25, relheight=0.48)
- enter.place(relx=0.30, rely=0.2, relwidth=0.60, relheight=0.48)
- for btn, text, func in zip(self.btn,
- ["通过条件更新", "通过垃圾袋ID更新"],
- [self.update_by_where, self.update_by_gid]):
- btn['font'] = btn_font
- btn['text'] = text
- btn['bg'] = Config.tk_btn_bg
- btn['command'] = func
- self.btn[0].place(relx=0.55, rely=0.43, relwidth=0.25, relheight=0.08)
- self.btn[1].place(relx=0.55, rely=0.83, relwidth=0.25, relheight=0.08)
- def update_by_gid(self):
- gid = self.enter.get()
- type_ = self.var[1].get()
- event = tk_event.UpdateGarbageTypeEvent(self.station).start(type_, f"GarbageID={gid}")
- self.station.push_event(event)
- def update_by_where(self):
- where = self.where_enter.get()
- type_ = self.where_var[1].get()
- event = tk_event.UpdateGarbageTypeEvent(self.station).start(type_, where)
- self.station.push_event(event)
- def set_disable(self):
- set_tk_disable_from_list(self.btn)
- self.enter['state'] = 'disable'
- self.where_enter['state'] = 'normal'
- def reset_disable(self):
- set_tk_disable_from_list(self.btn, flat='normal')
- self.enter['state'] = 'normal'
- self.where_enter['state'] = 'normal'
- class UpdateGarbageCheckResultProgram(AdminProgram):
- def __init__(self, station, win, color):
- super().__init__(station, win, color, "更新垃圾袋-检测结果")
- self.enter_frame = tk.Frame(self.frame)
- self.title: tk.Label = tk.Label(self.enter_frame)
- self.enter: tk.Entry = tk.Entry(self.enter_frame)
- self.type: List[tk.Radiobutton] = [tk.Radiobutton(self.frame) for _ in range(2)]
- self.var: List[tk.Variable] = [tk.StringVar, tk.IntVar()]
- self.where_frame = tk.Frame(self.frame)
- self.where_title: tk.Label = tk.Label(self.where_frame)
- self.where_enter: tk.Entry = tk.Entry(self.where_frame)
- self.where_type: List[tk.Radiobutton] = [tk.Radiobutton(self.frame) for _ in range(2)]
- self.where_var: List[tk.Variable] = [tk.StringVar, tk.IntVar()]
- self.btn: List[tk.Button] = [tk.Button(self.frame), tk.Button(self.frame)]
- self.__conf_font()
- def __conf_font(self, n: int = 1):
- self.title_font_size = int(16 * n)
- self.btn_font_size = int(14 * n)
- def conf_gui(self, n: int = 1):
- self.__conf_font(n)
- title_font = make_font(size=self.title_font_size)
- btn_font = make_font(size=self.btn_font_size)
- self.where_frame['bg'] = "#abc88b"
- self.where_frame['bd'] = 5
- self.where_frame['relief'] = "ridge"
- self.where_frame.place(relx=0.2, rely=0.20, relwidth=0.6, relheight=0.10)
- self.enter_frame['bg'] = "#abc88b"
- self.enter_frame['bd'] = 5
- self.enter_frame['relief'] = "ridge"
- self.enter_frame.place(relx=0.2, rely=0.60, relwidth=0.6, relheight=0.10)
- for lb, enter, radios, var, y, text in zip([self.title, self.where_title],
- [self.enter, self.where_enter],
- [self.type, self.where_type],
- [self.var, self.where_var],
- [0.32, 0.72],
- ["垃圾袋ID:", "条件:"]):
- lb['font'] = title_font
- lb['text'] = text
- lb['bg'] = "#abc88b"
- lb['anchor'] = 'e'
- enter['font'] = title_font
- enter['textvariable'] = var[0]
- for i, radio in enumerate(radios):
- radio['font'] = btn_font
- radio['bg'] = self.color
- radio['text'] = ["投放错误", "投放正确"][i]
- radio['value'] = i
- radio['variable'] = var[1]
- radio['anchor'] = 'w'
- var[1].set(1)
- radios[0].place(relx=0.20, rely=y + 0.00, relwidth=0.20, relheight=0.04)
- radios[1].place(relx=0.60, rely=y + 0.00, relwidth=0.20, relheight=0.04)
- lb.place(relx=0.02, rely=0.2, relwidth=0.25, relheight=0.48)
- enter.place(relx=0.30, rely=0.2, relwidth=0.60, relheight=0.48)
- for btn, text, func in zip(self.btn,
- ["通过条件更新", "通过垃圾袋ID更新"],
- [self.update_by_where, self.update_by_gid]):
- btn['font'] = btn_font
- btn['bg'] = Config.tk_btn_bg
- btn['text'] = text
- btn['command'] = func
- self.btn[0].place(relx=0.55, rely=0.38, relwidth=0.25, relheight=0.08)
- self.btn[1].place(relx=0.55, rely=0.78, relwidth=0.25, relheight=0.08)
- def update_by_gid(self):
- gid = self.enter.get()
- check = (self.var[1].get() == 1)
- event = tk_event.UpdateGarbageCheckEvent(self.station).start(check, f"GarbageID={gid}")
- self.station.push_event(event)
- def update_by_where(self):
- where = self.where_enter.get()
- check = (self.where_var[1].get() == 1)
- event = tk_event.UpdateGarbageCheckEvent(self.station).start(check, where)
- self.station.push_event(event)
- def set_disable(self):
- set_tk_disable_from_list(self.btn)
- self.enter['state'] = 'disable'
- self.where_enter['state'] = 'normal'
- def reset_disable(self):
- set_tk_disable_from_list(self.btn, flat='normal')
- self.enter['state'] = 'normal'
- self.where_enter['state'] = 'normal'
- all_program = [WelcomeProgram, CreateNormalUserProgram, CreateManagerUserProgram, CreateAutoNormalUserProgram,
- CreateGarbageProgram, DeleteUserProgram, DeleteUsersProgram, DeleteGarbageProgram,
- DeleteGarbageMoreProgram, DeleteAllGarbageProgram, SearchUserProgram, SearchUserAdvancedProgram,
- SearchGarbageProgram, SearchGarbageAdvancedProgram, SearchAdvancedProgram, UpdateUserScoreBase,
- UpdateUserReputationBase, UpdateGarbageTypeProgram, UpdateGarbageCheckResultProgram,
- ExportGarbageProgram, ExportUserProgram, CreateUserFromCSVProgram, AboutProgram]
|