|
|
|
/*
|
|
|
|
* textinput.h
|
|
|
|
*
|
|
|
|
* Copyright (c) 2001, 2002, 2003 Frerich Raabe <raabe@kde.org>
|
|
|
|
*
|
|
|
|
* 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. For licensing and distribution details, check the
|
|
|
|
* accompanying file 'COPYING'.
|
|
|
|
*/
|
|
|
|
#ifndef LIBRSS_TEXTINPUT_H
|
|
|
|
#define LIBRSS_TEXTINPUT_H
|
|
|
|
|
|
|
|
#include "global.h"
|
|
|
|
|
|
|
|
class KURL;
|
|
|
|
|
|
|
|
class TQDomNode;
|
|
|
|
class TQString;
|
|
|
|
|
|
|
|
namespace RSS
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Represents a text input facility as stored in a RSS file for the purpose
|
|
|
|
* of allowing users to submit queries back to the publisher's site. You
|
|
|
|
* don't have to instantiate one of these yourself, the common way to access
|
|
|
|
* instances is via Document::textInput().
|
|
|
|
* @see Document::textInput()
|
|
|
|
*/
|
|
|
|
class TextInput
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* Default constructor.
|
|
|
|
*/
|
|
|
|
TextInput();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Copy constructor.
|
|
|
|
* @param other The TextInput object to copy.
|
|
|
|
*/
|
|
|
|
TextInput(const TextInput &other);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Constructs a TextInput from a piece of RSS markup.
|
|
|
|
* @param node A TQDomNode which references the DOM leaf to be used
|
|
|
|
* for constructing the TextInput.
|
|
|
|
*/
|
|
|
|
TextInput(const TQDomNode &node);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Assignment operator.
|
|
|
|
* @param other The TextInput object to clone.
|
|
|
|
* @return A reference to the cloned TextInput object.
|
|
|
|
*/
|
|
|
|
TextInput &operator=(const TextInput &other);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Compares two text inputs. Two text inputs are considered
|
|
|
|
* identical if their properties (title, description, link etc.)
|
|
|
|
* are identical.
|
|
|
|
* @param other The text input to compare with.
|
|
|
|
* @return Whether the two text inputs are equal.
|
|
|
|
*/
|
|
|
|
bool operator==(const TextInput &other) const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Convenience method. Simply calls !operator==().
|
|
|
|
* @param other The text input to compared with.
|
|
|
|
* @return Whether the two text inputs are unequal.
|
|
|
|
*/
|
|
|
|
bool operator!=(const TextInput &other) const { return !operator==(other); }
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Destructor.
|
|
|
|
*/
|
|
|
|
virtual ~TextInput();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* RSS 0.90 and upwards
|
|
|
|
* @return The title (often a label to be used for the input field)
|
|
|
|
* of the text input, or TQString() if no title is available.
|
|
|
|
*/
|
|
|
|
TQString title() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* RSS 0.90 and upwards
|
|
|
|
* @return The description (usually used as a tooltip which appears
|
|
|
|
* if the mouse hovers above the input field for a short time) of
|
|
|
|
* the text input, or TQString() if no description is
|
|
|
|
* available.
|
|
|
|
*/
|
|
|
|
TQString description() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* RSS 0.90 and upwards
|
|
|
|
* @return The name of the text input (what's this for?) of the
|
|
|
|
* text input, or TQString(), if no name is available.
|
|
|
|
*/
|
|
|
|
TQString name() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* RSS 0.90 and upwards
|
|
|
|
* @return A link to which the contents of the input field should
|
|
|
|
* be sent after the user specified them. This is often a CGI
|
|
|
|
* program on a remote server which evaluates the entered
|
|
|
|
* information. An empty KURL is returned in case no link is
|
|
|
|
* available.
|
|
|
|
* Note that the RSS 0.91 Specification dictates that URLs not
|
|
|
|
* starting with "http://" or "ftp://" are considered invalid.
|
|
|
|
*/
|
|
|
|
const KURL &link() const;
|
|
|
|
|
|
|
|
private:
|
|
|
|
struct Private;
|
|
|
|
Private *d;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif // LIBRSS_TEXTINPUT_H
|