|
|
|
// -*- mode: C++; c-file-style: "gnu" -*-
|
|
|
|
// kmfilterrulesedit.h
|
|
|
|
// Author: Marc Mutz <Marc@Mutz.com>
|
|
|
|
// This code is under GPL
|
|
|
|
|
|
|
|
#ifndef KMFILTERRULESEDIT_H
|
|
|
|
#define KMFILTERRULESEDIT_H
|
|
|
|
|
|
|
|
#include "kwidgetlister.h"
|
|
|
|
|
|
|
|
#include <tqgroupbox.h>
|
|
|
|
#include <tqstringlist.h>
|
|
|
|
|
|
|
|
class KMSearchRule;
|
|
|
|
class KMSearchPattern;
|
|
|
|
|
|
|
|
template <typename T> class TQPtrList;
|
|
|
|
class TQString;
|
|
|
|
class TQComboBox;
|
|
|
|
class TQLineEdit;
|
|
|
|
class TQRadioButton;
|
|
|
|
class TQWidgetStack;
|
|
|
|
class TQLabel;
|
|
|
|
class KMSearchPatternEdit;
|
|
|
|
|
|
|
|
/** A widget to edit a single KMSearchRule.
|
|
|
|
It consists of an editable TQComboBox for the field,
|
|
|
|
a read-only TQComboBox for the function and
|
|
|
|
a TQLineEdit for the content or the pattern (in case of regexps).
|
|
|
|
It manages the i18n itself, so field name should be in it's english form.
|
|
|
|
|
|
|
|
To use, you essentially give it the reference to a KMSearchRule and
|
|
|
|
it does the rest. It will never delete the rule itself, as it assumes
|
|
|
|
that something outside of it manages this.
|
|
|
|
|
|
|
|
@short A widget to edit a single KMSearchRule.
|
|
|
|
@author Marc Mutz <Marc@Mutz.com>
|
|
|
|
*/
|
|
|
|
|
|
|
|
class KMSearchRuleWidget : public QWidget
|
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
public:
|
|
|
|
/** Constructor. You can give a KMSearchRule as parameter, which will
|
|
|
|
be used to initialize the widget. */
|
|
|
|
KMSearchRuleWidget( TQWidget* parent=0, KMSearchRule* aRule=0, const char* name=0, bool headersOnly = false, bool absoluteDates = false );
|
|
|
|
|
|
|
|
enum { Message, Body, AnyHeader, Recipients, Size, AgeInDays, Status,
|
|
|
|
Subject, From, To, CC, ReplyTo, Organization };
|
|
|
|
|
|
|
|
/** Set whether only header fields can be searched. If @p is true only
|
|
|
|
header fields can be searched otherwise \<message\> and \<body\> searches
|
|
|
|
are available also. */
|
|
|
|
void setHeadersOnly( bool headersOnly );
|
|
|
|
/** Set the rule. The rule is accepted regardless of the return
|
|
|
|
value of KMSearchRule::isEmpty. This widget makes a shallow
|
|
|
|
copy of @p aRule and operates directly on it. If @p aRule is
|
|
|
|
0, resets itself, taks user input, but does essentially
|
|
|
|
nothing. If you pass 0, you should probably disable it. */
|
|
|
|
void setRule( KMSearchRule* aRule );
|
|
|
|
/** Return a reference to the currently-worked-on KMSearchRule. */
|
|
|
|
KMSearchRule* rule() const;
|
|
|
|
/** Resets the rule currently worked on and updates the widget
|
|
|
|
accordingly. */
|
|
|
|
void reset();
|
|
|
|
static int ruleFieldToId( const TQString & i18nVal );
|
|
|
|
|
|
|
|
public slots:
|
|
|
|
void slotFunctionChanged();
|
|
|
|
void slotValueChanged();
|
|
|
|
|
|
|
|
signals:
|
|
|
|
/** This signal is emitted whenever the user alters the field. The
|
|
|
|
pseudo-headers <...> are returned in their i18n form, but stored
|
|
|
|
in their english form in the rule. */
|
|
|
|
void fieldChanged( const TQString & );
|
|
|
|
|
|
|
|
/** This signal is emitted whenever the user alters the
|
|
|
|
contents/value of the rule. */
|
|
|
|
void contentsChanged( const TQString & );
|
|
|
|
|
|
|
|
protected:
|
|
|
|
/** Used internally to translate i18n-ized pseudo-headers back to
|
|
|
|
english. */
|
|
|
|
static TQCString ruleFieldToEnglish(const TQString & i18nVal);
|
|
|
|
/** Used internally to find the corresponding index into the field
|
|
|
|
ComboBox. Returns the index if found or -1 if the search failed, */
|
|
|
|
int indexOfRuleField( const TQCString & aName ) const;
|
|
|
|
|
|
|
|
protected slots:
|
|
|
|
void slotRuleFieldChanged( const TQString & );
|
|
|
|
|
|
|
|
private:
|
|
|
|
void initWidget();
|
|
|
|
void initFieldList( bool headersOnly, bool absoluteDates );
|
|
|
|
|
|
|
|
TQStringList mFilterFieldList;
|
|
|
|
TQComboBox *mRuleField;
|
|
|
|
TQWidgetStack *mFunctionStack;
|
|
|
|
TQWidgetStack *mValueStack;
|
|
|
|
bool mAbsoluteDates;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
class KMSearchRuleWidgetLister : public KWidgetLister
|
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
|
|
|
|
friend class ::KMSearchPatternEdit;
|
|
|
|
|
|
|
|
public:
|
|
|
|
KMSearchRuleWidgetLister( TQWidget *parent=0, const char* name=0, bool headersOnly = false, bool absoluteDates = false );
|
|
|
|
|
|
|
|
virtual ~KMSearchRuleWidgetLister();
|
|
|
|
|
|
|
|
void setRuleList( TQPtrList<KMSearchRule> * aList );
|
|
|
|
void setHeadersOnly( bool headersOnly );
|
|
|
|
|
|
|
|
public slots:
|
|
|
|
void reset();
|
|
|
|
|
|
|
|
protected:
|
|
|
|
virtual void clearWidget( TQWidget *aWidget );
|
|
|
|
virtual TQWidget* createWidget( TQWidget *parent );
|
|
|
|
|
|
|
|
private:
|
|
|
|
void regenerateRuleListFromWidgets();
|
|
|
|
TQPtrList<KMSearchRule> *mRuleList;
|
|
|
|
bool mHeadersOnly;
|
|
|
|
bool mAbsoluteDates;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
/** This widget is intended to be used in the filter configuration as
|
|
|
|
well as in the message search dialogs. It consists of a frame,
|
|
|
|
inside which there are placed two radio buttons entitled "Match
|
|
|
|
{all,any} of the following", followed by a vertical stack of
|
|
|
|
KMSearchRuleWidgets (initially two) and two buttons to add and
|
|
|
|
remove, resp., additional KMSearchWidget 's.
|
|
|
|
|
|
|
|
To set the widget according to a given KMSearchPattern, use
|
|
|
|
setSearchPattern; to initialize it (e.g. for a new, virgin
|
|
|
|
rule), use setSearchPattern with a 0 argument. The widget
|
|
|
|
operates directly on a shallow(!) copy of the search rule. So
|
|
|
|
while you actually don't really need searchPattern, because
|
|
|
|
you can always store a pointer to the current pattern yourself,
|
|
|
|
you must not modify the currently-worked-on pattern yourself while
|
|
|
|
this widget holds a reference to it. The only exceptions are:
|
|
|
|
|
|
|
|
@li If you edit a derived class, you can change aspects of the
|
|
|
|
class that don't interfere with the KMSearchPattern part. An
|
|
|
|
example is KMFilter, whose actions you can still edit while
|
|
|
|
the KMSearchPattern part of it is being acted upon by this
|
|
|
|
widget.
|
|
|
|
|
|
|
|
@li You can change the name of the pattern, but only using (this
|
|
|
|
widget's) setName. You cannot change the pattern's name
|
|
|
|
directly, although this widget in itself doesn't let the user
|
|
|
|
change it. This is because it auto-names the pattern to
|
|
|
|
"<$field>:$contents" iff the pattern begins with "<".
|
|
|
|
|
|
|
|
@short A widget which allows editing a set of KMSearchRule's.
|
|
|
|
@author Marc Mutz <Marc@Mutz.com>
|
|
|
|
*/
|
|
|
|
|
|
|
|
class KMSearchPatternEdit : public TQGroupBox {
|
|
|
|
Q_OBJECT
|
|
|
|
public:
|
|
|
|
/** Constructor. The parent and name parameters are passed to the underlying
|
|
|
|
TQGroupBox, as usual. */
|
|
|
|
KMSearchPatternEdit(TQWidget *parent=0, const char *name=0, bool headersOnly = false, bool absoluteDates = false);
|
|
|
|
/** Constructor. This one allows you to set a title different from
|
|
|
|
i18n("Search Criteria"). */
|
|
|
|
KMSearchPatternEdit(const TQString & title, TQWidget *parent=0, const char *name=0, bool headersOnly = false, bool absoluteDates = false);
|
|
|
|
~KMSearchPatternEdit();
|
|
|
|
|
|
|
|
/** Set the search pattern. Rules are inserted regardless of the
|
|
|
|
return value of each rules' KMSearchRule::isEmpty. This
|
|
|
|
widget makes a shallow copy of @p aPattern and operates directly
|
|
|
|
on it. */
|
|
|
|
void setSearchPattern( KMSearchPattern* aPattern );
|
|
|
|
/** Set whether only header fields can be searched. If @p is true only
|
|
|
|
header fields can be searched otherwise \<message\> and \<body\> searches
|
|
|
|
are available also. */
|
|
|
|
void setHeadersOnly( bool headersOnly );
|
|
|
|
|
|
|
|
/** Updates the search pattern according to the current widget values */
|
|
|
|
void updateSearchPattern() { mRuleLister->regenerateRuleListFromWidgets(); }
|
|
|
|
|
|
|
|
public slots:
|
|
|
|
/** Called when the widget should let go of the currently referenced
|
|
|
|
filter and disable itself. */
|
|
|
|
void reset();
|
|
|
|
|
|
|
|
signals:
|
|
|
|
/** This signal is emitted whenever the name of the processed
|
|
|
|
search pattern may have changed. */
|
|
|
|
void maybeNameChanged();
|
|
|
|
|
|
|
|
private slots:
|
|
|
|
void slotRadioClicked(int aIdx);
|
|
|
|
void slotAutoNameHack();
|
|
|
|
|
|
|
|
private:
|
|
|
|
void initLayout( bool headersOnly, bool absoluteDates );
|
|
|
|
|
|
|
|
KMSearchPattern *mPattern;
|
|
|
|
TQRadioButton *mAllRBtn, *mAnyRBtn;
|
|
|
|
KMSearchRuleWidgetLister *mRuleLister;
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|