1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104
|
/* This file is part of the KDE project
Copyright (c) 2000 Simon Hausmann <hausmann@kde.org>
2006 Martin Pfeiffer <hubipete@gmx.net>
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Library General Public
License as published by the Free Software Foundation; either
version 2 of the License, or (at your option) any later version.
This library 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
Library General Public License for more details.
You should have received a copy of the GNU Library General Public License
along with this library; see the file COPYING.LIB. If not, write to
the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
* Boston, MA 02110-1301, USA.
*/
#ifndef __koDocumentInfoDlg_h__
#define __koDocumentInfoDlg_h__
#include <kpagedialog.h>
class KoDocumentInfo;
class KPageWidgetItem;
class KoPageWidgetItem;
#include "kowidgets_export.h"
/**
* @short The dialog that shows information about the document
* @author Simon Hausmann <hausmann@kde.org>
* @author Martin Pfeiffer <hubipete@gmx.net>
* @see KoDocumentInfo
*
* This dialog is invoked by KoMainWindow and shows the content
* of the given KoDocumentInfo class. It consists of several pages,
* one showing general information about the document and an other
* showing information about the author.
* This dialog implements only things that are stored in the OASIS
* meta.xml file and therefore available through the KoDocumentInfo
* class.
* The widgets shown in the tabs are koDocumentInfoAboutWidget and
* koDocumentInfoAuthorWidget. This class here is derived from
* KPageDialog and uses the face type Tabbed.
*/
class KOWIDGETS_EXPORT KoDocumentInfoDlg : public KPageDialog
{
Q_OBJECT
public:
/**
* The constructor
* @param parent a pointer to the parent widget
* @param docInfo a pointer to the shown KoDocumentInfo
*/
KoDocumentInfoDlg(QWidget *parent, KoDocumentInfo* docInfo);
/** The destructor */
virtual ~KoDocumentInfoDlg();
QList<KPageWidgetItem*> pages() const;
/** Returns true if the document was saved when the dialog was closed */
bool isDocumentSaved();
/** Sets all fields to read-only mode. Used by the property dialog. */
void setReadOnly(bool ro);
void addPageItem(KoPageWidgetItem *item);
public Q_SLOTS: // QDialog API
void accept();
protected: // QWidget API
void hideEvent(QHideEvent * event);
private Q_SLOTS:
/** Connected with clicked() from pbReset - Reset parts of the metadata */
void slotResetMetaData();
/** Connected with clicked() from pbEncrypt - Toggle the encryption of the document */
void slotToggleEncryption();
Q_SIGNALS:
void saveRequested();
private:
/** Sets up the aboutWidget and fills the widgets with content */
void initAboutTab();
/** Sets up the authorWidget and fills the widgets with content */
void initAuthorTab();
/** Saves the changed data back to the KoDocumentInfo class */
void saveAboutData();
/** Saves the document with changed encryption */
void saveEncryption();
class KoDocumentInfoDlgPrivate;
KoDocumentInfoDlgPrivate * const d;
};
#endif
|