/* * Copyright 2016, Luca Giambonini * Copyright 2016, Lisa Vitolo * Copyright 2017, Kyle Robbertze * Copyright 2017, Adriaan de Groot * * 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 . */ #ifndef NETINSTALLPAGE_H #define NETINSTALLPAGE_H #include "PackageModel.h" #include "PackageTreeItem.h" #include "Typedefs.h" #include #include #include // required forward declarations class QByteArray; class QNetworkReply; class QString; namespace Ui { class Page_NetInst; } class NetInstallPage : public QWidget { Q_OBJECT public: NetInstallPage( QWidget* parent = nullptr ); void onActivate(); /** @brief Retrieves the groups, with name, description and packages * * Loads data from the given URL. This should be called before * displaying the page. */ void loadGroupList( const QString& url ); // Sets the "required" state of netinstall data. Influences whether // corrupt or unavailable data causes checkReady() to be emitted // true (not-required) or false. void setRequired( bool ); bool getRequired() const { return m_required; } // Returns the list of packages belonging to groups that are // selected in the view in this given moment. No data is cached here, so // this function does not have constant time. PackageModel::PackageItemDataList selectedPackages() const; public slots: void dataIsHere( QNetworkReply* ); signals: void checkReady( bool ); private: // Takes the YAML data representing the groups and reads them into the // m_groups and m_groupOrder internal structures. See the README.md // of this module to know the format expected of the YAML files. bool readGroups( const QByteArray& yamlData ); Ui::Page_NetInst* ui; // Handles connection with the remote URL storing the configuration. QNetworkAccessManager m_networkManager; PackageModel* m_groups; bool m_required; }; #endif // NETINSTALLPAGE_H