Lint
This commit is contained in:
		| @@ -1,19 +1,28 @@ | |||||||
| import datetime | import datetime | ||||||
| from PySide6.QtCore import QAbstractTableModel, QModelIndex, Qt |  | ||||||
| from PySide6.QtGui import QColor, QFont | from PySide6.QtCore import ( | ||||||
|  |     QAbstractTableModel, | ||||||
|  |     QModelIndex, | ||||||
|  |     QPersistentModelIndex, | ||||||
|  |     Qt, | ||||||
|  | ) | ||||||
|  | from PySide6.QtGui import QFont | ||||||
| from PySide6.QtSql import QSqlQuery | from PySide6.QtSql import QSqlQuery | ||||||
|  |  | ||||||
| from lib.utils import query_error | from lib.utils import query_error | ||||||
|  |  | ||||||
|  |  | ||||||
| class docketModel(QAbstractTableModel): | class docketModel(QAbstractTableModel): | ||||||
|     entries = [] |     entries: list[list[str | None]] = [] | ||||||
|  |  | ||||||
|     def __init__(self, case_id: int | None = None) -> None: |     def __init__(self, case_id: int | None = None) -> None: | ||||||
|         super(docketModel, self).__init__() |         super(docketModel, self).__init__() | ||||||
|         if case_id == None: |         if case_id == None: | ||||||
|             return |             return | ||||||
|         query = QSqlQuery() |         query = QSqlQuery() | ||||||
|         query.prepare("SELECT * FROM entries WHERE case_id = :cid " |         query.prepare( | ||||||
|                       "ORDER BY entry_id") |             "SELECT * FROM entries WHERE case_id = :cid " "ORDER BY entry_id" | ||||||
|  |         ) | ||||||
|         q2 = QSqlQuery() |         q2 = QSqlQuery() | ||||||
|         q2.prepare("SELECT * FROM documents WHERE entry_id = :eid") |         q2.prepare("SELECT * FROM documents WHERE entry_id = :eid") | ||||||
|  |  | ||||||
| @@ -23,38 +32,40 @@ class docketModel(QAbstractTableModel): | |||||||
|         while query.next(): |         while query.next(): | ||||||
|             date = datetime.date.fromtimestamp(query.value(2)) |             date = datetime.date.fromtimestamp(query.value(2)) | ||||||
|             assert isinstance(date, datetime.date) |             assert isinstance(date, datetime.date) | ||||||
|             row = [ |             row = [date.strftime("%B %-d, %Y"), query.value(3)] | ||||||
|                 date.strftime("%B %-d, %Y"), |  | ||||||
|                 query.value(3) |  | ||||||
|                 ] |  | ||||||
|             self.entries.append(row) |             self.entries.append(row) | ||||||
|             q2.bindValue(":eid", query.value("entry_id")) |             q2.bindValue(":eid", query.value("entry_id")) | ||||||
|             if not q2.exec(): |             if not q2.exec(): | ||||||
|                 query_error(q2) |                 query_error(q2) | ||||||
|             row = [] |             row = [] | ||||||
|             while q2.next(): |             while q2.next(): | ||||||
|                 row.append(q2.value('name')) |                 row.append("<u>" + q2.value("name") + "</u>") | ||||||
|             if len(row) > 0: |             if len(row) > 0: | ||||||
|                 self.entries.append([None, " ".join(row)]) |                 self.entries.append([None, " ".join(row)]) | ||||||
|         return |         return | ||||||
|  |  | ||||||
|     def rowCount(self, parent:QModelIndex|None = None) -> int: |     def rowCount( | ||||||
|  |         self, _: QModelIndex | QPersistentModelIndex = QModelIndex() | ||||||
|  |     ) -> int: | ||||||
|         return len(self.entries) |         return len(self.entries) | ||||||
|  |  | ||||||
|     def columnCount(self, parent:QModelIndex|None = None) -> int: |     def columnCount( | ||||||
|  |         self, _: QModelIndex | QPersistentModelIndex = QModelIndex() | ||||||
|  |     ) -> int: | ||||||
|         return 2 |         return 2 | ||||||
|  |  | ||||||
|     def data(self, index: QModelIndex, role:int): |     def data(self, index: QModelIndex | QPersistentModelIndex, role: int = 0): | ||||||
|         if not index.isValid(): |         if not index.isValid(): | ||||||
|             return '' |             return "" | ||||||
|         if role == Qt.ItemDataRole.DisplayRole: |         if role == Qt.ItemDataRole.DisplayRole: | ||||||
|             return self.entries[index.row()][index.column()] |             return self.entries[index.row()][index.column()] | ||||||
|         if role == Qt.ItemDataRole.TextAlignmentRole and index.column() == 0: |         if role == Qt.ItemDataRole.TextAlignmentRole and index.column() == 0: | ||||||
|             return Qt.AlignmentFlag.AlignRight | Qt.AlignmentFlag.AlignTop |             return Qt.AlignmentFlag.AlignRight | Qt.AlignmentFlag.AlignTop | ||||||
|         return |         return | ||||||
|  |  | ||||||
|  |     def headerData( | ||||||
|     def headerData(self, section:int, orientation:Qt.Orientation, role:int): |         self, section: int, orientation: Qt.Orientation, role: int = 0 | ||||||
|  |     ): | ||||||
|         if orientation == Qt.Orientation.Vertical: |         if orientation == Qt.Orientation.Vertical: | ||||||
|             return |             return | ||||||
|         if role == Qt.ItemDataRole.FontRole: |         if role == Qt.ItemDataRole.FontRole: | ||||||
| @@ -63,4 +74,4 @@ class docketModel(QAbstractTableModel): | |||||||
|             return font |             return font | ||||||
|         if role != Qt.ItemDataRole.DisplayRole: |         if role != Qt.ItemDataRole.DisplayRole: | ||||||
|             return |             return | ||||||
|         return ['Date', 'Proceedings and Orders'][section] |         return ["Date", "Proceedings and Orders"][section] | ||||||
|   | |||||||
| @@ -1,9 +1,11 @@ | |||||||
| from typing import NoReturn | from typing import NoReturn | ||||||
|  |  | ||||||
| from PySide6.QtCore import QCoreApplication | from PySide6.QtCore import QCoreApplication | ||||||
| from PySide6.QtSql import QSqlQuery | from PySide6.QtSql import QSqlQuery | ||||||
|  |  | ||||||
|  |  | ||||||
| translate = QCoreApplication.translate | translate = QCoreApplication.translate | ||||||
|  |  | ||||||
|  |  | ||||||
| def query_error(query: QSqlQuery) -> NoReturn: | def query_error(query: QSqlQuery) -> NoReturn: | ||||||
|     """Standarized query error reporter.""" |     """Standarized query error reporter.""" | ||||||
|     print( |     print( | ||||||
|   | |||||||
							
								
								
									
										106
									
								
								scotus-pull.py
									
									
									
									
									
								
							
							
						
						
									
										106
									
								
								scotus-pull.py
									
									
									
									
									
								
							| @@ -37,25 +37,70 @@ translate = QCoreApplication.translate | |||||||
|  |  | ||||||
|  |  | ||||||
| class dateDelegate(QStyledItemDelegate): | class dateDelegate(QStyledItemDelegate): | ||||||
|     def displayText(self, value, locale) -> str: |     def displayText(self, value, locale) -> str:  # type: ignore | ||||||
|         date = datetime.date.fromtimestamp(value) |         date = datetime.date.fromtimestamp(value) | ||||||
|         return date.strftime("%B %-d, %Y") |         return date.strftime("%B %-d, %Y") | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class documentDelegate(QStyledItemDelegate): | ||||||
|  |     def paint( | ||||||
|  |         self, | ||||||
|  |         painter: QPainter, | ||||||
|  |         option: QStyleOptionViewItem, | ||||||
|  |         index: QModelIndex | QPersistentModelIndex, | ||||||
|  |     ): | ||||||
|  |         options = option | ||||||
|  |         self.initStyleOption(options, index) | ||||||
|  |         painter.save() | ||||||
|  |         doc = QTextDocument() | ||||||
|  |         doc.setTextWidth(option.rect.width())  # type: ignore | ||||||
|  |         doc.setHtml(option.text)  # type: ignore | ||||||
|  |         option.text = ""  # type: ignore | ||||||
|  |         option.widget.style().drawControl(  # type: ignore | ||||||
|  |             QStyle.ControlElement.CE_ItemViewItem, | ||||||
|  |             option, | ||||||
|  |             painter, | ||||||
|  |         ) | ||||||
|  |         painter.translate(option.rect.left(), options.rect.top())  # type: ignore | ||||||
|  |         clip = QRect(0, 0, option.rect.width(), option.rect.height())  # type: ignore | ||||||
|  |         doc.drawContents(painter, clip) | ||||||
|  |         painter.restore() | ||||||
|  |         return | ||||||
|  |  | ||||||
|  |     def sizeHint( | ||||||
|  |         self, | ||||||
|  |         option: QStyleOptionViewItem, | ||||||
|  |         index: QModelIndex | QPersistentModelIndex, | ||||||
|  |     ) -> QSize: | ||||||
|  |         self.initStyleOption(option, index) | ||||||
|  |         doc = QTextDocument() | ||||||
|  |         doc.setTextWidth(option.rect.width())  # type: ignore | ||||||
|  |         doc.setHtml(option.text)  # type: ignore | ||||||
|  |         doc.setTextWidth(option.rect.width())  # type: ignore | ||||||
|  |         return QSize(int(doc.idealWidth()), int(doc.size().height())) | ||||||
|  |  | ||||||
|  |  | ||||||
| class MainWindow(QMainWindow, Ui_MainWindow): | class MainWindow(QMainWindow, Ui_MainWindow): | ||||||
|     show_entries = Signal(int) |     show_entries = Signal(int) | ||||||
|  |  | ||||||
|     def __init__(self) -> None: |     def __init__(self) -> None: | ||||||
|         super(MainWindow, self).__init__() |         super(MainWindow, self).__init__() | ||||||
|         self.setupUi(self) |         self.setupUi(self) | ||||||
|  |  | ||||||
|         model = QSqlQueryModel() |         # model = QSqlQueryModel() | ||||||
|  |         model = QSqlTableModel() | ||||||
|         query = QSqlQuery("SELECT * FROM cases ORDER BY docket_id") |         query = QSqlQuery("SELECT * FROM cases ORDER BY docket_id") | ||||||
|         if not query.exec(): |         if not query.exec(): | ||||||
|             query_error(query) |             query_error(query) | ||||||
|         model.setQuery(query) |         model.setQuery(query) | ||||||
|         self.casesView.setModel(model) |         self.casesView.setModel(model) | ||||||
|  |  | ||||||
|         self.casesView.setSelectionMode(QAbstractItemView.SelectionMode.SingleSelection) |         self.casesView.setSelectionMode( | ||||||
|         self.casesView.setSelectionBehavior(QAbstractItemView.SelectionBehavior.SelectRows) |             QAbstractItemView.SelectionMode.SingleSelection | ||||||
|  |         ) | ||||||
|  |         self.casesView.setSelectionBehavior( | ||||||
|  |             QAbstractItemView.SelectionBehavior.SelectRows | ||||||
|  |         ) | ||||||
|         self.casesView.hideColumn(0) |         self.casesView.hideColumn(0) | ||||||
|         self.casesView.hideColumn(2) |         self.casesView.hideColumn(2) | ||||||
|         self.casesView.setItemDelegateForColumn(5, dateDelegate()) |         self.casesView.setItemDelegateForColumn(5, dateDelegate()) | ||||||
| @@ -65,7 +110,12 @@ class MainWindow(QMainWindow, Ui_MainWindow): | |||||||
|         header.setSectionResizeMode(3, QHeaderView.ResizeMode.Fixed) |         header.setSectionResizeMode(3, QHeaderView.ResizeMode.Fixed) | ||||||
|         header.setSectionResizeMode(4, QHeaderView.ResizeMode.Fixed) |         header.setSectionResizeMode(4, QHeaderView.ResizeMode.Fixed) | ||||||
|         self.show() |         self.show() | ||||||
|         remaining = self.casesView.width() - header.sectionSize(1) - header.sectionSize(5) - 5 |         remaining = ( | ||||||
|  |             self.casesView.width() | ||||||
|  |             - header.sectionSize(1) | ||||||
|  |             - header.sectionSize(5) | ||||||
|  |             - 5 | ||||||
|  |         ) | ||||||
|         self.casesView.setColumnWidth(3, int(remaining * 0.5)) |         self.casesView.setColumnWidth(3, int(remaining * 0.5)) | ||||||
|         self.casesView.setColumnWidth(4, int(remaining * 0.5)) |         self.casesView.setColumnWidth(4, int(remaining * 0.5)) | ||||||
|         self.casesView.verticalHeader().hide() |         self.casesView.verticalHeader().hide() | ||||||
| @@ -74,11 +124,14 @@ class MainWindow(QMainWindow, Ui_MainWindow): | |||||||
|         self.casesView.clicked.connect(self.rowClicked) |         self.casesView.clicked.connect(self.rowClicked) | ||||||
|  |  | ||||||
|         self.docketView.setModel(docketModel()) |         self.docketView.setModel(docketModel()) | ||||||
|         self.docketView.horizontalHeader().setSectionResizeMode(1, QHeaderView.ResizeMode.Stretch) |         self.docketView.horizontalHeader().setSectionResizeMode( | ||||||
|  |             1, QHeaderView.ResizeMode.Stretch | ||||||
|  |         ) | ||||||
|         self.docketView.resizeRowsToContents() |         self.docketView.resizeRowsToContents() | ||||||
|  |         self.docketView.setItemDelegateForColumn(1, documentDelegate()) | ||||||
|         return |         return | ||||||
|  |  | ||||||
|     @Slot(QModelIndex) |     @Slot(QModelIndex)  # type: ignore | ||||||
|     def rowClicked(self, index: QModelIndex) -> None: |     def rowClicked(self, index: QModelIndex) -> None: | ||||||
|         if not index.isValid(): |         if not index.isValid(): | ||||||
|             raise Exception("Bad index") |             raise Exception("Bad index") | ||||||
| @@ -91,13 +144,30 @@ class MainWindow(QMainWindow, Ui_MainWindow): | |||||||
|         self.docketView.resizeRowsToContents() |         self.docketView.resizeRowsToContents() | ||||||
|         return |         return | ||||||
|  |  | ||||||
|  |     updateThread = None | ||||||
|  |  | ||||||
|     @Slot() |     @Slot() | ||||||
|     def on_updateButton_clicked(self): |     def on_updateButton_clicked(self): | ||||||
|         text = self.docketInput.toPlainText() |         text = self.docketInput.toPlainText() | ||||||
|         update_db(text) |         print(f"on_updateButton_clicked(): {text}") | ||||||
|         self.update() |         if not self.updateThread: | ||||||
|  |             self.updateThread = updateThread() | ||||||
|  |             assert isinstance(self.updateThread, updateThread) | ||||||
|  |             self.updateThread.finished.connect(self.updateDone) | ||||||
|  |         self.updateThread.setDocketId(text) | ||||||
|  |         self.updateThread.start() | ||||||
|         return |         return | ||||||
|  |  | ||||||
|  |     @Slot() | ||||||
|  |     def updateDone(self): | ||||||
|  |         self.updateThread = None | ||||||
|  |         print("Done updating") | ||||||
|  |         model: QSqlTableModel = self.casesView.model()  # type: ignore | ||||||
|  |         query = model.query() | ||||||
|  |         query.exec() | ||||||
|  |         return | ||||||
|  |  | ||||||
|  |  | ||||||
| SQL_CMDS = [ | SQL_CMDS = [ | ||||||
|     # "PRAGMA foreign_keys=ON", |     # "PRAGMA foreign_keys=ON", | ||||||
|     "CREATE TABLE IF NOT EXISTS cases " |     "CREATE TABLE IF NOT EXISTS cases " | ||||||
| @@ -121,6 +191,12 @@ SQL_CMDS = [ | |||||||
|     "name TEXT, " |     "name TEXT, " | ||||||
|     "url TEXT, " |     "url TEXT, " | ||||||
|     "FOREIGN KEY(entry_id) REFERENCES entries(entry_id))", |     "FOREIGN KEY(entry_id) REFERENCES entries(entry_id))", | ||||||
|  |     # | ||||||
|  |     "CREATE TABLE IF NOT EXISTS history (" | ||||||
|  |     "history_id INTEGER PRIMARY KEY AUTOINCREMENT, " | ||||||
|  |     "year TEXT, " | ||||||
|  |     "edocket INTEGER, " | ||||||
|  |     "number INTEGER)", | ||||||
| ] | ] | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -148,7 +224,7 @@ def schema_update(db: QSqlDatabase) -> None: | |||||||
|         else: |         else: | ||||||
|             raise AttributeError(f"No match found: {create_cmd}") |             raise AttributeError(f"No match found: {create_cmd}") | ||||||
|  |  | ||||||
|         print("Table name = {}".format(table_name)) |         print(f"Table name = {table_name}") | ||||||
|         query.prepare("SELECT sql FROM sqlite_schema WHERE tbl_name = :tbl") |         query.prepare("SELECT sql FROM sqlite_schema WHERE tbl_name = :tbl") | ||||||
|         query.bindValue(":tbl", table_name) |         query.bindValue(":tbl", table_name) | ||||||
|         if not query.exec(): |         if not query.exec(): | ||||||
| @@ -178,7 +254,10 @@ def schema_update(db: QSqlDatabase) -> None: | |||||||
|             query_error(query) |             query_error(query) | ||||||
|         # step 5 transfer content |         # step 5 transfer content | ||||||
|         coldefs = re.search(r"\((.+)\)", old).group(1).split(", ")  # type: ignore[union-attr] |         coldefs = re.search(r"\((.+)\)", old).group(1).split(", ")  # type: ignore[union-attr] | ||||||
|         cols = [x.split(" ")[0] for x in filter(lambda s: not s.startswith('FOREIGN '),coldefs)] |         cols = [ | ||||||
|  |             x.split(" ")[0] | ||||||
|  |             for x in filter(lambda s: not s.startswith("FOREIGN "), coldefs) | ||||||
|  |         ] | ||||||
|         cols_str = ", ".join(cols) |         cols_str = ", ".join(cols) | ||||||
|         sql = f"INSERT INTO {new_table_name} ({cols_str}) SELECT {cols_str} FROM {table_name}" |         sql = f"INSERT INTO {new_table_name} ({cols_str}) SELECT {cols_str} FROM {table_name}" | ||||||
|         query.prepare(sql) |         query.prepare(sql) | ||||||
| @@ -190,7 +269,9 @@ def schema_update(db: QSqlDatabase) -> None: | |||||||
|         if not query.exec(): |         if not query.exec(): | ||||||
|             query_error(query) |             query_error(query) | ||||||
|         # step 6 rename new table to old table |         # step 6 rename new table to old table | ||||||
|         query.prepare("ALTER TABLE " + new_table_name + " RENAME TO " + table_name) |         query.prepare( | ||||||
|  |             "ALTER TABLE " + new_table_name + " RENAME TO " + table_name | ||||||
|  |         ) | ||||||
|         if not query.exec(): |         if not query.exec(): | ||||||
|             query_error(query) |             query_error(query) | ||||||
|  |  | ||||||
| @@ -214,5 +295,6 @@ def main() -> int: | |||||||
|     window = MainWindow() |     window = MainWindow() | ||||||
|     return app.exec() |     return app.exec() | ||||||
|  |  | ||||||
|  |  | ||||||
| if __name__ == "__main__": | if __name__ == "__main__": | ||||||
|     sys.exit(main()) |     sys.exit(main()) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user