You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
tdelibs/kate/part/kateschema.h

324 lines
7.7 KiB

/* This file is part of the KDE libraries
Copyright (C) 2001-2003 Christoph Cullmann <cullmann@kde.org>
Copyright (C) 2002, 2003 Anders Lund <anders.lund@lund.tdcadsl.dk>
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Library General Public
License version 2 as published by the Free Software Foundation.
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 __KATE_SCHEMA_H__
#define __KATE_SCHEMA_H__
#include "katehighlight.h"
#include "katedialogs.h"
#include <qstringlist.h>
#include <qintdict.h>
#include <qmap.h>
#include <qlistview.h>
#include <qfont.h>
#include <kconfig.h>
#include <kaction.h>
class KateView;
class KateStyleListItem;
class KateStyleListCaption;
class KColorButton;
class QPopupMenu;
class KComboBox;
class KateSchemaManager
{
public:
KateSchemaManager ();
~KateSchemaManager ();
/**
* Schema Config changed, update all renderers
*/
void update (bool readfromfile = true);
/**
* return kconfig with right group set or set to Normal if not there
*/
KConfig *schema (uint number);
void addSchema (const QString &t);
void removeSchema (uint number);
/**
* is this schema valid ? (does it exist ?)
*/
bool validSchema (uint number);
/**
* if not found, defaults to 0
*/
uint number (const QString &name);
/**
* group names in the end, no i18n involved
*/
QString name (uint number);
/**
* Don't modify, list with the names of the schemas (i18n name for the default ones)
*/
const QStringList &list () { return m_schemas; }
static QString normalSchema ();
static QString printingSchema ();
private:
KConfig m_config;
QStringList m_schemas;
};
class KateViewSchemaAction : public KActionMenu
{
Q_OBJECT
public:
KateViewSchemaAction(const QString& text, QObject* parent = 0, const char* name = 0)
: KActionMenu(text, parent, name) { init(); };
~KateViewSchemaAction(){;};
void updateMenu (KateView *view);
private:
void init();
QGuardedPtr<KateView> m_view;
QStringList names;
int last;
public slots:
void slotAboutToShow();
private slots:
void setSchema (int mode);
};
//
// DIALOGS
//
/*
QListView that automatically adds columns for KateStyleListItems and provides a
popup menu and a slot to edit a style using the keyboard.
Added by anders, jan 23 2002.
*/
class KateStyleListView : public QListView
{
Q_OBJECT
friend class KateStyleListItem;
public:
KateStyleListView( QWidget *parent=0, bool showUseDefaults=false);
~KateStyleListView() {};
/* Display a popupmenu for item i at the specified global position, eventually with a title,
promoting the context name of that item */
void showPopupMenu( KateStyleListItem *i, const QPoint &globalPos, bool showtitle=false );
void emitChanged() { emit changed(); };
void setBgCol( const QColor &c ) { bgcol = c; }
void setSelCol( const QColor &c ) { selcol = c; }
void setNormalCol( const QColor &c ) { normalcol = c; }
private slots:
/* Display a popupmenu for item i at item position */
void showPopupMenu( QListViewItem *i, const QPoint &globalPos );
/* call item to change a property, or display a menu */
void slotMousePressed( int, QListViewItem*, const QPoint&, int );
/* asks item to change the property in q */
void mSlotPopupHandler( int z );
void unsetColor( int );
signals:
void changed();
private:
QColor bgcol, selcol, normalcol;
QFont docfont;
};
class KateSchemaConfigColorTab : public QWidget
{
Q_OBJECT
public:
KateSchemaConfigColorTab( QWidget *parent = 0, const char *name = 0 );
~KateSchemaConfigColorTab();
private:
KColorButton *m_back;
KColorButton *m_selected;
KColorButton *m_current;
KColorButton *m_bracket;
KColorButton *m_wwmarker;
KColorButton *m_iconborder;
KColorButton *m_tmarker;
KColorButton *m_linenumber;
KColorButton *m_markers; // bg color for current selected marker
KComboBox* m_combobox; // switch marker type
// Class for storing the properties on 1 schema.
class SchemaColors {
public:
QColor back, selected, current, bracket, wwmarker, iconborder, tmarker, linenumber;
QMap<int, QColor> markerColors; // stores all markerColors
};
// schemaid=data, created when a schema is entered
QMap<int,SchemaColors> m_schemas;
// current schema
int m_schema;
public slots:
void apply();
void schemaChanged( int newSchema );
signals:
void changed(); // connected to parentWidget()->parentWidget() SLOT(slotChanged)
protected slots:
void slotMarkerColorChanged(const QColor&);
void slotComboBoxChanged(int index);
};
typedef QMap<int,QFont> FontMap; // ### remove it
class KateSchemaConfigFontTab : public QWidget
{
Q_OBJECT
public:
KateSchemaConfigFontTab( QWidget *parent = 0, const char *name = 0 );
~KateSchemaConfigFontTab();
public:
void readConfig (KConfig *config);
public slots:
void apply();
void schemaChanged( int newSchema );
signals:
void changed(); // connected to parentWidget()->parentWidget() SLOT(slotChanged)
private:
class KFontChooser *m_fontchooser;
FontMap m_fonts;
int m_schema;
private slots:
void slotFontSelected( const QFont &font );
};
class KateSchemaConfigFontColorTab : public QWidget
{
Q_OBJECT
public:
KateSchemaConfigFontColorTab( QWidget *parent = 0, const char *name = 0 );
~KateSchemaConfigFontColorTab();
public:
void schemaChanged (uint schema);
void reload ();
void apply ();
KateAttributeList *attributeList (uint schema);
private:
KateStyleListView *m_defaultStyles;
QIntDict<KateAttributeList> m_defaultStyleLists;
};
class KateSchemaConfigHighlightTab : public QWidget
{
Q_OBJECT
public:
KateSchemaConfigHighlightTab( QWidget *parent = 0, const char *name = 0, KateSchemaConfigFontColorTab *page = 0, uint hl = 0 );
~KateSchemaConfigHighlightTab();
public:
void schemaChanged (uint schema);
void reload ();
void apply ();
protected slots:
void hlChanged(int z);
private:
KateSchemaConfigFontColorTab *m_defaults;
QComboBox *hlCombo;
KateStyleListView *m_styles;
uint m_schema;
int m_hl;
QIntDict< QIntDict<KateHlItemDataList> > m_hlDict;
};
class KateSchemaConfigPage : public KateConfigPage
{
Q_OBJECT
public:
KateSchemaConfigPage ( QWidget *parent, class KateDocument *doc=0 );
~KateSchemaConfigPage ();
public slots:
void apply();
void reload();
void reset();
void defaults();
private slots:
void update ();
void deleteSchema ();
void newSchema ();
void schemaChanged (int schema);
void newCurrentPage (QWidget *w);
private:
int m_lastSchema;
int m_defaultSchema;
class QTabWidget *m_tabWidget;
class QPushButton *btndel;
class QComboBox *defaultSchemaCombo;
class QComboBox *schemaCombo;
KateSchemaConfigColorTab *m_colorTab;
KateSchemaConfigFontTab *m_fontTab;
KateSchemaConfigFontColorTab *m_fontColorTab;
KateSchemaConfigHighlightTab *m_highlightTab;
};
#endif
// kate: space-indent on; indent-width 2; replace-tabs on;