diff --git a/plugins/ChangeLogPlugin/ChangeLog.py b/plugins/ChangeLogPlugin/ChangeLog.py
index 7586268aa6..7c8c81f2c6 100644
--- a/plugins/ChangeLogPlugin/ChangeLog.py
+++ b/plugins/ChangeLogPlugin/ChangeLog.py
@@ -28,9 +28,10 @@ class ChangeLog(Extension, QObject,):
self._version = Version(version_string)
else:
self._version = None
+
self._change_logs = None
Application.getInstance().engineCreatedSignal.connect(self._onEngineCreated)
- Preferences.getInstance().addPreference("general/latest_version_changelog_shown", "15.05.90") #First version of CURA with uranium
+ Preferences.getInstance().addPreference("general/latest_version_changelog_shown", "2.0.0") #First version of CURA with uranium
self.addMenuItem(catalog.i18nc("@item:inmenu", "Show Changelog"), self.showChangelog)
#self.showChangelog()
@@ -42,7 +43,6 @@ class ChangeLog(Extension, QObject,):
@pyqtSlot(result = str)
def getChangeLogString(self):
logs = self.getChangeLogs()
- latest_version = Version(Preferences.getInstance().getValue("general/latest_version_changelog_shown"))
result = ""
for version in logs:
result += "
" + str(version) + "
"
@@ -58,7 +58,7 @@ class ChangeLog(Extension, QObject,):
def loadChangeLogs(self):
self._change_logs = collections.OrderedDict()
- with open(os.path.join(PluginRegistry.getInstance().getPluginPath("ChangeLogPlugin"), "ChangeLog.txt"), "r",-1, "utf-8") as f:
+ with open(os.path.join(PluginRegistry.getInstance().getPluginPath(self.getPluginId()), "ChangeLog.txt"), "r",-1, "utf-8") as f:
open_version = None
open_header = None
for line in f:
@@ -78,12 +78,19 @@ class ChangeLog(Extension, QObject,):
def _onEngineCreated(self):
if not self._version:
return #We're on dev branch.
- #if self._version > Preferences.getInstance().getValue("general/latest_version_changelog_shown"):
- #self.showChangelog()
+
+ if Preferences.getInstance().getValue("general/latest_version_changelog_shown") == "master":
+ latest_version_shown = Version("0.0.0")
+ else:
+ latest_version_shown = Version(Preferences.getInstance().getValue("general/latest_version_changelog_shown"))
+
+ if self._version > latest_version_shown:
+ self.showChangelog()
def showChangelog(self):
if not self._changelog_window:
self.createChangelogWindow()
+
self._changelog_window.show()
Preferences.getInstance().setValue("general/latest_version_changelog_shown", Application.getInstance().getVersion())
@@ -92,7 +99,8 @@ class ChangeLog(Extension, QObject,):
self._changelog_window.hide()
def createChangelogWindow(self):
- path = QUrl.fromLocalFile(os.path.join(PluginRegistry.getInstance().getPluginPath("ChangeLogPlugin"), "ChangeLog.qml"))
+ path = QUrl.fromLocalFile(os.path.join(PluginRegistry.getInstance().getPluginPath(self.getPluginId()), "ChangeLog.qml"))
+
component = QQmlComponent(Application.getInstance()._engine, path)
self._changelog_context = QQmlContext(Application.getInstance()._engine.rootContext())
self._changelog_context.setContextProperty("manager", self)
diff --git a/plugins/ChangeLogPlugin/__init__.py b/plugins/ChangeLogPlugin/__init__.py
index 42683d91dc..88ac4e08a6 100644
--- a/plugins/ChangeLogPlugin/__init__.py
+++ b/plugins/ChangeLogPlugin/__init__.py
@@ -12,7 +12,7 @@ def getMetaData():
"name": catalog.i18nc("@label", "Changelog"),
"author": "Ultimaker",
"version": "1.0",
- "description": catalog.i18nc("@info:whatsthis", "Shows changes since latest checked version."),
+ "description": catalog.i18nc("@info:whatsthis", "Shows changes since latest checked version."),
"api": 2
}
}