summaryrefslogtreecommitdiffstats
path: root/kdeui/kaboutdialog.h
diff options
context:
space:
mode:
Diffstat (limited to 'kdeui/kaboutdialog.h')
-rw-r--r--kdeui/kaboutdialog.h633
1 files changed, 633 insertions, 0 deletions
diff --git a/kdeui/kaboutdialog.h b/kdeui/kaboutdialog.h
new file mode 100644
index 000000000..25afc0a3b
--- /dev/null
+++ b/kdeui/kaboutdialog.h
@@ -0,0 +1,633 @@
+/*
+ * This file is part of the KDE Libraries
+ * Copyright (C) 1999-2001 Mirko Boehm (mirko@kde.org) and
+ * Espen Sand (espen@kde.org)
+ *
+ * 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.
+ *
+ */
+
+/*
+ * This file declares a class for creating "About ..." dialogs
+ * in a general way. It provides geometry management and some
+ * options to connect for, like emailing the author or maintainer.
+ */
+
+
+#ifndef _KABOUTDIALOG_H_
+#define _KABOUTDIALOG_H_
+
+#include <kdialogbase.h>
+#include <qstring.h>
+
+class QFrame;
+class QLabel;
+class QVBoxLayout;
+class QTabWidget;
+class KURLLabel;
+class KAboutContainer;
+class KAboutContainerBase;
+
+class KAboutWidgetPrivate;
+
+class KAboutContainerPrivate;
+/**
+ * KAboutContainer can be used to make a application specific AboutDialog.
+ */
+class KDEUI_EXPORT KAboutContainer : public QFrame
+{
+ Q_OBJECT
+
+ public:
+ KAboutContainer( QWidget *parent=0, const char *name=0,
+ int margin=0, int spacing=0,
+ int childAlignment = AlignCenter,
+ int innerAlignment = AlignCenter );
+
+ void addWidget( QWidget *widget );
+ void addPerson( const QString &name, const QString &email,
+ const QString &url, const QString &task,
+ bool showHeader = false, bool showframe = false,
+ bool showBold = false );
+ void addTitle( const QString &title, int alignment=AlignLeft,
+ bool showframe = false, bool showBold = false );
+ void addImage( const QString &fileName, int alignment=AlignLeft );
+
+ virtual QSize sizeHint( void ) const;
+ virtual QSize minimumSizeHint( void ) const;
+
+ protected:
+ virtual void childEvent( QChildEvent *e );
+
+ signals:
+ void urlClick( const QString &url );
+ void mailClick( const QString &name, const QString &address );
+
+
+ private:
+ QVBoxLayout *mVbox;
+ int mAlignment;
+ KAboutContainerPrivate* const d;
+};
+
+class KAboutContributorPrivate;
+
+/**
+ * Used internally by KAboutWidget
+ * @internal
+ */
+class KDEUI_EXPORT KAboutContributor : public QFrame
+{
+ Q_OBJECT
+
+ public:
+ KAboutContributor( QWidget *parent=0, const char *name=0,
+ const QString &username=QString::null,
+ const QString &email=QString::null,
+ const QString &url=QString::null,
+ const QString &work=QString::null,
+ bool showHeader=false, bool showFrame=true,
+ bool showBold=false );
+
+ void setName( const QString &text, const QString &header=QString::null,
+ bool update = true );
+ void setEmail( const QString &text, const QString &header=QString::null,
+ bool update = true );
+ void setURL( const QString &text, const QString &header=QString::null,
+ bool update = true );
+ void setWork( const QString &text, const QString &header=QString::null,
+ bool update = true );
+ QString getName( void ) const;
+ QString getEmail( void ) const;
+ QString getURL( void ) const;
+ QString getWork( void ) const;
+
+ virtual QSize sizeHint( void ) const;
+
+ protected:
+ virtual void fontChange( const QFont &oldFont );
+
+ protected slots:
+ void urlClickedSlot( const QString& );
+ void emailClickedSlot( const QString& emailaddress );
+
+ private:
+ void updateLayout( void );
+
+ signals:
+ void sendEmail(const QString& name, const QString& email);
+ void openURL(const QString& url);
+
+ private:
+ QLabel *mLabel[4];
+ QLabel *mText[4];
+ bool mShowHeader;
+ bool mShowBold;
+
+ KAboutContributorPrivate* const d;
+
+ virtual void setName(const char *_name) { QFrame::setName(_name); }
+};
+
+/**
+ * KAboutWidget is the main widget for KAboutDialog.
+ *
+ * It has a minimum size set.
+ */
+class KDEUI_EXPORT KAboutWidget : public QWidget
+{
+ Q_OBJECT
+
+public:
+
+ /**
+ * The Qt constructor.
+ */
+ KAboutWidget(QWidget* parent=0, const char* name=0 );
+
+ /**
+ * Adjust the minimum size (after setting the properties of the image and
+ * the labels.
+ */
+ void adjust();
+
+ /**
+ * Sets the image as the application logo.
+ */
+ void setLogo(const QPixmap&);
+ /**
+ * Sets the author's name and email address.
+ */
+ void setAuthor(const QString& name, const QString& email,
+ const QString& url, const QString& work);
+ /**
+ * Sets the maintainers name and email address.
+ */
+ void setMaintainer(const QString& name, const QString& email,
+ const QString& url, const QString& work);
+ /**
+ * Shows this person as one of the major contributors.
+ */
+ void addContributor(const QString& name, const QString& email,
+ const QString& url, const QString& work);
+ /**
+ * Sets the text describing the version.
+ */
+ void setVersion(const QString& name);
+ // -------------------------------------------------------------------------
+protected slots:
+ /**
+ * Catches the signals from the contributors elements.
+ */
+ void sendEmailSlot(const QString& name, const QString& email);
+ /**
+ * Catches the clicked URLs.
+ */
+ void openURLSlot(const QString& url);
+ // -------------------------------------------------------------------------
+signals:
+ /**
+ * An email address has been selected by the user.
+ */
+ void sendEmail(const QString& name, const QString& email);
+ /**
+ * An URL has been clicked.
+ */
+ void openURL(const QString& url);
+ // -------------------------------------------------------------------------
+protected:
+ // events:
+ /**
+ * The resize event.
+ */
+ void resizeEvent(QResizeEvent*);
+ /**
+ * The label showing the program version.
+ */
+ QLabel *version;
+ /**
+ * The label showing the text "Other contributors:".
+ */
+ QLabel *cont;
+ /**
+ * The frame showing the logo.
+ */
+ QLabel *logo;
+ /**
+ * The application developer.
+ */
+ KAboutContributor *author;
+ /**
+ * The application maintainer.
+ */
+ KAboutContributor *maintainer;
+ /**
+ * Show the maintainer?
+ */
+ bool showMaintainer;
+ /**
+ * A set of people who contributed to the application.
+ */
+ QPtrList<KAboutContributor> contributors;
+ // #########################################################################
+ //
+private:
+ KAboutWidgetPrivate* const d;
+};
+
+class KAboutDialogPrivate;
+/**
+ * A KDialogBase with predefined main widget.
+ *
+ * As a KDialogBase it uses your application wide settings
+ * for KDialogBase
+ * objects (base frame tiles, main frame tiles etc).
+ * To use it, simply create a KAboutDialog object, set all (or some) of its
+ * properties and show it. Do not derive it to create your own about dialog
+ * until you need some cool features that are unsupported and you have
+ * contacted me to add them.
+ *
+ * The dialog can be created using two different constructors. The
+ * difference between these constructors is the available components that
+ * can be used to build the contents of the dialog. The first (Constructor I)
+ * provides a number of easy to use methods. Basically it allows you
+ * to add the components of choice, and the components are placed in a
+ * predefined layout. You do not have to plan the layout. Everything is
+ * taken care of.
+ *
+ * The second constructor (Constructor II) works in quite the same manner
+ * as the first, but you have better control on where the components
+ * are postioned in the layout and you have access to an extended number
+ * of components you can install such as titles, product information,
+ * a tabbed pages (where you can display rich text with url links) and
+ * a person (developer) information field. The "About KDE" dialog box is
+ * created with Constructor II.
+ *
+ * For the derived features, see the basic class KDialogBase.
+ * @author Mirko Boehm (mirko@kde.org) and Espen Sand (espensa@online.no)
+ * @see KDialogBase
+ */
+class KDEUI_EXPORT KAboutDialog : public KDialogBase
+{
+ Q_OBJECT
+
+ public:
+ /**
+ * Layout formats.
+ **/
+ enum LayoutType
+ {
+ AbtPlain = 0x0001,
+ AbtTabbed = 0x0002,
+ AbtTitle = 0x0004,
+ AbtImageLeft = 0x0008,
+ AbtImageRight = 0x0010,
+ AbtImageOnly = 0x0020,
+ AbtProduct = 0x0040,
+ AbtKDEStandard = AbtTabbed|AbtTitle|AbtImageLeft,
+ AbtAppStandard = AbtTabbed|AbtTitle|AbtProduct,
+ AbtImageAndTitle = AbtPlain|AbtTitle|AbtImageOnly
+ };
+
+ public:
+ /**
+ * The standard Qt constructor (Constructor I).
+ *
+ * Add components with the following methods:
+ * setLogo(), setAuthor(), setMaintainer(),
+ * addContributor(), or setVersion().
+ * The dialog will be laid out automatically.
+ */
+ KAboutDialog( QWidget *parent=0, const char *name=0, bool modal=true );
+
+ /**
+ * The extended constructor. (Constructor II).
+ *
+ * Add components with the methods:
+ * setTitle(), setImage(), setImageBackgroundColor(),
+ * setImageFrame(), setProduct(), addTextPage(),
+ * addContainerPage(), addContainer(), or addPage().
+ *
+ * @param dialogLayout Use a mask of LayoutType flags.
+ * @param caption The dialog caption. The text you specify is prepended
+ * by i18n("About").
+ * @param buttonMask Specifies what buttons will be visible.
+ * @param defaultButton Specifies what button will be marked as the default.
+ * @param parent Parent of the dialog.
+ * @param name Dialog name (for internal use only)
+ * @param modal Sets dialog modality. If false, the rest of the
+ * program interface (other dialogs, for example) is accessible while
+ * the dialog is open.
+ * @param separator If true, a separator line is drawn between the action
+ * buttons an the main widget.
+ * @param user1 User button1 text.
+ * @param user2 User button2 text.
+ * @param user3 User button3 text.
+ *
+ */
+ KAboutDialog( int dialogLayout, const QString &caption, int buttonMask,
+ ButtonCode defaultButton, QWidget *parent=0,
+ const char *name=0, bool modal=false, bool separator = false,
+ const QString &user1 = QString::null,
+ const QString &user2 = QString::null,
+ const QString &user3 = QString::null );
+
+ /**
+ * Adjusts the dialog.
+ *
+ * You can call this method after you have set up all
+ * the contents but it is not required. It is done automatically when
+ * show() is executed.
+ */
+ void adjust();
+
+ /**
+ * Makes a modeless (modal = false in constructor) dialog visible.
+ *
+ * If you reimplement this method make sure you run it
+ * in the new method (e.g., show()). Reimplemented
+ * from KDialogBase.
+ */
+ virtual void show( void );
+
+ /**
+ * Makes a modeless (modal = false in constructor) dialog visible.
+ *
+ * If you reimplmement this method make sure you run it
+ * in the new method (i.e., show( parent )).
+ *
+ * @param centerParent Center the dialog with respect to this widget.
+ */
+ virtual void show( QWidget *centerParent );
+
+ /**
+ * (Constructor II only)
+ * Sets a title (not caption) in the uppermost area of the dialog.
+ *
+ * @param title Title string.
+ */
+ void setTitle( const QString &title );
+
+ /**
+ * (Constructor II only)
+ * Define an image to be shown in the dialog. The position is dependent
+ * on the @p dialogLayout in the constructor
+ *
+ * @param fileName Path to image file.
+ */
+ void setImage( const QString &fileName );
+
+ /**
+ * (Constructor II only)
+ * Define the program logo to be shown in the dialog. Use this to override the
+ * default program logo. For example, use this function if the
+ * KAboutDialog is for a panel applet and you want to override the
+ * appletproxy logo with your own pixmap.
+ *
+ * @param fileName Path to file containing logo data in a format that
+ * can be loaded by QPixmap.
+ *
+ * @since 3.3
+ */
+ void setIcon( const QString &fileName ) KDE_DEPRECATED; // KDE4: remove
+
+ /**
+ * Overloaded version of setProgramLogo(const QPixmap& pixmap).
+ *
+ * @since 3.4
+ */
+ void setProgramLogo( const QString &fileName );
+
+ /**
+ * (Constructor II only)
+ * Define the program logo to be shown in the dialog. Use this to override the
+ * default program logo. For example, use this function if the
+ * KAboutDialog is for a panel applet and you want to override the
+ * appletproxy logo with your own pixmap.
+ *
+ * @param pixmap The logo pixmap.
+ *
+ * @since 3.4
+ */
+ void setProgramLogo( const QPixmap &pixmap );
+
+ /**
+ * (Constructor II only)
+ * The image has a minimum size, but is centered within an area if the
+ * dialog box is enlarged by the user. You set the background color
+ * of the area with this method.
+ *
+ * @param color Background color.
+ */
+ void setImageBackgroundColor( const QColor &color );
+
+ /**
+ * (Constructor II only)
+ * Enables or disables a frame around the image. The frame is, by default,
+ * enabled in the constructor
+ *
+ * @param state A value of @p true enables the frame
+ */
+ void setImageFrame( bool state );
+
+ /**
+ * (Constructor II only)
+ * Prints the application name, KDE version, author, a copyright sign
+ * and a year string. To the left of the text the standard application
+ * icon is displayed.
+ *
+ * @param appName The application name.
+ * @param version Application version.
+ * @param author One or more authors.
+ * @param year A string telling when the application was made.
+ */
+ void setProduct( const QString &appName, const QString &version,
+ const QString &author, const QString &year );
+
+ /**
+ * (Constructor II only)
+ * Adds a text page to a tab box. The text can be regular text or
+ * rich text. The rich text can contain URLs and mail links.
+ *
+ * @param title Tab name.
+ * @param text The text to display.
+ * @param richText Set this to @p true if 'text' is rich text.
+ * @param numLines The text area height will be adjusted so that this
+ * is the minimum number of lines of text that are visible.
+ * @return The frame that contains the page.
+ */
+ QFrame *addTextPage( const QString &title, const QString &text,
+ bool richText=false, int numLines=10 );
+
+ /**
+ * (Constructor II only)
+ * Adds a license page to a tab box.
+ *
+ * @param title Tab name.
+ * @param text The text to display.
+ * @param numLines The text area height will be adjusted so that this
+ * is the minimum number of lines of text that are visible.
+ * @return The frame that contains the page.
+ */
+ QFrame *addLicensePage( const QString &title, const QString &text,
+ int numLines=10 );
+
+ /**
+ * (Constructor II only)
+ * Adds a container to a tab box. You can add text and images to a
+ * container.
+ *
+ * @param title Tab name.
+ * @param childAlignment Specifies how the children of the container are
+ * aligned with respect to the container.
+ * @param innerAlignment Specifies how the children are aligned with
+ * respect to each other.
+ * @return The new container.
+ */
+ KAboutContainer *addContainerPage( const QString &title,
+ int childAlignment = AlignCenter, int innerAlignment = AlignCenter );
+
+ /**
+ * (Constructor II only)
+ * Adds a container inside a QScrollView to a tab box. You can add text
+ * and images to a container.
+ *
+ * @param title Tab name.
+ * @param childAlignment Specifies how the children of the container are
+ * aligned with respect to the container.
+ * @param innerAlignment Specifies how the children are aligned with
+ * respect to each other.
+ * @return The new container.
+ */
+ KAboutContainer *addScrolledContainerPage( const QString &title,
+ int childAlignment = AlignCenter, int innerAlignment = AlignCenter );
+
+ /**
+ * (Constructor II only)
+ * Adds a container. You can add text and images to a container.
+ *
+ * @param childAlignment Specifies how the children of the container are
+ * aligned with respect to the container.
+ * @param innerAlignment Specifies how the children are aligned with
+ * respect to each other.
+ * @return The new container.
+ */
+ KAboutContainer *addContainer( int childAlignment, int innerAlignment );
+
+ /**
+ * (Constructor II only)
+ * Adds an empty page to a tab box.
+ *
+ * @param title Tab name
+ * @return The new page.
+ */
+ QFrame *addPage( const QString &title );
+
+
+ /**
+ * (Constructor I only)
+ * Sets the image as the application logo.
+ */
+ void setLogo(const QPixmap&);
+
+ /**
+ * (Constructor I only)
+ * Sets the author's name and email address.
+ */
+ void setAuthor(const QString& name, const QString& email,
+ const QString& url, const QString& work);
+
+ /**
+ * (Constructor I only)
+ * Sets the maintainer's name and email address.
+ */
+ void setMaintainer(const QString& name, const QString& email,
+ const QString& url, const QString& work);
+
+ /**
+ * (Constructor I only)
+ * Show this person as one of the major contributors.
+ */
+ void addContributor(const QString& name, const QString& email,
+ const QString& url, const QString& work);
+
+ /**
+ * (Constructor I only)
+ * Sets the text describing the version.
+ */
+ void setVersion(const QString& name);
+
+ /**
+ * Create a modal dialog with an image in the upper area with a
+ * URL link below.
+ */
+ static void imageURL( QWidget *parent, const QString &caption,
+ const QString &path, const QColor &imageColor,
+ const QString &url );
+
+signals:
+ /**
+ * Send an email to this person.
+ *
+ * The application must provide the
+ * functionality.
+ */
+ void sendEmail(const QString& name, const QString& email);
+
+ /**
+ * Open the selected URL.
+ */
+ void openURL(const QString& url);
+ // ----------------------------------------------------------------------------
+protected:
+ /**
+ * The main widget (Constructor I)
+ */
+ KAboutWidget * about;
+
+ /**
+ * The main widget (Constructor II)
+ */
+ KAboutContainerBase *mContainerBase;
+
+ // -------------------------------------------------------------------------
+protected slots:
+
+ /**
+ * Connected to widget->sendEmail.
+ */
+ void sendEmailSlot(const QString& name, const QString& email);
+
+ /**
+ * Open this URL.
+ */
+ void openURLSlot(const QString& url);
+
+ /**
+ * (Constructor II only)
+ * Tells the position of the mouse cursor when the left mouse button
+ * is pressed above an image
+ */
+ virtual void mouseTrackSlot( int mode, const QMouseEvent *e );
+
+ // #########################################################################
+protected:
+ virtual void virtual_hook( int id, void* data );
+private:
+ KAboutDialogPrivate* const d;
+};
+
+#endif // defined KABOUTDIALOG_H