Contiguous selection and keyboard input for mod lists.
Tweak console to take up the sides. You can reorder mods from the keyboard.
This commit is contained in:
parent
524fbcdd3e
commit
b781231666
@ -19,6 +19,8 @@
|
|||||||
#include <pathutils.h>
|
#include <pathutils.h>
|
||||||
#include <QFileDialog>
|
#include <QFileDialog>
|
||||||
#include <QDebug>
|
#include <QDebug>
|
||||||
|
#include <QEvent>
|
||||||
|
#include <QKeyEvent>
|
||||||
|
|
||||||
LegacyModEditDialog::LegacyModEditDialog( LegacyInstance* inst, QWidget* parent ) :
|
LegacyModEditDialog::LegacyModEditDialog( LegacyInstance* inst, QWidget* parent ) :
|
||||||
m_inst(inst),
|
m_inst(inst),
|
||||||
@ -34,13 +36,13 @@ LegacyModEditDialog::LegacyModEditDialog( LegacyInstance* inst, QWidget* parent
|
|||||||
m_coremods = m_inst->coreModList();
|
m_coremods = m_inst->coreModList();
|
||||||
m_jarmods = m_inst->jarModList();
|
m_jarmods = m_inst->jarModList();
|
||||||
|
|
||||||
qDebug() << m_mods.data();
|
|
||||||
qDebug() << m_coremods.data();
|
|
||||||
qDebug() << m_jarmods.data();
|
|
||||||
|
|
||||||
ui->jarModsTreeView->setModel(m_jarmods.data());
|
ui->jarModsTreeView->setModel(m_jarmods.data());
|
||||||
ui->coreModsTreeView->setModel(m_coremods.data());
|
ui->coreModsTreeView->setModel(m_coremods.data());
|
||||||
ui->mlModTreeView->setModel(m_mods.data());
|
ui->mlModTreeView->setModel(m_mods.data());
|
||||||
|
|
||||||
|
ui->jarModsTreeView->installEventFilter( this );
|
||||||
|
ui->coreModsTreeView->installEventFilter( this );
|
||||||
|
ui->mlModTreeView->installEventFilter( this );
|
||||||
}
|
}
|
||||||
|
|
||||||
LegacyModEditDialog::~LegacyModEditDialog()
|
LegacyModEditDialog::~LegacyModEditDialog()
|
||||||
@ -48,6 +50,90 @@ LegacyModEditDialog::~LegacyModEditDialog()
|
|||||||
delete ui;
|
delete ui;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool LegacyModEditDialog::coreListFilter ( QKeyEvent* keyEvent )
|
||||||
|
{
|
||||||
|
switch(keyEvent->key())
|
||||||
|
{
|
||||||
|
case Qt::Key_Delete:
|
||||||
|
on_rmCoreBtn_clicked();
|
||||||
|
return true;
|
||||||
|
case Qt::Key_Plus:
|
||||||
|
on_addCoreBtn_clicked();
|
||||||
|
return true;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return QDialog::eventFilter( ui->coreModsTreeView, keyEvent );
|
||||||
|
}
|
||||||
|
|
||||||
|
bool LegacyModEditDialog::jarListFilter ( QKeyEvent* keyEvent )
|
||||||
|
{
|
||||||
|
switch(keyEvent->key())
|
||||||
|
{
|
||||||
|
case Qt::Key_Up:
|
||||||
|
{
|
||||||
|
if(keyEvent->modifiers() & Qt::ControlModifier)
|
||||||
|
{
|
||||||
|
on_moveJarUpBtn_clicked();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case Qt::Key_Down:
|
||||||
|
{
|
||||||
|
if(keyEvent->modifiers() & Qt::ControlModifier)
|
||||||
|
{
|
||||||
|
on_moveJarDownBtn_clicked();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case Qt::Key_Delete:
|
||||||
|
on_rmJarBtn_clicked();
|
||||||
|
return true;
|
||||||
|
case Qt::Key_Plus:
|
||||||
|
on_addJarBtn_clicked();
|
||||||
|
return true;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return QDialog::eventFilter( ui->jarModsTreeView, keyEvent );
|
||||||
|
}
|
||||||
|
|
||||||
|
bool LegacyModEditDialog::loaderListFilter ( QKeyEvent* keyEvent )
|
||||||
|
{
|
||||||
|
switch(keyEvent->key())
|
||||||
|
{
|
||||||
|
case Qt::Key_Delete:
|
||||||
|
on_rmModBtn_clicked();
|
||||||
|
return true;
|
||||||
|
case Qt::Key_Plus:
|
||||||
|
on_addModBtn_clicked();
|
||||||
|
return true;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return QDialog::eventFilter( ui->mlModTreeView, keyEvent );
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool LegacyModEditDialog::eventFilter ( QObject* obj, QEvent* ev )
|
||||||
|
{
|
||||||
|
if (ev->type() != QEvent::KeyPress)
|
||||||
|
{
|
||||||
|
return QDialog::eventFilter( obj, ev );
|
||||||
|
}
|
||||||
|
QKeyEvent *keyEvent = static_cast<QKeyEvent*>(ev);
|
||||||
|
if(obj == ui->jarModsTreeView)
|
||||||
|
return jarListFilter(keyEvent);
|
||||||
|
if(obj == ui->coreModsTreeView)
|
||||||
|
return coreListFilter(keyEvent);
|
||||||
|
if(obj == ui->mlModTreeView)
|
||||||
|
return loaderListFilter(keyEvent);
|
||||||
|
return QDialog::eventFilter( obj, ev );
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void LegacyModEditDialog::on_addCoreBtn_clicked()
|
void LegacyModEditDialog::on_addCoreBtn_clicked()
|
||||||
{
|
{
|
||||||
QStringList fileNames = QFileDialog::getOpenFileNames(this, "Select Core Mods");
|
QStringList fileNames = QFileDialog::getOpenFileNames(this, "Select Core Mods");
|
||||||
@ -58,51 +144,90 @@ void LegacyModEditDialog::on_addCoreBtn_clicked()
|
|||||||
}
|
}
|
||||||
void LegacyModEditDialog::on_addForgeBtn_clicked()
|
void LegacyModEditDialog::on_addForgeBtn_clicked()
|
||||||
{
|
{
|
||||||
|
|
||||||
}
|
}
|
||||||
void LegacyModEditDialog::on_addJarBtn_clicked()
|
void LegacyModEditDialog::on_addJarBtn_clicked()
|
||||||
{
|
{
|
||||||
|
QStringList fileNames = QFileDialog::getOpenFileNames(this, "Select Jar Mods");
|
||||||
|
for(auto filename:fileNames)
|
||||||
|
{
|
||||||
|
m_jarmods->installMod(QFileInfo(filename));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
void LegacyModEditDialog::on_addModBtn_clicked()
|
void LegacyModEditDialog::on_addModBtn_clicked()
|
||||||
{
|
{
|
||||||
|
QStringList fileNames = QFileDialog::getOpenFileNames(this, "Select Loader Mods");
|
||||||
|
for(auto filename:fileNames)
|
||||||
|
{
|
||||||
|
m_mods->installMod(QFileInfo(filename));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
void LegacyModEditDialog::on_addTexPackBtn_clicked()
|
void LegacyModEditDialog::on_addTexPackBtn_clicked()
|
||||||
{
|
{
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool lastfirst (QModelIndexList & list, int & first, int & last)
|
||||||
|
{
|
||||||
|
if(!list.size())
|
||||||
|
return false;
|
||||||
|
first = last = list[0].row();
|
||||||
|
for(auto item: list)
|
||||||
|
{
|
||||||
|
int row = item.row();
|
||||||
|
if(row < first)
|
||||||
|
first = row;
|
||||||
|
if(row > last)
|
||||||
|
last = row;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
void LegacyModEditDialog::on_moveJarDownBtn_clicked()
|
void LegacyModEditDialog::on_moveJarDownBtn_clicked()
|
||||||
{
|
{
|
||||||
|
int first, last;
|
||||||
|
auto list = ui->jarModsTreeView->selectionModel()->selectedRows();
|
||||||
|
|
||||||
|
if(!lastfirst(list, first, last))
|
||||||
|
return;
|
||||||
|
|
||||||
|
m_jarmods->moveModsDown(first, last);
|
||||||
}
|
}
|
||||||
void LegacyModEditDialog::on_moveJarUpBtn_clicked()
|
void LegacyModEditDialog::on_moveJarUpBtn_clicked()
|
||||||
{
|
{
|
||||||
|
int first, last;
|
||||||
|
auto list = ui->jarModsTreeView->selectionModel()->selectedRows();
|
||||||
|
|
||||||
|
if(!lastfirst(list, first, last))
|
||||||
|
return;
|
||||||
|
m_jarmods->moveModsUp(first, last);
|
||||||
}
|
}
|
||||||
void LegacyModEditDialog::on_rmCoreBtn_clicked()
|
void LegacyModEditDialog::on_rmCoreBtn_clicked()
|
||||||
{
|
{
|
||||||
auto sm = ui->coreModsTreeView->selectionModel();
|
int first, last;
|
||||||
auto selection = sm->selectedRows();
|
auto list = ui->coreModsTreeView->selectionModel()->selectedRows();
|
||||||
if(!selection.size())
|
|
||||||
|
if(!lastfirst(list, first, last))
|
||||||
return;
|
return;
|
||||||
m_coremods->deleteMod(selection[0].row());
|
m_coremods->deleteMods(first, last);
|
||||||
}
|
}
|
||||||
void LegacyModEditDialog::on_rmJarBtn_clicked()
|
void LegacyModEditDialog::on_rmJarBtn_clicked()
|
||||||
{
|
{
|
||||||
auto sm = ui->jarModsTreeView->selectionModel();
|
int first, last;
|
||||||
auto selection = sm->selectedRows();
|
auto list = ui->jarModsTreeView->selectionModel()->selectedRows();
|
||||||
if(!selection.size())
|
|
||||||
|
if(!lastfirst(list, first, last))
|
||||||
return;
|
return;
|
||||||
m_jarmods->deleteMod(selection[0].row());
|
m_jarmods->deleteMods(first, last);
|
||||||
}
|
}
|
||||||
void LegacyModEditDialog::on_rmModBtn_clicked()
|
void LegacyModEditDialog::on_rmModBtn_clicked()
|
||||||
{
|
{
|
||||||
auto sm = ui->mlModTreeView->selectionModel();
|
int first, last;
|
||||||
auto selection = sm->selectedRows();
|
auto list = ui->mlModTreeView->selectionModel()->selectedRows();
|
||||||
if(!selection.size())
|
|
||||||
|
if(!lastfirst(list, first, last))
|
||||||
return;
|
return;
|
||||||
m_mods->deleteMod(selection[0].row());
|
m_mods->deleteMods(first, last);
|
||||||
}
|
}
|
||||||
void LegacyModEditDialog::on_rmTexPackBtn_clicked()
|
void LegacyModEditDialog::on_rmTexPackBtn_clicked()
|
||||||
{
|
{
|
||||||
|
@ -51,7 +51,11 @@ private slots:
|
|||||||
void on_viewTexPackBtn_clicked();
|
void on_viewTexPackBtn_clicked();
|
||||||
// Questionable: SettingsDialog doesn't need this for some reason?
|
// Questionable: SettingsDialog doesn't need this for some reason?
|
||||||
void on_buttonBox_rejected();
|
void on_buttonBox_rejected();
|
||||||
|
protected:
|
||||||
|
bool eventFilter(QObject *obj, QEvent *ev);
|
||||||
|
bool jarListFilter( QKeyEvent* ev );
|
||||||
|
bool coreListFilter( QKeyEvent* ev );
|
||||||
|
bool loaderListFilter( QKeyEvent* ev );
|
||||||
private:
|
private:
|
||||||
Ui::LegacyModEditDialog *ui;
|
Ui::LegacyModEditDialog *ui;
|
||||||
QSharedPointer<ModList> m_mods;
|
QSharedPointer<ModList> m_mods;
|
||||||
|
@ -13,7 +13,7 @@ ModListView::ModListView ( QWidget* parent )
|
|||||||
setRootIsDecorated ( false );
|
setRootIsDecorated ( false );
|
||||||
setSortingEnabled ( false );
|
setSortingEnabled ( false );
|
||||||
setAlternatingRowColors ( true );
|
setAlternatingRowColors ( true );
|
||||||
setSelectionMode ( QAbstractItemView::SingleSelection );
|
setSelectionMode ( QAbstractItemView::ContiguousSelection );
|
||||||
setHeaderHidden ( false );
|
setHeaderHidden ( false );
|
||||||
setSelectionBehavior(QAbstractItemView::SelectRows);
|
setSelectionBehavior(QAbstractItemView::SelectRows);
|
||||||
setVerticalScrollBarPolicy ( Qt::ScrollBarAlwaysOn );
|
setVerticalScrollBarPolicy ( Qt::ScrollBarAlwaysOn );
|
||||||
|
@ -1,6 +1,8 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
#include <QTreeView>
|
#include <QTreeView>
|
||||||
|
|
||||||
|
class Mod;
|
||||||
|
|
||||||
class ModListView: public QTreeView
|
class ModListView: public QTreeView
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
@ -14,6 +14,15 @@
|
|||||||
<string>MultiMC Console</string>
|
<string>MultiMC Console</string>
|
||||||
</property>
|
</property>
|
||||||
<layout class="QVBoxLayout" name="verticalLayout">
|
<layout class="QVBoxLayout" name="verticalLayout">
|
||||||
|
<property name="leftMargin">
|
||||||
|
<number>0</number>
|
||||||
|
</property>
|
||||||
|
<property name="topMargin">
|
||||||
|
<number>0</number>
|
||||||
|
</property>
|
||||||
|
<property name="rightMargin">
|
||||||
|
<number>0</number>
|
||||||
|
</property>
|
||||||
<item>
|
<item>
|
||||||
<widget class="QPlainTextEdit" name="text">
|
<widget class="QPlainTextEdit" name="text">
|
||||||
<property name="font">
|
<property name="font">
|
||||||
@ -30,6 +39,9 @@
|
|||||||
<property name="plainText">
|
<property name="plainText">
|
||||||
<string notr="true"/>
|
<string notr="true"/>
|
||||||
</property>
|
</property>
|
||||||
|
<property name="textInteractionFlags">
|
||||||
|
<set>Qt::LinksAccessibleByKeyboard|Qt::LinksAccessibleByMouse|Qt::TextBrowserInteraction|Qt::TextSelectableByKeyboard|Qt::TextSelectableByMouse</set>
|
||||||
|
</property>
|
||||||
<property name="centerOnScroll">
|
<property name="centerOnScroll">
|
||||||
<bool>false</bool>
|
<bool>false</bool>
|
||||||
</property>
|
</property>
|
||||||
|
@ -260,5 +260,7 @@ QString Mod::version() const
|
|||||||
return "Folder";
|
return "Folder";
|
||||||
case MOD_SINGLEFILE:
|
case MOD_SINGLEFILE:
|
||||||
return "File";
|
return "File";
|
||||||
|
default:
|
||||||
|
return "VOID";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -137,9 +137,9 @@ bool ModList::isValid()
|
|||||||
return m_dir.exists() && m_dir.isReadable();
|
return m_dir.exists() && m_dir.isReadable();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ModList::installMod ( const QFileInfo& filename, size_t index )
|
bool ModList::installMod ( const QFileInfo& filename, int index )
|
||||||
{
|
{
|
||||||
if(!filename.exists() || !filename.isReadable())
|
if(!filename.exists() || !filename.isReadable() || index < 0)
|
||||||
{
|
{
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -198,9 +198,9 @@ bool ModList::installMod ( const QFileInfo& filename, size_t index )
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ModList::deleteMod ( size_t index )
|
bool ModList::deleteMod ( int index )
|
||||||
{
|
{
|
||||||
if(index >= mods.size())
|
if(index >= mods.size() || index < 0)
|
||||||
return false;
|
return false;
|
||||||
Mod & m = mods[index];
|
Mod & m = mods[index];
|
||||||
if(m.destroy())
|
if(m.destroy())
|
||||||
@ -215,7 +215,23 @@ bool ModList::deleteMod ( size_t index )
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ModList::moveMod ( size_t from, size_t to )
|
bool ModList::deleteMods ( int first, int last )
|
||||||
|
{
|
||||||
|
for(int i = first; i <= last; i++)
|
||||||
|
{
|
||||||
|
Mod & m = mods[i];
|
||||||
|
m.destroy();
|
||||||
|
}
|
||||||
|
beginRemoveRows(QModelIndex(), first, last);
|
||||||
|
mods.erase(mods.begin() + first, mods.begin() + last + 1);
|
||||||
|
endRemoveRows();
|
||||||
|
saveListFile();
|
||||||
|
emit changed();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool ModList::moveModTo ( int from, int to )
|
||||||
{
|
{
|
||||||
if(from < 0 || from >= mods.size())
|
if(from < 0 || from >= mods.size())
|
||||||
return false;
|
return false;
|
||||||
@ -223,18 +239,61 @@ bool ModList::moveMod ( size_t from, size_t to )
|
|||||||
to = rowCount() - 1;
|
to = rowCount() - 1;
|
||||||
if (to == -1)
|
if (to == -1)
|
||||||
to = rowCount() - 1;
|
to = rowCount() - 1;
|
||||||
// FIXME: this should be better, but segfaults for some reason
|
if(from == to)
|
||||||
//beginMoveRows(QModelIndex(), from, from, QModelIndex(), to);
|
return false;
|
||||||
|
int togap = to > from ? to + 1: to;
|
||||||
beginResetModel();
|
beginMoveRows(QModelIndex(), from, from, QModelIndex(), togap);
|
||||||
mods.move(from, to);
|
mods.move(from, to);
|
||||||
endResetModel();
|
endMoveRows();
|
||||||
//endMoveRows();
|
|
||||||
saveListFile();
|
saveListFile();
|
||||||
emit changed();
|
emit changed();
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool ModList::moveModUp ( int from )
|
||||||
|
{
|
||||||
|
if(from > 0)
|
||||||
|
return moveModTo(from, from - 1);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool ModList::moveModsUp ( int first, int last )
|
||||||
|
{
|
||||||
|
if(first == 0)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
beginMoveRows(QModelIndex(), first, last, QModelIndex(), first - 1);
|
||||||
|
mods.move(first-1, last);
|
||||||
|
endMoveRows();
|
||||||
|
saveListFile();
|
||||||
|
emit changed();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool ModList::moveModDown ( int from )
|
||||||
|
{
|
||||||
|
if(from < 0)
|
||||||
|
return false;
|
||||||
|
if(from < mods.size() - 1)
|
||||||
|
return moveModTo(from, from + 1);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool ModList::moveModsDown ( int first, int last )
|
||||||
|
{
|
||||||
|
if(last == mods.size() - 1)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
beginMoveRows(QModelIndex(), first, last, QModelIndex(), last + 2);
|
||||||
|
mods.move(last+1, first);
|
||||||
|
endMoveRows();
|
||||||
|
saveListFile();
|
||||||
|
emit changed();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
int ModList::columnCount ( const QModelIndex& parent ) const
|
int ModList::columnCount ( const QModelIndex& parent ) const
|
||||||
{
|
{
|
||||||
return 2;
|
return 2;
|
||||||
@ -329,11 +388,6 @@ QMimeData* ModList::mimeData ( const QModelIndexList& indexes ) const
|
|||||||
data->setText(params.join('|'));
|
data->setText(params.join('|'));
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
bool ModList::removeRows ( int row, int count, const QModelIndex& parent )
|
|
||||||
{
|
|
||||||
return QAbstractItemModel::removeRows ( row, count, parent );
|
|
||||||
}
|
|
||||||
|
|
||||||
bool ModList::dropMimeData ( const QMimeData* data, Qt::DropAction action, int row, int column, const QModelIndex& parent )
|
bool ModList::dropMimeData ( const QMimeData* data, Qt::DropAction action, int row, int column, const QModelIndex& parent )
|
||||||
{
|
{
|
||||||
if (action == Qt::IgnoreAction)
|
if (action == Qt::IgnoreAction)
|
||||||
@ -386,7 +440,7 @@ bool ModList::dropMimeData ( const QMimeData* data, Qt::DropAction action, int r
|
|||||||
if(row == remoteIndex)
|
if(row == remoteIndex)
|
||||||
return false;
|
return false;
|
||||||
// otherwise, move the mod :D
|
// otherwise, move the mod :D
|
||||||
moveMod(remoteIndex, row);
|
moveModTo(remoteIndex, row);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
|
@ -45,16 +45,31 @@ public:
|
|||||||
/**
|
/**
|
||||||
* Adds the given mod to the list at the given index - if the list supports custom ordering
|
* Adds the given mod to the list at the given index - if the list supports custom ordering
|
||||||
*/
|
*/
|
||||||
virtual bool installMod(const QFileInfo& filename, size_t index = 0);
|
virtual bool installMod(const QFileInfo& filename, int index = 0);
|
||||||
|
|
||||||
/// Deletes the mod at the given index.
|
/// Deletes the mod at the given index.
|
||||||
virtual bool deleteMod(size_t index);
|
virtual bool deleteMod(int index);
|
||||||
|
|
||||||
|
/// Deletes all the selected mods
|
||||||
|
virtual bool deleteMods( int first, int last );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* move the mod at index to the position N
|
* move the mod at index to the position N
|
||||||
* 0 is the beginning of the list, length() is the end of the list.
|
* 0 is the beginning of the list, length() is the end of the list.
|
||||||
*/
|
*/
|
||||||
virtual bool moveMod(size_t from, size_t to);
|
virtual bool moveModTo(int from, int to);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* move the mod at index one position upwards
|
||||||
|
*/
|
||||||
|
virtual bool moveModUp(int from);
|
||||||
|
virtual bool moveModsUp( int first, int last );
|
||||||
|
|
||||||
|
/**
|
||||||
|
* move the mod at index one position downwards
|
||||||
|
*/
|
||||||
|
virtual bool moveModDown(int from);
|
||||||
|
virtual bool moveModsDown( int first, int last );
|
||||||
|
|
||||||
/// flags, mostly to support drag&drop
|
/// flags, mostly to support drag&drop
|
||||||
virtual Qt::ItemFlags flags(const QModelIndex& index) const;
|
virtual Qt::ItemFlags flags(const QModelIndex& index) const;
|
||||||
@ -67,7 +82,6 @@ public:
|
|||||||
/// what drag actions do we support?
|
/// what drag actions do we support?
|
||||||
virtual Qt::DropActions supportedDragActions() const;
|
virtual Qt::DropActions supportedDragActions() const;
|
||||||
|
|
||||||
virtual bool removeRows(int row, int count, const QModelIndex& parent = QModelIndex());
|
|
||||||
/// what drop actions do we support?
|
/// what drop actions do we support?
|
||||||
virtual Qt::DropActions supportedDropActions() const;
|
virtual Qt::DropActions supportedDropActions() const;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user