%PDF- %PDF-
| Direktori : /usr/share/hplip/ui5/ |
| Current File : //usr/share/hplip/ui5/printdialog.py |
# -*- coding: utf-8 -*-
#
# (c) Copyright 2001-2015 HP Development Company, L.P.
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
#
# Authors: Don Welch
#
# Local
from base.g import *
from base import device, utils
from prnt import cups
from base.codes import *
from .ui_utils import *
# Qt
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *
# Ui
from .printdialog_base import Ui_Dialog
from .filetable import FileTable, FILETABLE_TYPE_PRINT
from .printernamecombobox import PRINTERNAMECOMBOBOX_TYPE_PRINTER_ONLY
#signal
import signal
import subprocess
PAGE_FILE = 0
PAGE_OPTIONS = 1
PAGE_MAX = 1
class PrintDialog(QDialog, Ui_Dialog):
def __init__(self, parent, printer_name, args=None):
QDialog.__init__(self, parent)
self.setupUi(self)
self.printer_name = printer_name
# User settings
self.user_settings = UserSettings()
self.user_settings.load()
self.user_settings.debug()
self.initUi()
self.file_list = []
if args is not None:
for a in args:
self.Files.addFileFromUI(os.path.abspath(a))
self.devices = {}
QTimer.singleShot(0, self.updateFilePage)
def initUi(self):
self.OptionsToolBox.include_job_options = True
# connect signals/slots
self.CancelButton.clicked.connect(self.CancelButton_clicked)
self.BackButton.clicked.connect(self.BackButton_clicked)
self.NextButton.clicked.connect(self.NextButton_clicked)
signal.signal(signal.SIGINT, signal.SIG_DFL)
self.initFilePage()
self.initOptionsPage()
# Application icon
self.setWindowIcon(QIcon(load_pixmap('hp_logo', '128x128')))
if self.printer_name:
self.PrinterName.setInitialPrinter(self.printer_name)
self.StackedWidget.setCurrentIndex(0)
#
# File Page
#
def initFilePage(self):
self.Files.setType(FILETABLE_TYPE_PRINT)
#self.Files.setWorkingDir(user_conf.workingDirectory())
self.Files.setWorkingDir(self.user_settings.working_dir)
self.Files.isEmpty.connect(self.Files_isEmpty)
self.Files.isNotEmpt.connect(self.Files_isNotEmpty)
def updateFilePage(self):
self.NextButton.setText(self.__tr("Next >"))
self.NextButton.setEnabled(self.Files.isNotEmpty())
self.BackButton.setEnabled(False)
self.updateStepText(PAGE_FILE)
self.Files.updateUi()
def Files_isEmpty(self):
self.NextButton.setEnabled(False)
def Files_isNotEmpty(self):
self.NextButton.setEnabled(True)
#
# Options Page
#
def initOptionsPage(self):
self.BackButton.setEnabled(True)
self.PrinterName.setType(PRINTERNAMECOMBOBOX_TYPE_PRINTER_ONLY)
self.PrinterName.PrinterNameComboBox_currentChanged.connect(self.PrinterNameComboBox_currentChanged)
self.PrinterName.PrinterNameComboBox_noPrinters.connect(self.PrinterNameComboBox_noPrinters)
def updateOptionsPage(self):
QApplication.setOverrideCursor(QCursor(Qt.WaitCursor))
try:
self.PrinterName.updateUi()
self.BackButton.setEnabled(True)
num_files = len(self.Files.file_list)
if num_files > 1:
self.NextButton.setText(self.__tr("Print %s Files"%num_files))
else:
self.NextButton.setText(self.__tr("Print File"))
self.updateStepText(PAGE_OPTIONS)
# TODO: Enable print button only if printer is accepting and all options are OK (esp. page range)
finally:
QApplication.restoreOverrideCursor()
def PrinterNameComboBox_currentChanged(self, device_uri, printer_name):
try:
self.devices[device_uri]
except KeyError:
self.devices[device_uri] = device.Device(device_uri)
self.OptionsToolBox.updateUi(self.devices[device_uri], printer_name)
def PrinterNameComboBox_noPrinters(self):
FailureUI(self, self.__tr("<b>No printers found.</b><p>Please setup a printer and try again."))
self.close()
#
# Print
#
def executePrint(self):
for cmd in self.OptionsToolBox.getPrintCommands(self.Files.file_list):
log.debug(cmd)
#status, output = utils.run(cmd)
status = subprocess.call(cmd, shell=True)
if status != 0:
FailureUI(self, self.__tr("<b>Print command failed with status code %s.</b><p>%s</p>"%(status,cmd)))
self.close()
#print file('/home/dwelch/.cups/lpoptions', 'r').read()
#
# Misc
#
def CancelButton_clicked(self):
self.close()
def BackButton_clicked(self):
p = self.StackedWidget.currentIndex()
if p == PAGE_OPTIONS:
self.StackedWidget.setCurrentIndex(PAGE_FILE)
self.updateFilePage()
else:
log.error("Invalid page!") # shouldn't happen!
def NextButton_clicked(self):
p = self.StackedWidget.currentIndex()
if p == PAGE_FILE:
self.StackedWidget.setCurrentIndex(PAGE_OPTIONS)
self.updateOptionsPage()
elif p == PAGE_OPTIONS:
self.executePrint()
def updateStepText(self, p):
self.StepText.setText(self.__tr("Step %d of %d" %(p+1, PAGE_MAX+1)))
def __tr(self,s,c = None):
return qApp.translate("PrintDialog",s,c)