/***************************************************************************
 *   Copyright (C) 2005 by Stefan Kebekus                                  *
 *   kebekus@kde.org                                                       *
 *                                                                         *
 *   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.,                                       *
 *   51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.             *
 ***************************************************************************/

#ifndef FAXMULTIPAGE_H
#define FAXMULTIPAGE_H

#include <tqstringlist.h>

#include "tdemultipage.h"
#include "faxrenderer.h"



/*! \mainpage FaxMultiPage
  
\section intro_sec Introduction

FaxMultiPage is a minimal, but well-documented reference
implementation of a kviewshell plugin that can serve as a starting
point for implementations.

\section install_sec Usage

When FaxMultiPage and the associated files are installed, the
kviewshell program can open TIFF-Fax anf G3 fax files, i.e. files of
mime types image/fax-g3 or image/tiff.
 
\section content Content

Only the two classes that are absolutely necessary for a working
plugin are implemented. The only other file that is installed are
desktop file, which tells kviewshell to use the plugin.

- FaxMultiPage, an implementation of a KMultiPage. In a larger
application, this class would contain the GUI elements that the plugin
adds to the GUI of the kviewshell. For viewing FAXes, no special GUI
elements are required, and this plugin does only the minimal
initialization required.

- FaxRenderer, an implementation of a DocumentRenderer. This class is
responsible for document loading and rendering.

- kfaxmultipage.desktop and kfaxmultipage_tiff.desktop are desktop
entry files that associate the plugin wit image/fax-g3 or image/tiff
mime-types.  Without these files installed, the file dialog in
kviewshell would not show FAX files, and the command line "kvieshell
test.g3" would fail with an error dialog "No plugin for image/fax-g3
files installed".
*/



 
/*! \brief Well-documented minimal implementation of a KMultiPage
  
This class provides a well-documented reference implementation of a
KMultiPage, suitable as a starting point for a real-world
implementation. In a larger application, this class would contain the
GUI elements that the plugin adds to the GUI of the kviewshell. For
viewing FAXes, no special GUI elements are required, and this plugin
does only the minimal initialization required.
*/

class FaxMultiPage : public KMultiPage
{
  Q_OBJECT
  

public:
  /** Constructor
      
  The constructor needs to initialize several members of the
  tdemultipage. Please have a look at the constructor's source code to
  see how to adjust this for your implementation.
  */
  FaxMultiPage(TQWidget *parentWidget, const char *widgetName, TQObject *parent,
		   const char *name, const TQStringList& args = TQStringList());
  
  /** Destructor
		
  This destructor does nothing.
  */
  virtual ~FaxMultiPage();

  /** List of file formats for file saving
  
  This method returns the list of supported file formats for saving
  the file.
  */
  virtual TQStringList fileFormats() const;

  /** Author information
 
  This member returns a structure that contains information about the
  authors of the implementation
  */
  static TDEAboutData* createAboutData();
  
 private:
  /** This member holds the renderer which is used by the demo implementation */
  FaxRenderer     faxRenderer;
};

#endif