-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathTIMS.py
121 lines (95 loc) · 4.11 KB
/
TIMS.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
# -*-coding: utf-8-*-
import tkinter as tk
from tkinter import ttk, font, filedialog, messagebox
import threading
import os, platform, sys
import discord
import subprocess
window = tk.Tk()
# 창 기본 설정
window.title('TIMS - 참치봇 통합 관리 시스템')
window.geometry('960x540+200+200')
window.resizable(False, False)
# 탭 설정
NotebookTabs = ttk.Notebook(window, width=700, height=430)
NotebookTabs.place(x=250, y=40)
# 봇 로그 탭(Notebook1) 추가
Notebook1 = tk.Frame(window)
NotebookTabs.add(Notebook1, text='봇 로그')
ScrollbarBotLog = ttk.Scrollbar(Notebook1)
ScrollbarBotLog.pack(side='right', fill='y')
font = tk.font.Font(family='굴림체', size=9)
TextBotLog = tk.Text(Notebook1, yscrollcommand=ScrollbarBotLog.set, width=700, height=430, background='gray15', foreground='white', font=font)
TextBotLog.pack(side='left')
ScrollbarBotLog['command'] = TextBotLog.yview
TextBotLog.insert(tk.END, '와아아아아아아아아아아아아아아아아아아아아아아아아아아아아아아아아아아아아아아아아새애애애애애애애애애애애애애애애애애애앤즈으으으으으으으으으으으으으으은')
for x in range(40):
TextBotLog.insert(tk.END, 'SANS\n')
TextBotLog.config(state='disabled')
# 콘솔 탭(NoteBook2) 추가
Notebook2 = tk.Frame(window)
if platform.system() == 'Windows':
NotebookTabs.add(Notebook2, text='명령 프롬프트')
elif platform.system() == 'Linux':
NotebookTabs.add(Notebook2, text='터미널')
ScrollbarConsole = tk.Scrollbar(Notebook2)
ScrollbarConsole.pack(side='right', fill='y')
TextConsole = tk.Text(Notebook2, width=700, height=430,
background='gray15', foreground='white', font=font, yscrollcommand=ScrollbarConsole.set)
TextConsole.pack()
#TextConsole.insert(tk.END, )
# 상단 배너 설정
imgLabelBanner = tk.PhotoImage(file='./resources/tims-label.png')
LabelBanner = tk.Label(window, image=imgLabelBanner)
LabelBanner.place(x=-5, y=-1)
# 좌측 로고 설정
imgLabelLogo = tk.PhotoImage(file='./resources/TunaBot-text.png')
LabelLogo = tk.Label(window, image=imgLabelLogo)
LabelLogo.place(x=5, y=35)
# 좌측 로고 개발자 라벨
font = tk.font.Font(family='맑은 고딕', size=10)
LabelBy = tk.Label(window, text='By ArpaAP\nin InfiniteTEAM', font=font, justify='left')
LabelBy.place(x=110, y=40)
# 봇 토큰 입력칸 설정
LabelBotToken = tk.Label(window, text='봇 토큰:')
LabelBotToken.place(x=10, y=90)
EntryBotToken = ttk.Entry(window, show='●')
EntryBotToken.place(x=80, y=90, width=162)
# =============== 봇 코드 시작 ===============
client = discord.Client()
@client.event
async def on_ready():
print(client.user.id)
await client.change_presence(status=discord.Status.dnd, activity=discord.Game('InfinieTEAM'))
@client.event
async def on_message(message):
if message.content.startswith('hu'):
await message.channel.send('dwdw')
# =============== 봇 코드 종료 ===============
def botThread():
client.run(EntryBotToken.get())
# 봇 실행 사전 준비
def botStart():
ButtonBotStart.config(state='disabled')
if EntryBotToken.get():
threading.Thread(target=botThread,
daemon=True).start() # 봇 소스 파일이 실행되는 동안 프로그램 진행이 멈추고 응답 없음이 되므로, 멀티스레딩으로 해결.
else:
messagebox.showerror('토큰 오류', '토큰을 입력하세요')
def botStop():
pass
# 봇 시작 버튼 설정
ButtonBotStart = ttk.Button(window, text="봇 시작", command=botStart)
ButtonBotStart.place(x=10, y=118, width=113)
# 봇 정지 버튼 설정
ButtonBotStop = ttk.Button(window, text="봇 정지", command=botStop)
ButtonBotStop.place(x=130, y=118, width=113)
# 창이 닫힐 때 알림상자.
def onClosing():
if str(ButtonBotStart['state']) == 'disabled':
if messagebox.askyesno('종료', '현재 봇 세션이 실행중입니다. 지금 닫으면 세션을 강제 종료하게 됩니다. 봇 종료를 통해 안전하게 종료한 후 닫는 것을 권장합니다.'):
sys.exit()
else:
window.destroy()
window.protocol('WM_DELETE_WINDOW', onClosing)
window.mainloop()