Compare commits
3 commits
78a06e8a73
...
807a21e9af
| Author | SHA1 | Date | |
|---|---|---|---|
| 807a21e9af | |||
| 4ec8c64994 | |||
| 054ad88991 |
6 changed files with 58 additions and 6 deletions
|
|
@ -1,3 +1,7 @@
|
||||||
|
# 0.4.5
|
||||||
|
|
||||||
|
* Make it possible to delete revisions
|
||||||
|
|
||||||
# 0.4.4.1
|
# 0.4.4.1
|
||||||
|
|
||||||
* Adjust some widget heights/settings text wrap
|
* Adjust some widget heights/settings text wrap
|
||||||
|
|
|
||||||
|
|
@ -369,6 +369,17 @@ class DBManager:
|
||||||
(version_id, date_iso),
|
(version_id, date_iso),
|
||||||
)
|
)
|
||||||
|
|
||||||
|
def delete_version(self, *, version_id: int) -> bool | None:
|
||||||
|
"""
|
||||||
|
Delete a specific version by version_id.
|
||||||
|
"""
|
||||||
|
cur = self.conn.cursor()
|
||||||
|
row = cur.execute(
|
||||||
|
"DELETE FROM versions WHERE id=?;",
|
||||||
|
(version_id,),
|
||||||
|
)
|
||||||
|
return True
|
||||||
|
|
||||||
# ------------------------- Export logic here ------------------------#
|
# ------------------------- Export logic here ------------------------#
|
||||||
def get_all_entries(self) -> List[Entry]:
|
def get_all_entries(self) -> List[Entry]:
|
||||||
"""
|
"""
|
||||||
|
|
|
||||||
|
|
@ -13,6 +13,7 @@ from PySide6.QtWidgets import (
|
||||||
QMessageBox,
|
QMessageBox,
|
||||||
QTextBrowser,
|
QTextBrowser,
|
||||||
QTabWidget,
|
QTabWidget,
|
||||||
|
QAbstractItemView,
|
||||||
)
|
)
|
||||||
|
|
||||||
from . import strings
|
from . import strings
|
||||||
|
|
@ -82,6 +83,7 @@ class HistoryDialog(QDialog):
|
||||||
# Top: list of versions
|
# Top: list of versions
|
||||||
top = QHBoxLayout()
|
top = QHBoxLayout()
|
||||||
self.list = QListWidget()
|
self.list = QListWidget()
|
||||||
|
self.list.setSelectionMode(QAbstractItemView.ExtendedSelection)
|
||||||
self.list.setMinimumSize(500, 650)
|
self.list.setMinimumSize(500, 650)
|
||||||
self.list.currentItemChanged.connect(self._on_select)
|
self.list.currentItemChanged.connect(self._on_select)
|
||||||
top.addWidget(self.list, 1)
|
top.addWidget(self.list, 1)
|
||||||
|
|
@ -104,9 +106,12 @@ class HistoryDialog(QDialog):
|
||||||
row.addStretch(1)
|
row.addStretch(1)
|
||||||
self.btn_revert = QPushButton(strings._("history_dialog_revert_to_selected"))
|
self.btn_revert = QPushButton(strings._("history_dialog_revert_to_selected"))
|
||||||
self.btn_revert.clicked.connect(self._revert)
|
self.btn_revert.clicked.connect(self._revert)
|
||||||
|
self.btn_delete = QPushButton(strings._("history_dialog_delete"))
|
||||||
|
self.btn_delete.clicked.connect(self._delete)
|
||||||
self.btn_close = QPushButton(strings._("close"))
|
self.btn_close = QPushButton(strings._("close"))
|
||||||
self.btn_close.clicked.connect(self.reject)
|
self.btn_close.clicked.connect(self.reject)
|
||||||
row.addWidget(self.btn_revert)
|
row.addWidget(self.btn_revert)
|
||||||
|
row.addWidget(self.btn_delete)
|
||||||
row.addWidget(self.btn_close)
|
row.addWidget(self.btn_close)
|
||||||
root.addLayout(row)
|
root.addLayout(row)
|
||||||
|
|
||||||
|
|
@ -145,20 +150,24 @@ class HistoryDialog(QDialog):
|
||||||
|
|
||||||
@Slot()
|
@Slot()
|
||||||
def _on_select(self):
|
def _on_select(self):
|
||||||
|
selected_items = self.list.selectedItems()
|
||||||
item = self.list.currentItem()
|
item = self.list.currentItem()
|
||||||
if not item:
|
if not item or len(selected_items) > 1:
|
||||||
self.preview.clear()
|
self.preview.clear()
|
||||||
self.diff.clear()
|
self.diff.clear()
|
||||||
self.btn_revert.setEnabled(False)
|
self.btn_revert.setEnabled(False)
|
||||||
return
|
return
|
||||||
|
|
||||||
sel_id = item.data(Qt.UserRole)
|
sel_id = item.data(Qt.UserRole)
|
||||||
sel = self._db.get_version(version_id=sel_id)
|
sel = self._db.get_version(version_id=sel_id)
|
||||||
self.preview.setMarkdown(sel["content"])
|
self.preview.setMarkdown(sel["content"])
|
||||||
# Diff vs current (textual diff)
|
# Diff vs current (textual diff)
|
||||||
cur = self._db.get_version(version_id=self._current_id)
|
cur = self._db.get_version(version_id=self._current_id)
|
||||||
self.diff.setHtml(_colored_unified_diff_html(cur["content"], sel["content"]))
|
self.diff.setHtml(_colored_unified_diff_html(cur["content"], sel["content"]))
|
||||||
# Enable revert only if selecting a non-current version
|
|
||||||
|
# Enable revert and delete buttons only if selecting a non-current version
|
||||||
self.btn_revert.setEnabled(sel_id != self._current_id)
|
self.btn_revert.setEnabled(sel_id != self._current_id)
|
||||||
|
self.btn_delete.setEnabled(sel_id != self._current_id)
|
||||||
|
|
||||||
@Slot()
|
@Slot()
|
||||||
def _revert(self):
|
def _revert(self):
|
||||||
|
|
@ -175,3 +184,19 @@ class HistoryDialog(QDialog):
|
||||||
)
|
)
|
||||||
return
|
return
|
||||||
self.accept()
|
self.accept()
|
||||||
|
|
||||||
|
@Slot()
|
||||||
|
def _delete(self):
|
||||||
|
selected_items = self.list.selectedItems()
|
||||||
|
for item in selected_items:
|
||||||
|
sel_id = item.data(Qt.UserRole)
|
||||||
|
if sel_id == self._current_id:
|
||||||
|
return
|
||||||
|
try:
|
||||||
|
self._db.delete_version(version_id=sel_id)
|
||||||
|
except Exception as e:
|
||||||
|
QMessageBox.critical(
|
||||||
|
self, strings._("history_dialog_delete_failed"), str(e)
|
||||||
|
)
|
||||||
|
return
|
||||||
|
return self._load_versions()
|
||||||
|
|
|
||||||
|
|
@ -22,7 +22,7 @@
|
||||||
"key_changed_explanation": "The notebook was re-encrypted with the new key!",
|
"key_changed_explanation": "The notebook was re-encrypted with the new key!",
|
||||||
"error": "Error",
|
"error": "Error",
|
||||||
"success": "Success",
|
"success": "Success",
|
||||||
"close": "Close",
|
"close": "&Close",
|
||||||
"find": "Find",
|
"find": "Find",
|
||||||
"file": "File",
|
"file": "File",
|
||||||
"locale": "Language",
|
"locale": "Language",
|
||||||
|
|
@ -81,8 +81,10 @@
|
||||||
"find_bar_match_case": "Match case",
|
"find_bar_match_case": "Match case",
|
||||||
"history_dialog_preview": "Preview",
|
"history_dialog_preview": "Preview",
|
||||||
"history_dialog_diff": "Diff",
|
"history_dialog_diff": "Diff",
|
||||||
"history_dialog_revert_to_selected": "Revert to selected",
|
"history_dialog_revert_to_selected": "&Revert to selected",
|
||||||
"history_dialog_revert_failed": "Revert failed",
|
"history_dialog_revert_failed": "Revert failed",
|
||||||
|
"history_dialog_delete": "&Delete revision",
|
||||||
|
"history_dialog_delete_failed": "Could not delete revision",
|
||||||
"key_prompt_enter_key": "Enter key",
|
"key_prompt_enter_key": "Enter key",
|
||||||
"lock_overlay_locked_due_to_inactivity": "Locked due to inactivity",
|
"lock_overlay_locked_due_to_inactivity": "Locked due to inactivity",
|
||||||
"lock_overlay_unlock": "Unlock",
|
"lock_overlay_unlock": "Unlock",
|
||||||
|
|
|
||||||
|
|
@ -249,7 +249,6 @@ class StatisticsDialog(QDialog):
|
||||||
|
|
||||||
self.setWindowTitle(strings._("statistics"))
|
self.setWindowTitle(strings._("statistics"))
|
||||||
self.setMinimumWidth(600)
|
self.setMinimumWidth(600)
|
||||||
self.setMinimumHeight(350)
|
|
||||||
root = QVBoxLayout(self)
|
root = QVBoxLayout(self)
|
||||||
|
|
||||||
(
|
(
|
||||||
|
|
@ -325,10 +324,16 @@ class StatisticsDialog(QDialog):
|
||||||
self._revisions_by_date = revisions_by_date
|
self._revisions_by_date = revisions_by_date
|
||||||
|
|
||||||
scroll = QScrollArea()
|
scroll = QScrollArea()
|
||||||
scroll.setWidgetResizable(True)
|
scroll.setWidgetResizable(False)
|
||||||
scroll.setHorizontalScrollBarPolicy(Qt.ScrollBarAsNeeded)
|
scroll.setHorizontalScrollBarPolicy(Qt.ScrollBarAsNeeded)
|
||||||
scroll.setVerticalScrollBarPolicy(Qt.ScrollBarAlwaysOff)
|
scroll.setVerticalScrollBarPolicy(Qt.ScrollBarAlwaysOff)
|
||||||
|
self._heatmap.setSizePolicy(QSizePolicy.Fixed, QSizePolicy.Fixed)
|
||||||
scroll.setWidget(self._heatmap)
|
scroll.setWidget(self._heatmap)
|
||||||
|
|
||||||
|
# ensure the scroll area is never shorter than the heatmap's preferred height
|
||||||
|
scroll.setSizePolicy(QSizePolicy.Expanding, QSizePolicy.Fixed)
|
||||||
|
scroll.setMinimumHeight(self._heatmap.minimumSizeHint().height())
|
||||||
|
|
||||||
group_layout.addWidget(scroll)
|
group_layout.addWidget(scroll)
|
||||||
|
|
||||||
root.addWidget(group)
|
root.addWidget(group)
|
||||||
|
|
@ -339,6 +344,8 @@ class StatisticsDialog(QDialog):
|
||||||
else:
|
else:
|
||||||
root.addWidget(QLabel(strings._("stats_no_data")))
|
root.addWidget(QLabel(strings._("stats_no_data")))
|
||||||
|
|
||||||
|
self.adjustSize()
|
||||||
|
|
||||||
# ---------- internal helpers ----------
|
# ---------- internal helpers ----------
|
||||||
|
|
||||||
def _apply_metric(self, metric: str) -> None:
|
def _apply_metric(self, metric: str) -> None:
|
||||||
|
|
|
||||||
|
|
@ -944,6 +944,9 @@ def test_open_version(qtbot, tmp_db_cfg, app, monkeypatch):
|
||||||
def setIcon(self, icon):
|
def setIcon(self, icon):
|
||||||
self._icon = icon
|
self._icon = icon
|
||||||
|
|
||||||
|
def setIconPixmap(self, icon):
|
||||||
|
self._icon = icon
|
||||||
|
|
||||||
def setWindowTitle(self, title):
|
def setWindowTitle(self, title):
|
||||||
self._title = title
|
self._title = title
|
||||||
called["title"] = title
|
called["title"] = title
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue