Adding now adds an empty string to list and starts edit for that string.
[emufront] / src / widgets / stringlistwidget.h
1 // EmuFront
2 // Copyright 2010 Mikko Keinänen
3 //
4 // This file is part of EmuFront.
5 //
6 //
7 // EmuFront is free software: you can redistribute it and/or modify
8 // it under the terms of the GNU General Public License version 2 as published by
9 // the Free Software Foundation and appearing in the file gpl.txt included in the
10 // packaging of this file.
11 //
12 // EmuFront is distributed in the hope that it will be useful,
13 // but WITHOUT ANY WARRANTY; without even the implied warranty of
14 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15 // GNU General Public License for more details.
16 //
17 // You should have received a copy of the GNU General Public License
18 // along with EmuFront.  If not, see <http://www.gnu.org/licenses/>.
19
20 #ifndef STRINGLISTWIDGET_H
21 #define STRINGLISTWIDGET_H
22
23 #include <QWidget>
24
25 class QListWidget;
26 class QListWidgetItem;
27 class QPushButton;
28
29 class StringListWidget : public QWidget
30 {
31     Q_OBJECT
32 public:
33     explicit StringListWidget(QWidget *parent = 0, bool sort = true, int sortIndex = 0);
34     QStringList getItems();
35     void setItems(QStringList);
36     void clear();
37
38 signals:
39     void stringListUpdated();
40
41 protected:
42     virtual bool confirmInput(const QString &) const;
43
44 private slots:
45     void addClicked();
46     void removeClicked();
47     void itemUpdated(QListWidgetItem *);
48
49 private:
50     void initUi();
51     void connectSignals();
52     //QStringListModel *model;
53     QListWidget *stringList;
54     QPushButton *btnAdd;
55     QPushButton *btnRemove;
56     bool sort;
57     int sortIndex;
58 };
59
60 #endif // STRINGLISTWIDGET_H