summaryrefslogtreecommitdiff
path: root/src/frontend/gui/office.py
diff options
context:
space:
mode:
authorV3n3RiX <venerix@redcorelinux.org>2017-06-24 21:55:37 +0100
committerV3n3RiX <venerix@redcorelinux.org>2017-06-24 21:55:37 +0100
commitf7e54cc8a29e5fa319ce21d6ec268e210397740a (patch)
tree5078d7a5f7f2393aa3b5068d980b0d3598bff878 /src/frontend/gui/office.py
parent2faa4c83dbaca3958feb092c9776f016a0133e8f (diff)
write a proper Makefile, rearrange source code a bit
Diffstat (limited to 'src/frontend/gui/office.py')
-rwxr-xr-xsrc/frontend/gui/office.py84
1 files changed, 84 insertions, 0 deletions
diff --git a/src/frontend/gui/office.py b/src/frontend/gui/office.py
new file mode 100755
index 0000000..286494a
--- /dev/null
+++ b/src/frontend/gui/office.py
@@ -0,0 +1,84 @@
+#!/usr/bin/python3
+import sys, subprocess, sqlite3
+from PyQt5 import QtCore, QtGui, QtWidgets, uic
+
+class Office(QtWidgets.QMainWindow):
+ def __init__(self):
+ super(Office, self).__init__()
+ uic.loadUi('ui/office.ui', self)
+ self.centerOnScreen()
+ self.show()
+ self.load_packages()
+
+ self.package_install.clicked.connect(self.install_package)
+ self.package_uninstall.clicked.connect(self.uninstall_package)
+ self.orphans_remove.clicked.connect(self.remove_orphans)
+ self.category_exit.clicked.connect(self.exit_category)
+
+ def centerOnScreen(self):
+ resolution = QtWidgets.QDesktopWidget().screenGeometry()
+ self.move((resolution.width() / 2) - (self.frameSize().width() / 2),
+ (resolution.height() / 2) - (self.frameSize().height() / 2))
+
+ def install_package(self):
+ pkgname = self.table_office.item(self.table_office.currentRow(), 1).text()
+ subprocess.Popen(['xterm', '-e', 'sisyphus', 'auto-install'] + pkgname.split())
+
+ def uninstall_package(self):
+ pkgname = self.table_office.item(self.table_office.currentRow(), 1).text()
+ subprocess.Popen(['xterm', '-e', 'sisyphus', 'auto-uninstall'] + pkgname.split())
+
+ def remove_orphans(self):
+ subprocess.Popen(['xterm', '-e', 'sisyphus', 'remove-orphans'])
+
+ def exit_category(self):
+ self.close()
+
+ def load_packages(self):
+ with sqlite3.connect('/var/lib/sisyphus/db/sisyphus.db') as db:
+ cursor=db.cursor()
+ cursor.execute('''SELECT
+ a.category AS cat,
+ a.name AS pn,
+ a.version AS av,
+ i.version AS iv,
+ a.description AS descr
+ FROM remote_packages AS a
+ LEFT JOIN local_packages AS i
+ ON a.category = i.category
+ AND a.name = i.name
+ AND a.slot = i.slot
+ WHERE a.name IN
+ ('fet',
+ 'libreoffice',
+ 'wps-office',
+ 'tesseract',
+ 'okular',
+ 'cantarell',
+ 'corefonts',
+ 'dejavu',
+ 'liberation-fonts',
+ 'libertine',
+ 'noto',
+ 'open-sans',
+ 'roboto',
+ 'ttf-bitstream-vera',
+ 'qpdfview',
+ 'cups',
+ 'cups-filters',
+ 'cups-pdf',
+ 'simple-scan',
+ 'cnijfilter',
+ 'cnijfilter-drivers',
+ 'hplip')
+ ''')
+ rows = cursor.fetchall()
+
+ for row in rows:
+ inx = rows.index(row)
+ self.table_office.insertRow(inx)
+ self.table_office.setItem(inx, 0, QtWidgets.QTableWidgetItem(row[0]))
+ self.table_office.setItem(inx, 1, QtWidgets.QTableWidgetItem(row[1]))
+ self.table_office.setItem(inx, 2, QtWidgets.QTableWidgetItem(row[2]))
+ self.table_office.setItem(inx, 3, QtWidgets.QTableWidgetItem(row[3]))
+ self.table_office.setItem(inx, 4, QtWidgets.QTableWidgetItem(row[4]))