1
0
Fork 0
mirror of synced 2024-07-01 04:30:20 +12:00
Rare/rare/components/tabs/settings/about.py

74 lines
2.4 KiB
Python
Raw Normal View History

import webbrowser
from logging import getLogger
from PyQt5.QtCore import pyqtSignal
from PyQt5.QtGui import QShowEvent
2021-04-22 08:54:24 +12:00
from PyQt5.QtWidgets import QWidget
from rare import __version__, __codename__
from rare.ui.components.tabs.settings.about import Ui_About
from rare.utils.qt_requests import QtRequests
logger = getLogger("About")
2021-02-20 00:57:55 +13:00
def versiontuple(v):
2021-04-09 23:18:58 +12:00
try:
return tuple(map(int, (v.split("."))))
except Exception:
return 9, 9, 9
class About(QWidget):
update_available_ready = pyqtSignal()
def __init__(self, parent=None):
super(About, self).__init__(parent=parent)
self.ui = Ui_About()
self.ui.setupUi(self)
2021-02-20 00:57:55 +13:00
self.ui.version.setText(f"{__version__} {__codename__}")
2021-04-22 08:54:24 +12:00
self.ui.update_label.setEnabled(False)
self.ui.update_lbl.setEnabled(False)
self.ui.open_browser.setVisible(False)
self.ui.open_browser.setEnabled(False)
2021-02-20 00:57:55 +13:00
self.manager = QtRequests(parent=self)
2021-12-24 22:09:50 +13:00
self.manager.get(
2023-11-29 02:20:06 +13:00
"https://api.github.com/repos/RareDevs/Rare/releases/latest",
2021-12-24 22:09:50 +13:00
self.update_available_finished,
)
2021-04-22 08:54:24 +12:00
self.ui.open_browser.clicked.connect(
2023-11-29 02:20:06 +13:00
lambda: webbrowser.open("https://github.com/RareDevs/Rare/releases/latest")
2021-12-24 22:09:50 +13:00
)
2021-04-22 08:54:24 +12:00
self.update_available = False
def showEvent(self, a0: QShowEvent) -> None:
if a0.spontaneous():
return super().showEvent(a0)
self.manager.get(
2023-11-29 02:20:06 +13:00
"https://api.github.com/repos/RareDevs/Rare/releases/latest",
self.update_available_finished,
)
super().showEvent(a0)
def update_available_finished(self, data: dict):
if latest_tag := data.get("tag_name"):
self.update_available = versiontuple(latest_tag) > versiontuple(__version__)
else:
self.update_available = False
if self.update_available:
logger.info(f"Update available: {__version__} -> {latest_tag}")
self.ui.update_lbl.setText(f"{__version__} -> {latest_tag}")
self.update_available_ready.emit()
else:
self.ui.update_lbl.setText(self.tr("You have the latest version"))
self.ui.update_label.setEnabled(self.update_available)
self.ui.update_lbl.setEnabled(self.update_available)
self.ui.open_browser.setVisible(self.update_available)
self.ui.open_browser.setEnabled(self.update_available)