/*************************************************************************** * Copyright (C) 2002 by Wilco Greven * * Copyright (C) 2002 by Chris Cheney * * Copyright (C) 2003 by Benjamin Meyer * * Copyright (C) 2003-2004 by Christophe Devriese * * * * Copyright (C) 2003 by Laurent Montel * * Copyright (C) 2003-2004 by Albert Astals Cid * * Copyright (C) 2003 by Luboš Luňák * * Copyright (C) 2003 by Malcolm Hunter * * Copyright (C) 2004 by Dominique Devriese * * Copyright (C) 2004 by Dirk Mueller * * * * 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. * ***************************************************************************/ // qt/kde includes #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include // local includes #include "shell.h" #include "kdocumentviewer.h" Shell::Shell(KCmdLineArgs* args, const KUrl &url) : KParts::MainWindow(), m_args(args), m_menuBarWasShown(true), m_toolBarWasShown(true) { m_openUrl = url; init(); } void Shell::init() { setObjectName( QLatin1String( "okular::Shell" ) ); setContextMenuPolicy( Qt::NoContextMenu ); // set the shell's ui resource file setXMLFile("shell.rc"); m_doc=0L; m_fileformats=0L; // this routine will find and load our Part. it finds the Part by // name which is a bad idea usually.. but it's alright in this // case since our Part is made for this Shell KParts::Factory *factory = (KParts::Factory *) KLibLoader::self()->factory("libokularpart"); if (factory) { // now that the Part is loaded, we cast it to a Part to get // our hands on it m_part = (KParts::ReadOnlyPart*) factory->createPart(this, this); if (m_part) { // then, setup our actions setupActions(); // tell the KParts::MainWindow that this is indeed the main widget setCentralWidget(m_part->widget()); // and integrate the part's GUI with the shell's setupGUI(Keys | Save); createGUI(m_part); m_showToolBarAction = static_cast(toolBarMenuAction()); m_doc = qobject_cast(m_part); } } else { // if we couldn't find our Part, we exit since the Shell by // itself can't do anything useful KMessageBox::error(this, i18n("Unable to find okular part.")); m_part = 0; return; } connect( this, SIGNAL( restoreDocument(KConfig*) ),m_part, SLOT( restoreDocument(KConfig*))); connect( this, SIGNAL( saveDocumentRestoreInfo(KConfig*) ), m_part, SLOT( saveDocumentRestoreInfo(KConfig*))); connect( m_part, SIGNAL( enablePrintAction(bool) ), m_printAction, SLOT( setEnabled(bool))); readSettings(); if (!KGlobal::config()->hasGroup("MainWindow")) { showMaximized(); } setAutoSaveSettings(); if (m_openUrl.isValid()) QTimer::singleShot(0, this, SLOT(delayedOpen())); } void Shell::delayedOpen() { uint page = 0; if (m_args && m_doc) { QByteArray pageopt = m_args->getOption("page"); page = pageopt.toUInt(); } openUrl(m_openUrl, page); } Shell::~Shell() { if ( m_part ) writeSettings(); if ( m_fileformats ) delete m_fileformats; delete m_part; } void Shell::openUrl( const KUrl & url, uint page ) { if ( m_part ) { if ( m_doc && m_args && m_args->isSet( "presentation" ) ) m_doc->startPresentation(); bool openOk = page > 0 && m_doc ? m_doc->openDocument( url, page ) : m_part->openUrl( url ); if ( openOk ) m_recent->addUrl( url ); else m_recent->removeUrl( url ); } } void Shell::readSettings() { m_recent->loadEntries( KGlobal::config().data() ); m_recent->setEnabled( true ); // force enabling m_recent->setToolTip( i18n("Click to open a file\nClick and hold to open a recent file") ); KGlobal::config()->setDesktopGroup(); bool fullScreen = KGlobal::config()->readEntry( "FullScreen", false ); setFullScreen( fullScreen ); } void Shell::writeSettings() { m_recent->saveEntries( KGlobal::config().data() ); KGlobal::config()->setDesktopGroup(); KGlobal::config()->writeEntry( "FullScreen", m_fullScreenAction->isChecked()); KGlobal::config()->sync(); } void Shell::setupActions() { KStandardAction::open(this, SLOT(fileOpen()), actionCollection()); m_recent = KStandardAction::openRecent( this, SLOT( openUrl( const KUrl& ) ), actionCollection() ); m_recent->setToolBarMode( KRecentFilesAction::MenuMode ); m_recent->setToolButtonPopupMode( QToolButton::DelayedPopup ); connect( m_recent, SIGNAL( triggered() ), this, SLOT( fileOpen() ) ); m_recent->setWhatsThis( i18n( "Click to open a file or Click and hold to select a recent file" ) ); m_printAction = KStandardAction::print( m_part, SLOT( slotPrint() ), actionCollection() ); m_printAction->setEnabled( false ); KStandardAction::quit(this, SLOT(slotQuit()), actionCollection()); setStandardToolBarMenuEnabled(true); m_showMenuBarAction = KStandardAction::showMenubar( this, SLOT( slotShowMenubar() ), actionCollection()); KStandardAction::configureToolbars(this, SLOT(optionsConfigureToolbars()), actionCollection()); m_fullScreenAction = KStandardAction::fullScreen( this, SLOT( slotUpdateFullScreen() ), this,actionCollection() ); } void Shell::saveProperties(KConfig* config) { // the 'config' object points to the session managed // config file. anything you write here will be available // later when this app is restored emit saveDocumentRestoreInfo(config); } void Shell::readProperties(KConfig* config) { // the 'config' object points to the session managed // config file. this function is automatically called whenever // the app is being restored. read in here whatever you wrote // in 'saveProperties' if(m_part) { emit restoreDocument(config); } } // this comes from kviewpart/kviewpart.cpp, fileformats function QStringList* Shell::fileFormats() { QString constraint("([X-KDE-Priority] > 0) and (exist Library) ") ; KService::List offers = KServiceTypeTrader::self()->query("okular/Generator",constraint); QStringList supportedMimeTypes; QStringList * supportedPattern; if (offers.isEmpty()) { return 0; } KFilterBase* filter = KFilterBase::findFilterByMimeType( "application/x-bzip2" ); bool bzip2Available = (filter != 0L); delete filter; supportedPattern = new QStringList; KService::List::ConstIterator iterator = offers.begin(); KService::List::ConstIterator end = offers.end(); QStringList::ConstIterator mimeType; QString tmp; QStringList mimeTypes,pattern,extensions; QString allExt,comment; for (; iterator != end; ++iterator) { KService::Ptr service = *iterator; mimeTypes = service->serviceTypes(); for (mimeType=mimeTypes.begin();mimeType!=mimeTypes.end();++mimeType) { if (! (*mimeType).contains("okular")) { KMimeType::Ptr mimePtr = KMimeType::mimeType(*mimeType); if ( mimePtr ) { pattern = mimePtr->patterns(); supportedMimeTypes << *mimeType; extensions.clear(); while(!pattern.isEmpty()) { tmp=pattern.front().trimmed(); extensions.append(tmp); if (tmp.indexOf(".gz", -3) == -1) extensions.append(tmp+".gz"); if ((bzip2Available) && (tmp.indexOf(".bz2", -4) == -1)) extensions.append(tmp+".bz2"); pattern.pop_front(); } comment=mimePtr->comment(); if (! comment.contains("Unknown")) supportedPattern->append(extensions.join(" ") + '|' + comment); allExt+=extensions.join(" "); } } } } supportedPattern->prepend(allExt + "|All Files"); return supportedPattern; } void Shell::fileOpen() { // this slot is called whenever the File->Open menu is selected, // the Open shortcut is pressed (usually CTRL+O) or the Open toolbar // button is clicked if (!m_fileformats) m_fileformats = fileFormats(); if (m_fileformats) { QString startDir; if ( m_openUrl.isLocalFile() ) startDir = m_openUrl.path(); KUrl url = KFileDialog::getOpenUrl( startDir, m_fileformats->join("\n") );//getOpenFileName(); if (!url.isEmpty()) openUrl(url); } else { KMessageBox::error(this, i18n("No okular plugins were found.")); slotQuit(); } } void Shell::optionsConfigureToolbars() { KEditToolbar dlg(factory()); connect(&dlg, SIGNAL(newToolbarConfig()), this, SLOT(applyNewToolbarConfig())); dlg.exec(); } void Shell::applyNewToolbarConfig() { applyMainWindowSettings(KGlobal::config().data(), "MainWindow"); } void Shell::slotQuit() { kapp->closeAllWindows(); } // only called when starting the program void Shell::setFullScreen( bool useFullScreen ) { if( useFullScreen ) showFullScreen(); else showNormal(); } void Shell::slotUpdateFullScreen() { if(m_fullScreenAction->isChecked()) { m_menuBarWasShown = m_showMenuBarAction->isChecked(); m_showMenuBarAction->setChecked(false); menuBar()->hide(); m_toolBarWasShown = m_showToolBarAction->isChecked(); m_showToolBarAction->setChecked(false); toolBar()->hide(); showFullScreen(); } else { if (m_menuBarWasShown) { m_showMenuBarAction->setChecked(true); menuBar()->show(); } if (m_toolBarWasShown) { m_showToolBarAction->setChecked(true); toolBar()->show(); } showNormal(); } } void Shell::slotShowMenubar() { if ( m_showMenuBarAction->isChecked() ) menuBar()->show(); else menuBar()->hide(); } #include "shell.moc"