diff --git a/view.py b/view.py index 50bd8f8f..d16fe3c4 100644 --- a/view.py +++ b/view.py @@ -37,6 +37,7 @@ class View(): self.view_variable = SimpleNamespace( # Main Window + # Sidebar # Sidebar Compact Mode IS_MAIN_WINDOW_SIDEBAR_COMPACT_MODE=False, CALLBACK_TOGGLE_MAIN_WINDOW_SIDEBAR_COMPACT_MODE=None, @@ -54,7 +55,7 @@ class View(): VAR_LABEL_FOREGROUND=StringVar(value="Foreground"), CALLBACK_TOGGLE_FOREGROUND=None, - # Language Settings + # Sidebar Language Settings VAR_LABEL_LANGUAGE_SETTINGS=StringVar(value="Language Settings"), # JA: 言語設定 LIST_SELECTABLE_LANGUAGES=[], @@ -70,6 +71,14 @@ class View(): CALLBACK_SELECTED_TARGET_LANGUAGE=None, + VAR_LABEL_TEXTBOX_ALL=StringVar(value="All"), # JA: 全て + VAR_LABEL_TEXTBOX_SENT=StringVar(value="Sent"), # JA: 送信 + VAR_LABEL_TEXTBOX_RECEIVED=StringVar(value="Received"), # JA: 受信 + VAR_LABEL_TEXTBOX_SYSTEM=StringVar(value="System"), # JA: システム + + + + # Config Window # Appearance Tab diff --git a/vrct_gui/main_window/createMainWindowWidgets.py b/vrct_gui/main_window/createMainWindowWidgets.py index d55a66ed..4e65aa31 100644 --- a/vrct_gui/main_window/createMainWindowWidgets.py +++ b/vrct_gui/main_window/createMainWindowWidgets.py @@ -60,6 +60,6 @@ def createMainWindowWidgets(vrct_gui, settings, view_variable): createMinimizeSidebarButton(settings, vrct_gui, view_variable) - createTextbox(settings, vrct_gui) + createTextbox(settings, vrct_gui, view_variable) createEntryMessageBox(settings, vrct_gui) \ No newline at end of file diff --git a/vrct_gui/main_window/widgets/create_textbox.py b/vrct_gui/main_window/widgets/create_textbox.py index eb301ba5..14a5ba5f 100644 --- a/vrct_gui/main_window/widgets/create_textbox.py +++ b/vrct_gui/main_window/widgets/create_textbox.py @@ -3,7 +3,7 @@ from customtkinter import CTkFont, CTkFrame, CTkLabel, CTkTextbox from ...ui_utils import getLatestWidth, getLongestText, bindEnterAndLeaveColor, bindButtonPressColor, bindButtonReleaseFunction, _setDefaultActiveTab, switchActiveTabAndPassiveTab, switchTabsColor -def createTextbox(settings, main_window): +def createTextbox(settings, main_window, view_variable): def switchTextbox(target_textbox_attr_name): main_window.current_active_textbox.grid_remove() @@ -78,70 +78,59 @@ def createTextbox(settings, main_window): "textbox_tab_attr_name": "textbox_tab_all", "command": switchToTextboxAll, "textbox_attr_name": "textbox_all", - "text": "All", + "textvariable": view_variable.VAR_LABEL_TEXTBOX_ALL }, { "textbox_tab_attr_name": "textbox_tab_sent", "command": switchToTextboxSent, "textbox_attr_name": "textbox_sent", - "text": "Sent", + "textvariable": view_variable.VAR_LABEL_TEXTBOX_SENT }, - { "textbox_tab_attr_name": "textbox_tab_received", "command": switchToTextboxReceived, "textbox_attr_name": "textbox_received", - "text": "Received", + "textvariable": view_variable.VAR_LABEL_TEXTBOX_RECEIVED }, - { "textbox_tab_attr_name": "textbox_tab_system", "command": switchToTextboxSystem, "textbox_attr_name": "textbox_system", - "text": "System", + "textvariable": view_variable.VAR_LABEL_TEXTBOX_SYSTEM }, ] - longest_text = getLongestText(textbox_settings) - - setattr(main_window, "_mlw", CTkLabel( - main_window, - text=longest_text, - corner_radius=0, - font=CTkFont(family=settings.FONT_FAMILY, size=settings.uism.TEXTBOX_TAB_FONT_SIZE, weight="normal"), - height=0, - anchor="center", - )) - label_widget = getattr(main_window, "_mlw") - label_widget.grid() - MAX_LABEL_WIDTH = getLatestWidth(label_widget) - label_widget.grid_remove() - - column=0 for textbox_setting in textbox_settings: - setattr(main_window, textbox_setting["textbox_tab_attr_name"], CTkFrame(main_window.textbox_switch_tabs_container, corner_radius=settings.uism.TEXTBOX_TAB_CORNER_RADIUS, fg_color=settings.ctm.TEXTBOX_TAB_BG_PASSIVE_COLOR, cursor="hand2", width=0, height=0) + setattr(main_window, textbox_setting["textbox_tab_attr_name"], + CTkFrame( + main_window.textbox_switch_tabs_container, + corner_radius=settings.uism.TEXTBOX_TAB_CORNER_RADIUS, + fg_color=settings.ctm.TEXTBOX_TAB_BG_PASSIVE_COLOR, + cursor="hand2", + width=0, + height=0 + ) ) target_widget = getattr(main_window, textbox_setting["textbox_tab_attr_name"]) target_widget.grid(row=0, column=column, pady=0, padx=(0,2), sticky="ew") + target_widget.columnconfigure((0,2), weight=1) setattr(main_window, "label_widget", CTkLabel( target_widget, - text=textbox_setting["text"], + textvariable=textbox_setting["textvariable"], corner_radius=0, font=CTkFont(family=settings.FONT_FAMILY, size=settings.uism.TEXTBOX_TAB_FONT_SIZE, weight="normal"), height=0, - width=MAX_LABEL_WIDTH, + width=0, anchor="center", text_color=settings.ctm.TEXTBOX_TAB_TEXT_PASSIVE_COLOR, )) label_widget = getattr(main_window, "label_widget") - label_widget.grid(row=0, column=column) - - label_widget.grid(row=0, column=column, pady=settings.uism.TEXTBOX_TAB_PADY, padx=settings.uism.TEXTBOX_TAB_PADX) + label_widget.grid(row=0, column=1, pady=settings.uism.TEXTBOX_TAB_PADY, padx=settings.uism.TEXTBOX_TAB_PADX) bindEnterAndLeaveColor([target_widget, label_widget], settings.ctm.TEXTBOX_TAB_BG_HOVERED_COLOR, settings.ctm.TEXTBOX_TAB_BG_PASSIVE_COLOR) bindButtonPressColor([target_widget, label_widget], settings.ctm.TEXTBOX_TAB_BG_CLICKED_COLOR, settings.ctm.TEXTBOX_TAB_BG_PASSIVE_COLOR)