Some checks failed
CI / test (push) Has been cancelled
핵심 기능: - 단축근무·표준·반일 등 다양한 근무 패턴 (5개 프리셋 + 사용자 정의) - Windows 이벤트 뷰어 자동 출퇴근 감지 - 30분 단위 연장근무 적립/사용 시스템 - 1.0/0.5/0.25일 연차·반차·반반차 - 자동 점심·저녁·외출·자동 백업·화면 잠금 자동 외출 - 한국 공휴일 자동 등록 (음력 포함, holidays 패키지) - matplotlib 차트 기반 주간/월간/패턴 통계 - 미니 위젯 + 시스템 트레이 통합 - 한국어/English i18n - 자가 업데이트 (updater.exe + Gitea Releases) 아키텍처: - core/ (db, time_calculator, notifier, i18n, version, settings_keys) - ui/ (main_window + 9 dialogs + 3 controllers) - utils/ (backup, lock_detector, debug_log, updater_client, time_format) - tests/ (66 pytest 단위) + 통합/i18n GUI 검증 CI/CD: - .gitea/workflows/ci.yml: push 시 pytest + 통합 테스트 - .gitea/workflows/release.yml: v* 태그 push 시 두 .exe 자동 빌드 + Releases 첨부 Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
85 lines
2.6 KiB
Python
85 lines
2.6 KiB
Python
"""
|
|
사용 설명 가이드 창.
|
|
|
|
i18n 사전(_HELP_HTML)에서 ko/en HTML을 가져와 6개 탭으로 표시.
|
|
"""
|
|
from PyQt5.QtWidgets import (QDialog, QVBoxLayout, QHBoxLayout, QLabel,
|
|
QPushButton, QWidget, QTabWidget, QTextBrowser)
|
|
from PyQt5.QtCore import Qt
|
|
|
|
from core.i18n import tr, tr_html
|
|
from ui.styles import apply_dark_titlebar
|
|
|
|
|
|
class HelpView(QDialog):
|
|
"""사용 설명 가이드 다이얼로그"""
|
|
|
|
# (사전 키, 탭 라벨 키)
|
|
_TABS = [
|
|
('help.html.intro', 'help.tab_intro'),
|
|
('help.html.work_hours', 'help.tab_work_hours'),
|
|
('help.html.overtime', 'help.tab_overtime'),
|
|
('help.html.leave', 'help.tab_leave'),
|
|
('help.html.break', 'help.tab_break'),
|
|
('help.html.faq', 'help.tab_faq'),
|
|
]
|
|
|
|
def __init__(self, parent=None):
|
|
super().__init__(parent)
|
|
self.setWindowTitle(tr('window.help'))
|
|
self.setModal(True)
|
|
self.setMinimumSize(680, 720)
|
|
|
|
self.init_ui()
|
|
apply_dark_titlebar(self)
|
|
|
|
def init_ui(self):
|
|
main_layout = QVBoxLayout()
|
|
main_layout.setContentsMargins(0, 0, 0, 0)
|
|
main_layout.setSpacing(0)
|
|
|
|
title = QLabel(tr('window.help'))
|
|
title.setObjectName("dialog_title")
|
|
title.setAlignment(Qt.AlignCenter)
|
|
main_layout.addWidget(title)
|
|
|
|
tabs = QTabWidget()
|
|
tabs.setDocumentMode(True)
|
|
for html_key, tab_label_key in self._TABS:
|
|
tabs.addTab(self._make_tab(tr_html(html_key)), tr(tab_label_key))
|
|
main_layout.addWidget(tabs)
|
|
|
|
button_layout = QHBoxLayout()
|
|
button_layout.setContentsMargins(20, 10, 20, 20)
|
|
button_layout.addStretch()
|
|
close_button = QPushButton(tr('btn.close'))
|
|
close_button.setObjectName("btn_primary")
|
|
close_button.setMinimumHeight(40)
|
|
close_button.setMinimumWidth(120)
|
|
close_button.clicked.connect(self.close)
|
|
button_layout.addWidget(close_button)
|
|
button_layout.addStretch()
|
|
main_layout.addLayout(button_layout)
|
|
|
|
self.setLayout(main_layout)
|
|
|
|
def _make_tab(self, html: str) -> QWidget:
|
|
container = QWidget()
|
|
layout = QVBoxLayout()
|
|
layout.setContentsMargins(16, 12, 16, 12)
|
|
browser = QTextBrowser()
|
|
browser.setOpenExternalLinks(False)
|
|
browser.setHtml(html)
|
|
layout.addWidget(browser)
|
|
container.setLayout(layout)
|
|
return container
|
|
|
|
|
|
# 단독 실행 테스트
|
|
if __name__ == "__main__":
|
|
import sys
|
|
from PyQt5.QtWidgets import QApplication
|
|
app = QApplication(sys.argv)
|
|
dialog = HelpView()
|
|
dialog.exec_()
|