Fixed some embarassing bugs wrt to %s strings outside logging, & made theme selections persist between list rebuilds

This commit is contained in:
anne 2023-07-26 16:09:48 +02:00
parent 95060f9bdd
commit d3ee9d07e0

View file

@ -139,7 +139,7 @@ class ThemeManager(QtCore.QObject):
PchumLog.debug("(force_install is enabled)") PchumLog.debug("(force_install is enabled)")
if not theme_name in self.database_entries: if not theme_name in self.database_entries:
PchumLog.error("Theme %s does not exist in the database!", theme_name) PchumLog.error("Theme %s does not exist in the database!", theme_name)
self.errored.emit("Theme %s does not exist in the database!", theme_name) self.errored.emit("Theme %s does not exist in the database!" % theme_name)
return return
all_themes = self.config.availableThemes() all_themes = self.config.availableThemes()
@ -192,9 +192,8 @@ class ThemeManager(QtCore.QObject):
theme["inherits"], theme["inherits"],
) )
self.errored.emit( self.errored.emit(
"Theme %s requires theme %s, which is not installed and not in the database. Cancelling install", "Theme %s requires theme %s, which is not installed and not in the database. Cancelling install"
theme_name, % (theme_name, theme["inherits"])
theme["inherits"],
) )
return return
@ -214,8 +213,8 @@ class ThemeManager(QtCore.QObject):
theme_name, theme_name,
) )
self.errored.emit( self.errored.emit(
"Theme %s is already installed, and no update is available. Cancelling install", "Theme %s is already installed, and no update is available. Cancelling install"
theme_name, % theme_name
) )
return return
@ -252,7 +251,7 @@ class ThemeManager(QtCore.QObject):
"An error occured contacting the repository: %s", reply.error() "An error occured contacting the repository: %s", reply.error()
) )
self.errored.emit( self.errored.emit(
"An error occured contacting the repository: %s", reply.error() "An error occured contacting the repository: %s" % reply.error()
) )
return return
try: try:
@ -297,13 +296,13 @@ class ThemeManager(QtCore.QObject):
except json.decoder.JSONDecodeError as e: except json.decoder.JSONDecodeError as e:
PchumLog.error("Could not decode theme database JSON: %s", e) PchumLog.error("Could not decode theme database JSON: %s", e)
self.errored.emit("Could not decode theme database JSON: %s", e) self.errored.emit("Could not decode theme database JSON: %s" % e)
return return
except KeyError as e: except KeyError as e:
self.database = {} self.database = {}
self.database_entries = {} self.database_entries = {}
PchumLog.error("Vital key missing from theme database: %s", e) PchumLog.error("Vital key missing from theme database: %s", e)
self.errored.emit("Vital key missing from theme database: %s", e) self.errored.emit("Vital key missing from theme database: %s" % e)
return return
def _handle_downloaded_zip(self, zip_buffer, theme_name): def _handle_downloaded_zip(self, zip_buffer, theme_name):
@ -485,38 +484,32 @@ class ThemeManagerWidget(QtWidgets.QWidget):
self.btn_uninstall.setVisible(themeManager.is_installed(theme_name)) self.btn_uninstall.setVisible(themeManager.is_installed(theme_name))
self.lbl_theme_name.setText(theme_name) self.lbl_theme_name.setText(theme_name)
self.lbl_author_name.setText("By %s", theme["author"]) self.lbl_author_name.setText("By %s" % theme["author"])
self.lbl_description.setText(theme["description"]) self.lbl_description.setText(theme["description"])
version_text = "Version %s", theme["version"] version_text = "Version %s" % theme["version"]
if has_update: if has_update:
version_text += ( version_text += (
" (installed: %s)", " (installed: %s)" % themeManager.manifest[theme_name]["version"]
themeManager.manifest[theme_name]["version"],
) )
self.lbl_version.setText(version_text) self.lbl_version.setText(version_text)
self.lbl_requires.setText( requires_text = ""
( if theme["inherits"]:
"Requires %s", requires_text += "Requires %s" % theme["inherits"]
theme["inherits"] if theme["inherits"] in self.config.availableThemes():
+ ( requires_text += " (installed)"
" (installed)" self.lbl_requires.setText((requires_text) if theme["inherits"] else "")
if theme["inherits"] in self.config.availableThemes() last_update_text = "Released on: "
else "" last_update_text += datetime.fromtimestamp(theme["updated"]).strftime(
), "%d/%m/%Y, %H:%M"
)
if theme["inherits"]
else ""
)
self.lbl_last_update.setText(
"Released on: "
+ datetime.fromtimestamp(theme["updated"]).strftime("%d/%m/%Y, %H:%M")
) )
self.lbl_last_update.setText(last_update_text)
@QtCore.pyqtSlot(dict) @QtCore.pyqtSlot(dict)
def _on_database_refreshed(self, _): def _on_database_refreshed(self, _):
self.rebuild() self.rebuild()
def rebuild(self): def rebuild(self):
prev_selected_index = self.list_results.currentRow()
database = themeManager.database database = themeManager.database
self.list_results.clear() self.list_results.clear()
self.lbl_error.setText("") self.lbl_error.setText("")
@ -538,10 +531,16 @@ class ThemeManagerWidget(QtWidgets.QWidget):
else: else:
status = "~ (installed)" status = "~ (installed)"
icon = self.icons[1] icon = self.icons[1]
text = "%s by %s %s", (dbitem["name"], dbitem["author"], status) text = "%s by %s %s" % (dbitem["name"], dbitem["author"], status)
item = QtWidgets.QListWidgetItem(icon, text) item = QtWidgets.QListWidgetItem(icon, text)
self.list_results.addItem(item) self.list_results.addItem(item)
if prev_selected_index > -1:
# Re-select last item, if it was selected
self.list_results.setCurrentRow(prev_selected_index)
self._on_theme_selected(self.list_results.currentItem())
else:
# Return sidebar info panel to defaults if nothing was selected
self.btn_install.setDisabled(True) self.btn_install.setDisabled(True)
for lbl in [ for lbl in [
self.lbl_author_name, self.lbl_author_name,