[packagechooser] Add a model for the list to use
- Model contents currently hard-coded
This commit is contained in:
parent
727290f75e
commit
d1a85ba5ca
@ -6,6 +6,7 @@ calamares_add_plugin( packagechooser
|
|||||||
SOURCES
|
SOURCES
|
||||||
PackageChooserPage.cpp
|
PackageChooserPage.cpp
|
||||||
PackageChooserViewStep.cpp
|
PackageChooserViewStep.cpp
|
||||||
|
PackageModel.cpp
|
||||||
UI
|
UI
|
||||||
page_package.ui
|
page_package.ui
|
||||||
LINK_PRIVATE_LIBRARIES
|
LINK_PRIVATE_LIBRARIES
|
||||||
|
@ -30,9 +30,7 @@ PackageChooserPage::PackageChooserPage( QWidget* parent )
|
|||||||
, ui( new Ui::PackageChooserPage )
|
, ui( new Ui::PackageChooserPage )
|
||||||
{
|
{
|
||||||
ui->setupUi( this );
|
ui->setupUi( this );
|
||||||
CALAMARES_RETRANSLATE(
|
CALAMARES_RETRANSLATE( updateLabels(); )
|
||||||
updateLabels();
|
|
||||||
)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@ -42,3 +40,17 @@ PackageChooserPage::updateLabels()
|
|||||||
ui->productScreenshot->hide();
|
ui->productScreenshot->hide();
|
||||||
ui->productDescription->setText( tr( "Please pick a product from the list." ) );
|
ui->productDescription->setText( tr( "Please pick a product from the list." ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
PackageChooserPage::setModel( QAbstractItemModel* model )
|
||||||
|
{
|
||||||
|
ui->products->setModel( model );
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
PackageChooserPage::currentChanged( const QModelIndex& current )
|
||||||
|
{
|
||||||
|
updateLabels();
|
||||||
|
cDebug() << "Current updated to" << current.row();
|
||||||
|
cDebug() << ui->products->model()->data( current, Qt::DisplayRole );
|
||||||
|
}
|
||||||
|
@ -19,6 +19,7 @@
|
|||||||
#ifndef PACKAGECHOOSERPAGE_H
|
#ifndef PACKAGECHOOSERPAGE_H
|
||||||
#define PACKAGECHOOSERPAGE_H
|
#define PACKAGECHOOSERPAGE_H
|
||||||
|
|
||||||
|
#include <QAbstractItemModel>
|
||||||
#include <QWidget>
|
#include <QWidget>
|
||||||
|
|
||||||
namespace Ui
|
namespace Ui
|
||||||
@ -32,8 +33,11 @@ class PackageChooserPage : public QWidget
|
|||||||
public:
|
public:
|
||||||
explicit PackageChooserPage( QWidget* parent = nullptr );
|
explicit PackageChooserPage( QWidget* parent = nullptr );
|
||||||
|
|
||||||
|
void setModel( QAbstractItemModel* model );
|
||||||
|
|
||||||
public slots:
|
public slots:
|
||||||
void updateLabels();
|
void updateLabels();
|
||||||
|
void currentChanged( const QModelIndex& current );
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Ui::PackageChooserPage* ui;
|
Ui::PackageChooserPage* ui;
|
||||||
|
@ -19,6 +19,7 @@
|
|||||||
#include "PackageChooserViewStep.h"
|
#include "PackageChooserViewStep.h"
|
||||||
|
|
||||||
#include "PackageChooserPage.h"
|
#include "PackageChooserPage.h"
|
||||||
|
#include "PackageModel.h"
|
||||||
|
|
||||||
#include "GlobalStorage.h"
|
#include "GlobalStorage.h"
|
||||||
#include "JobQueue.h"
|
#include "JobQueue.h"
|
||||||
@ -35,6 +36,7 @@ CALAMARES_PLUGIN_FACTORY_DEFINITION( PackageChooserViewStepFactory, registerPlug
|
|||||||
PackageChooserViewStep::PackageChooserViewStep( QObject* parent )
|
PackageChooserViewStep::PackageChooserViewStep( QObject* parent )
|
||||||
: Calamares::ViewStep( parent )
|
: Calamares::ViewStep( parent )
|
||||||
, m_widget( nullptr )
|
, m_widget( nullptr )
|
||||||
|
, m_model( nullptr )
|
||||||
{
|
{
|
||||||
emit nextStatusChanged( false );
|
emit nextStatusChanged( false );
|
||||||
}
|
}
|
||||||
@ -46,6 +48,7 @@ PackageChooserViewStep::~PackageChooserViewStep()
|
|||||||
{
|
{
|
||||||
m_widget->deleteLater();
|
m_widget->deleteLater();
|
||||||
}
|
}
|
||||||
|
delete m_model;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -62,6 +65,10 @@ PackageChooserViewStep::widget()
|
|||||||
if ( !m_widget )
|
if ( !m_widget )
|
||||||
{
|
{
|
||||||
m_widget = new PackageChooserPage( nullptr );
|
m_widget = new PackageChooserPage( nullptr );
|
||||||
|
if ( m_model )
|
||||||
|
{
|
||||||
|
hookupModel();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return m_widget;
|
return m_widget;
|
||||||
}
|
}
|
||||||
@ -110,4 +117,32 @@ PackageChooserViewStep::jobs() const
|
|||||||
void
|
void
|
||||||
PackageChooserViewStep::setConfigurationMap( const QVariantMap& configurationMap )
|
PackageChooserViewStep::setConfigurationMap( const QVariantMap& configurationMap )
|
||||||
{
|
{
|
||||||
|
// TODO: use the configurationMap
|
||||||
|
|
||||||
|
if ( !m_model )
|
||||||
|
{
|
||||||
|
|
||||||
|
m_model = new PackageListModel( nullptr );
|
||||||
|
m_model->addPackage( PackageItem { "kde", "kde", "Plasma", "Plasma Desktop" } );
|
||||||
|
m_model->addPackage(
|
||||||
|
PackageItem { "gnome", "gnome", "GNOME", "GNU Networked Object Modeling Environment Desktop" } );
|
||||||
|
|
||||||
|
|
||||||
|
if ( m_widget )
|
||||||
|
{
|
||||||
|
hookupModel();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
PackageChooserViewStep::hookupModel()
|
||||||
|
{
|
||||||
|
if ( !m_model || !m_widget )
|
||||||
|
{
|
||||||
|
cError() << "Can't hook up model until widget and model both exist.";
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
m_widget->setModel( m_model );
|
||||||
}
|
}
|
||||||
|
@ -19,14 +19,17 @@
|
|||||||
#ifndef PACKAGECHOOSERVIEWSTEP_H
|
#ifndef PACKAGECHOOSERVIEWSTEP_H
|
||||||
#define PACKAGECHOOSERVIEWSTEP_H
|
#define PACKAGECHOOSERVIEWSTEP_H
|
||||||
|
|
||||||
#include <PluginDllMacro.h>
|
#include "PluginDllMacro.h"
|
||||||
#include <utils/PluginFactory.h>
|
#include "utils/PluginFactory.h"
|
||||||
#include <viewpages/ViewStep.h>
|
#include "viewpages/ViewStep.h"
|
||||||
|
|
||||||
#include <QObject>
|
#include <QObject>
|
||||||
#include <QUrl>
|
#include <QUrl>
|
||||||
#include <QVariantMap>
|
#include <QVariantMap>
|
||||||
|
|
||||||
|
class PackageChooserPage;
|
||||||
|
class PackageListModel;
|
||||||
|
|
||||||
class PLUGINDLLEXPORT PackageChooserViewStep : public Calamares::ViewStep
|
class PLUGINDLLEXPORT PackageChooserViewStep : public Calamares::ViewStep
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
@ -52,7 +55,10 @@ public:
|
|||||||
void setConfigurationMap( const QVariantMap& configurationMap ) override;
|
void setConfigurationMap( const QVariantMap& configurationMap ) override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
QWidget* m_widget;
|
void hookupModel();
|
||||||
|
|
||||||
|
PackageChooserPage* m_widget;
|
||||||
|
PackageListModel* m_model;
|
||||||
};
|
};
|
||||||
|
|
||||||
CALAMARES_PLUGIN_FACTORY_DECLARATION( PackageChooserViewStepFactory )
|
CALAMARES_PLUGIN_FACTORY_DECLARATION( PackageChooserViewStepFactory )
|
||||||
|
93
src/modules/packagechooser/PackageModel.cpp
Normal file
93
src/modules/packagechooser/PackageModel.cpp
Normal file
@ -0,0 +1,93 @@
|
|||||||
|
/* === This file is part of Calamares - <https://github.com/calamares> ===
|
||||||
|
*
|
||||||
|
* Copyright 2019, Adriaan de Groot <groot@kde.org>
|
||||||
|
*
|
||||||
|
* Calamares is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* Calamares 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 General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with Calamares. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "PackageModel.h"
|
||||||
|
|
||||||
|
#include "utils/Logger.h"
|
||||||
|
|
||||||
|
PackageItem
|
||||||
|
PackageItem::fromAppStream( const QString& filename )
|
||||||
|
{
|
||||||
|
// TODO: implement this
|
||||||
|
return PackageItem {};
|
||||||
|
}
|
||||||
|
|
||||||
|
PackageItem::PackageItem() {}
|
||||||
|
|
||||||
|
PackageItem::PackageItem( const QString& a_id,
|
||||||
|
const QString& a_package,
|
||||||
|
const QString& a_name,
|
||||||
|
const QString& a_description )
|
||||||
|
: id( a_id )
|
||||||
|
, package( a_package )
|
||||||
|
, name( a_name )
|
||||||
|
, description( a_description )
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
PackageListModel::PackageListModel( QObject* parent )
|
||||||
|
: QAbstractListModel( parent )
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
PackageListModel::PackageListModel( PackageList&& items, QObject* parent )
|
||||||
|
: QAbstractListModel( parent )
|
||||||
|
, m_packages( std::move( items ) )
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
PackageListModel::~PackageListModel() {}
|
||||||
|
|
||||||
|
void
|
||||||
|
PackageListModel::addPackage( PackageItem&& p )
|
||||||
|
{
|
||||||
|
int c = m_packages.count();
|
||||||
|
beginInsertRows( QModelIndex(), c, c );
|
||||||
|
m_packages.append( p );
|
||||||
|
endInsertRows();
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
PackageListModel::rowCount( const QModelIndex& index ) const
|
||||||
|
{
|
||||||
|
// For lists, valid indexes have zero children; only the root index has them
|
||||||
|
return index.isValid() ? 0 : m_packages.count();
|
||||||
|
}
|
||||||
|
|
||||||
|
QVariant
|
||||||
|
PackageListModel::data( const QModelIndex& index, int role ) const
|
||||||
|
{
|
||||||
|
cDebug() << "Data" << m_packages.count() << index.isValid() << ( index.isValid() ? index.row() : -1 );
|
||||||
|
if ( !index.isValid() )
|
||||||
|
{
|
||||||
|
return QVariant();
|
||||||
|
}
|
||||||
|
int row = index.row();
|
||||||
|
if ( row >= m_packages.count() || row < 0 )
|
||||||
|
{
|
||||||
|
return QVariant();
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( role == Qt::DisplayRole )
|
||||||
|
{
|
||||||
|
return m_packages[ row ].name;
|
||||||
|
}
|
||||||
|
|
||||||
|
return QVariant();
|
||||||
|
}
|
62
src/modules/packagechooser/PackageModel.h
Normal file
62
src/modules/packagechooser/PackageModel.h
Normal file
@ -0,0 +1,62 @@
|
|||||||
|
/* === This file is part of Calamares - <https://github.com/calamares> ===
|
||||||
|
*
|
||||||
|
* Copyright 2019, Adriaan de Groot <groot@kde.org>
|
||||||
|
*
|
||||||
|
* Calamares is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* Calamares 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 General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with Calamares. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef PACKAGEMODEL_H
|
||||||
|
#define PACKAGEMODEL_H
|
||||||
|
|
||||||
|
#include <QAbstractListModel>
|
||||||
|
#include <QObject>
|
||||||
|
#include <QVector>
|
||||||
|
|
||||||
|
struct PackageItem
|
||||||
|
{
|
||||||
|
QString id;
|
||||||
|
// TODO: may need more than one
|
||||||
|
QString package;
|
||||||
|
// TODO: name and description are localized
|
||||||
|
QString name;
|
||||||
|
QString description;
|
||||||
|
// TODO: may be more than one
|
||||||
|
// QPixmap screenshot;
|
||||||
|
|
||||||
|
PackageItem();
|
||||||
|
PackageItem( const QString& id, const QString& package, const QString& name, const QString& description );
|
||||||
|
|
||||||
|
// TODO: implement this
|
||||||
|
PackageItem fromAppStream( const QString& filename );
|
||||||
|
};
|
||||||
|
|
||||||
|
using PackageList = QVector< PackageItem >;
|
||||||
|
|
||||||
|
class PackageListModel : public QAbstractListModel
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
PackageListModel( PackageList&& items, QObject* parent );
|
||||||
|
PackageListModel( QObject* parent );
|
||||||
|
virtual ~PackageListModel();
|
||||||
|
|
||||||
|
void addPackage( PackageItem&& p );
|
||||||
|
|
||||||
|
int rowCount( const QModelIndex& index ) const override;
|
||||||
|
QVariant data( const QModelIndex& index, int role ) const override;
|
||||||
|
|
||||||
|
private:
|
||||||
|
PackageList m_packages;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif
|
Loading…
Reference in New Issue
Block a user