/* === This file is part of Calamares - === * * Copyright 2014-2015, Teo Mrnjavac * Copyright 2017-2018, Adriaan de Groot * * Portions from the Manjaro Installation Framework * by Roland Singer * Copyright (C) 2007 Free Software Foundation, Inc. * * 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 USERSPAGE_H #define USERSPAGE_H #include class Config; class QLabel; namespace Ui { class Page_UserSetup; } class UsersPage : public QWidget { Q_OBJECT public: explicit UsersPage( Config* config, QWidget* parent = nullptr ); virtual ~UsersPage(); bool isReady() const; void fillGlobalStorage() const; void onActivate(); protected slots: void onFullNameTextEdited( const QString& ); void reportLoginNameStatus( const QString& ); void reportHostNameStatus( const QString& ); void onPasswordTextChanged( const QString& ); void onRootPasswordTextChanged( const QString& ); void onReuseUserPasswordChanged( const int ); signals: void checkReady( bool ); private: /// @brief Which password are we talking about? (for checkPasswordAcceptance()) enum class Password { Root, User }; /** @brief Is the password acceptable? * * Checks the two copies of the password and places error messages in the * given QLabels. Returns true (and clears the error messages) if the * password is acceptable. */ bool checkPasswordAcceptance( Password p, QLabel* badge, QLabel* message ); void retranslate(); Ui::Page_UserSetup* ui; Config* m_config; bool m_readyFullName; bool m_readyUsername; bool m_readyHostname; bool m_readyPassword; bool m_readyRootPassword; }; #endif // USERSPAGE_H