Introduced a Manager to centralize plugin/package management

Should have done this from the start.
Will move other relevant scattered functions to this type.
For now it checks if the restart banner needs to show.
Taking into account that a user can toggle between enable
and disable without an actual restart. Even with multiple
plugins.

Contributes to: CURA-8587
This commit is contained in:
Jelle Spijker 2021-12-08 08:06:56 +01:00
parent a61c3e9eff
commit 6c976bc9b0
No known key found for this signature in database
GPG key ID: 6662DC033BE6B99A
4 changed files with 38 additions and 4 deletions

View file

@ -13,6 +13,7 @@ from UM.PluginRegistry import PluginRegistry # To find out where we are stored
from .RemotePackageList import RemotePackageList # To register this type with QML.
from .LocalPackageList import LocalPackageList # To register this type with QML.
from .Manager import Manager # To register this type with QML.
if TYPE_CHECKING:
from PyQt5.QtCore import QObject
@ -30,6 +31,7 @@ class Marketplace(Extension):
qmlRegisterType(RemotePackageList, "Marketplace", 1, 0, "RemotePackageList")
qmlRegisterType(LocalPackageList, "Marketplace", 1, 0, "LocalPackageList")
qmlRegisterType(Manager, "Marketplace", 1, 0, "Manager")
@pyqtSlot()
def show(self) -> None:
@ -44,7 +46,7 @@ class Marketplace(Extension):
if plugin_path is None:
plugin_path = os.path.dirname(__file__)
path = os.path.join(plugin_path, "resources", "qml", "Marketplace.qml")
self._window = CuraApplication.getInstance().createQmlComponent(path, {"plugin_registry": self.plugin_registry})
self._window = CuraApplication.getInstance().createQmlComponent(path, {})
if self._window is None: # Still None? Failed to load the QML then.
return
self._window.show()