diff --git a/CMakeLists.txt b/CMakeLists.txt
index 74f62c770267513da1af85d2b2d440cd0bcf0ca5..750cf57e19fb7d6981e5c4fc9a6af33974853195 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -27,7 +27,7 @@ include( MacroLogFeature )
 
 set( QT_VERSION 5.3.0 )
 
-find_package( Qt5 ${QT_VERSION} CONFIG REQUIRED Core Gui Widgets LinguistTools )
+find_package( Qt5 ${QT_VERSION} CONFIG REQUIRED Core Gui Widgets LinguistTools Svg )
 find_package( YamlCpp 0.5.1 REQUIRED )
 
 option( WITH_PYTHON "Enable Python modules support." ON )
diff --git a/CalamaresAddLibrary.cmake b/CalamaresAddLibrary.cmake
index 050c08a5d275fcc9c84dadcc9eae1e458a15da8e..a774b1f31753e4300c4e5cce29b34c78b8026101 100644
--- a/CalamaresAddLibrary.cmake
+++ b/CalamaresAddLibrary.cmake
@@ -4,7 +4,7 @@ function(calamares_add_library)
     # parse arguments (name needs to be saved before passing ARGN into the macro)
     set(NAME ${ARGV0})
     set(options NO_INSTALL NO_VERSION)
-    set(oneValueArgs NAME TYPE EXPORT_MACRO TARGET TARGET_TYPE EXPORT VERSION SOVERSION INSTALL_BINDIR)
+    set(oneValueArgs NAME TYPE EXPORT_MACRO TARGET TARGET_TYPE EXPORT VERSION SOVERSION INSTALL_BINDIR RESOURCES)
     set(multiValueArgs SOURCES UI LINK_LIBRARIES LINK_PRIVATE_LIBRARIES COMPILE_DEFINITIONS QT5_MODULES)
     cmake_parse_arguments(LIBRARY "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN})
     set(LIBRARY_NAME ${NAME})
@@ -30,8 +30,8 @@ function(calamares_add_library)
     endif()
 
     # add resources from current dir
-    if(EXISTS "${CMAKE_CURRENT_LIST_DIR}/resources.qrc")
-        qt5_add_resources(LIBRARY_RC_SOURCES "resources.qrc")
+    if(EXISTS "${CMAKE_CURRENT_LIST_DIR}/${LIBRARY_RESOURCES}")
+        qt5_add_resources(LIBRARY_RC_SOURCES "${LIBRARY_RESOURCES}")
         list(APPEND LIBRARY_SOURCES ${LIBRARY_RC_SOURCES})
         unset(LIBRARY_RC_SOURCES)
     endif()
diff --git a/CalamaresAddPlugin.cmake b/CalamaresAddPlugin.cmake
index 63e63d009eaafffb078805f1176d37ed38c95970..e9d5607c9f21c4aa466cefd1fb416205265c495c 100644
--- a/CalamaresAddPlugin.cmake
+++ b/CalamaresAddPlugin.cmake
@@ -5,7 +5,7 @@ function( calamares_add_plugin )
     # parse arguments ( name needs to be saved before passing ARGN into the macro )
     set( NAME ${ARGV0} )
     set( options NO_INSTALL SHARED_LIB )
-    set( oneValueArgs NAME TYPE EXPORT_MACRO )
+    set( oneValueArgs NAME TYPE EXPORT_MACRO RESOURCES )
     set( multiValueArgs SOURCES UI LINK_LIBRARIES COMPILE_DEFINITIONS )
     cmake_parse_arguments( PLUGIN "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN} )
     set( PLUGIN_NAME ${NAME} )
@@ -30,6 +30,9 @@ function( calamares_add_plugin )
         if( EXISTS "${CMAKE_CURRENT_SOURCE_DIR}/${PLUGIN_CONFIG_FILE}" )
             message( "   ${Green}CONFIGURATION_FILE:${ColorReset} ${PLUGIN_CONFIG_FILE} => ${PLUGIN_DATA_DESTINATION}" )
         endif()
+        if( PLUGIN_RESOURCES )
+            message( "   ${Green}RESOURCES:${ColorReset} ${PLUGIN_RESOURCES}" )
+        endif()
         message( "" )
     endif()
     # create target name once for convenience
@@ -65,6 +68,10 @@ function( calamares_add_plugin )
 
     list( APPEND calamares_add_library_args "INSTALL_BINDIR" "${PLUGIN_DESTINATION}" )
 
+    if( PLUGIN_RESOURCES )
+        list( APPEND calamares_add_library_args "RESOURCES" "${PLUGIN_RESOURCES}" )
+    endif()
+
     calamares_add_library( ${calamares_add_library_args} )
 
     configure_file( ${PLUGIN_DESC_FILE} ${PLUGIN_DESC_FILE} COPYONLY )
diff --git a/data/images/no.svgz b/data/images/no.svgz
new file mode 100644
index 0000000000000000000000000000000000000000..423fdaca7fddc8afc7e2b69a18fefbc2963bc1d5
Binary files /dev/null and b/data/images/no.svgz differ
diff --git a/images/squid.png b/data/images/squid.png
similarity index 100%
rename from images/squid.png
rename to data/images/squid.png
diff --git a/images/squid.svg b/data/images/squid.svg
similarity index 100%
rename from images/squid.svg
rename to data/images/squid.svg
diff --git a/data/images/yes.svgz b/data/images/yes.svgz
new file mode 100644
index 0000000000000000000000000000000000000000..a4a8f6c8460700aa47e0c980d2534d8439c024a1
Binary files /dev/null and b/data/images/yes.svgz differ
diff --git a/src/libcalamares/utils/CalamaresUtils.h b/src/libcalamares/utils/CalamaresUtils.h
index c0839f96fe0aca741679b5dd89c7583c2ac8178a..915b4c2a662a70cedf2b8a5bb229eaf6667b1e33 100644
--- a/src/libcalamares/utils/CalamaresUtils.h
+++ b/src/libcalamares/utils/CalamaresUtils.h
@@ -26,6 +26,8 @@
 
 #include "DllMacro.h"
 
+#define RESPATH ":/data/"
+
 class QDir;
 class QObject;
 
diff --git a/src/libcalamaresui/CMakeLists.txt b/src/libcalamaresui/CMakeLists.txt
index 6ded069b0f1b8b11787f68f00b42ac41e1e0fff5..357ee971277c06791676b71f6a07e6f38c1eafb4 100644
--- a/src/libcalamaresui/CMakeLists.txt
+++ b/src/libcalamaresui/CMakeLists.txt
@@ -7,6 +7,7 @@ list( APPEND ${CALAMARESUI_LIBRARY_TARGET}_SOURCES
     modulesystem/ViewModule.cpp
 
     utils/CalamaresUtilsGui.cpp
+    utils/ImageRegistry.cpp
     utils/YamlUtils.cpp
 
     viewpages/AbstractPage.cpp
@@ -35,6 +36,8 @@ calamares_add_library( ${CALAMARESUI_LIBRARY_TARGET}
     EXPORT_MACRO UIDLLEXPORT_PRO
     LINK_LIBRARIES
         yaml-cpp
+        Qt5::Svg
+    RESOURCES libcalamaresui.qrc
     EXPORT CalamaresLibraryDepends
     VERSION ${CALAMARES_VERSION_SHORT}
 )
diff --git a/src/libcalamaresui/libcalamaresui.qrc b/src/libcalamaresui/libcalamaresui.qrc
new file mode 100644
index 0000000000000000000000000000000000000000..4bea23aeb4abe4aba4d03a237f1d9d90f906c263
--- /dev/null
+++ b/src/libcalamaresui/libcalamaresui.qrc
@@ -0,0 +1,6 @@
+<RCC>
+    <qresource prefix="/data">
+        <file alias="images/yes.svgz">../../data/images/yes.svgz</file>
+        <file alias="images/no.svgz">../../data/images/no.svgz</file>
+    </qresource>
+</RCC>
diff --git a/src/libcalamaresui/utils/CalamaresUtilsGui.cpp b/src/libcalamaresui/utils/CalamaresUtilsGui.cpp
index e43dc966c06c3d752e4a266d65d482d086084bfb..747460261ef3feed31611d343540d596f3b3dcd9 100644
--- a/src/libcalamaresui/utils/CalamaresUtilsGui.cpp
+++ b/src/libcalamaresui/utils/CalamaresUtilsGui.cpp
@@ -18,9 +18,14 @@
 
 #include "CalamaresUtilsGui.h"
 
+#include "ImageRegistry.h"
+
+#include <QBrush>
 #include <QFont>
 #include <QFontMetrics>
 #include <QLayout>
+#include <QPainter>
+#include <QPen>
 
 namespace CalamaresUtils
 {
@@ -29,6 +34,84 @@ static int s_defaultFontSize   = 0;
 static int s_defaultFontHeight = 0;
 
 
+
+QPixmap
+defaultPixmap( ImageType type, ImageMode mode, const QSize& size )
+{
+    QPixmap pixmap;
+
+    switch ( type )
+    {
+        case Yes:
+            pixmap = ImageRegistry::instance()->pixmap( RESPATH "images/yes.svgz", size );
+            break;
+
+        case No:
+            pixmap = ImageRegistry::instance()->pixmap( RESPATH "images/no.svgz", size );
+            break;
+
+        default:
+            break;
+    }
+
+    if ( pixmap.isNull() )
+    {
+        Q_ASSERT( false );
+        return QPixmap();
+    }
+
+    return pixmap;
+}
+
+
+QPixmap
+createRoundedImage( const QPixmap& pixmap, const QSize& size, float frameWidthPct )
+{
+    int height;
+    int width;
+
+    if ( !size.isEmpty() )
+    {
+        height = size.height();
+        width = size.width();
+    }
+    else
+    {
+        height = pixmap.height();
+        width = pixmap.width();
+    }
+
+    if ( !height || !width )
+        return QPixmap();
+
+    QPixmap scaledAvatar = pixmap.scaled( width, height, Qt::IgnoreAspectRatio, Qt::SmoothTransformation );
+    if ( frameWidthPct == 0.00 )
+        return scaledAvatar;
+
+    QPixmap frame( width, height );
+    frame.fill( Qt::transparent );
+
+    QPainter painter( &frame );
+    painter.setRenderHint( QPainter::Antialiasing );
+
+    QRect outerRect( 0, 0, width, height );
+    QBrush brush( scaledAvatar );
+    QPen pen;
+    pen.setColor( Qt::transparent );
+    pen.setJoinStyle( Qt::RoundJoin );
+
+    painter.setBrush( brush );
+    painter.setPen( pen );
+    painter.drawRoundedRect( outerRect, frameWidthPct * 100.0, frameWidthPct * 100.0, Qt::RelativeSize );
+
+/*    painter.setBrush( Qt::transparent );
+    painter.setPen( Qt::white );
+    painter.drawRoundedRect( outerRect, frameWidthPct, frameWidthPct, Qt::RelativeSize ); */
+
+    return frame;
+}
+
+
 void
 unmarginLayout( QLayout* layout )
 {
diff --git a/src/libcalamaresui/utils/CalamaresUtilsGui.h b/src/libcalamaresui/utils/CalamaresUtilsGui.h
index c835ddbf7aaefb86ea0313d4633a1dc8aebaf175..1a52bf305856d589fe6d5d848bbd3ecab52d6014 100644
--- a/src/libcalamaresui/utils/CalamaresUtilsGui.h
+++ b/src/libcalamaresui/utils/CalamaresUtilsGui.h
@@ -22,19 +22,37 @@
 #include "utils/CalamaresUtils.h"
 #include "UiDllMacro.h"
 
+#include <QPixmap>
 #include <QSize>
 
 class QLayout;
 
 namespace CalamaresUtils
 {
+enum ImageType
+{
+    Yes,
+    No
+};
+
+enum ImageMode
+{
+    Original,
+    CoverInCase,
+    Grid,
+    DropShadow,
+    RoundedCorners
+};
+
+UIDLLEXPORT QPixmap defaultPixmap( ImageType type, ImageMode mode = CalamaresUtils::Original, const QSize& size = QSize( 0, 0 ) );
+UIDLLEXPORT QPixmap createRoundedImage( const QPixmap& avatar, const QSize& size, float frameWidthPct = 0.20 );
 
 UIDLLEXPORT void unmarginLayout( QLayout* layout );
 
-DLLEXPORT void setDefaultFontSize( int points );
-DLLEXPORT int defaultFontSize();
-DLLEXPORT int defaultFontHeight();
-DLLEXPORT QSize defaultIconSize();
+UIDLLEXPORT void setDefaultFontSize( int points );
+UIDLLEXPORT int defaultFontSize();
+UIDLLEXPORT int defaultFontHeight();
+UIDLLEXPORT QSize defaultIconSize();
 
 }
 
diff --git a/src/libcalamaresui/utils/ImageRegistry.cpp b/src/libcalamaresui/utils/ImageRegistry.cpp
new file mode 100644
index 0000000000000000000000000000000000000000..48f5ea86764d6adfaa1eaed0d2a42ce5a4e7380e
--- /dev/null
+++ b/src/libcalamaresui/utils/ImageRegistry.cpp
@@ -0,0 +1,163 @@
+/* === This file is part of Calamares - <http://github.com/calamares> ===
+ *
+ *   Copyright 2014, Teo Mrnjavac <teo@kde.org>
+ *
+ *   Originally from Tomahawk,
+ *   Copyright 2012, Christian Muehlhaeuser <muesli@tomahawk-player.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 "ImageRegistry.h"
+
+#include <QSvgRenderer>
+#include <QPainter>
+#include <QIcon>
+
+#include "utils/Logger.h"
+
+static QHash< QString, QHash< int, QHash< qint64, QPixmap > > > s_cache;
+ImageRegistry* ImageRegistry::s_instance = 0;
+
+
+ImageRegistry*
+ImageRegistry::instance()
+{
+    return s_instance;
+}
+
+
+ImageRegistry::ImageRegistry()
+{
+    s_instance = this;
+}
+
+
+QIcon
+ImageRegistry::icon( const QString& image, CalamaresUtils::ImageMode mode )
+{
+    return pixmap( image, CalamaresUtils::defaultIconSize(), mode );
+}
+
+
+qint64
+ImageRegistry::cacheKey( const QSize& size, float opacity, QColor tint )
+{
+    return size.width() * 100 + size.height() * 10 + ( opacity * 100.0 ) + tint.value();
+}
+
+
+QPixmap
+ImageRegistry::pixmap( const QString& image, const QSize& size, CalamaresUtils::ImageMode mode, float opacity, QColor tint )
+{
+    QHash< qint64, QPixmap > subsubcache;
+    QHash< int, QHash< qint64, QPixmap > > subcache;
+
+    if ( s_cache.contains( image ) )
+    {
+        subcache = s_cache.value( image );
+
+        if ( subcache.contains( mode ) )
+        {
+            subsubcache = subcache.value( mode );
+
+            const qint64 ck = cacheKey( size, opacity, tint );
+            if ( subsubcache.contains( ck ) )
+            {
+                return subsubcache.value( ck );
+            }
+        }
+    }
+
+    // Image not found in cache. Let's load it.
+    QPixmap pixmap;
+    if ( image.toLower().endsWith( ".svg" ) ||
+         image.toLower().endsWith( ".svgz" ) )
+    {
+        QSvgRenderer svgRenderer( image );
+        QPixmap p( size.isNull() ? svgRenderer.defaultSize() : size );
+        p.fill( Qt::transparent );
+
+        QPainter pixPainter( &p );
+        pixPainter.setOpacity( opacity );
+        svgRenderer.render( &pixPainter );
+        pixPainter.end();
+
+        if ( tint.alpha() > 0 )
+        {
+            QImage resultImage( p.size(), QImage::Format_ARGB32_Premultiplied );
+            QPainter painter( &resultImage );
+            painter.drawPixmap( 0, 0, p );
+            painter.setCompositionMode( QPainter::CompositionMode_Screen );
+            painter.fillRect( resultImage.rect(), tint );
+            painter.end();
+
+            resultImage.setAlphaChannel( p.toImage().alphaChannel() );
+            p = QPixmap::fromImage( resultImage );
+        }
+
+        pixmap = p;
+    }
+    else
+        pixmap = QPixmap( image );
+
+    if ( !pixmap.isNull() )
+    {
+        switch ( mode )
+        {
+            case CalamaresUtils::RoundedCorners:
+                pixmap = CalamaresUtils::createRoundedImage( pixmap, size );
+                break;
+
+            default:
+                break;
+        }
+
+        if ( !size.isNull() && pixmap.size() != size )
+            pixmap = pixmap.scaled( size, Qt::IgnoreAspectRatio, Qt::SmoothTransformation );
+
+        putInCache( image, size, mode, opacity, pixmap, tint );
+    }
+
+    return pixmap;
+}
+
+
+void
+ImageRegistry::putInCache( const QString& image, const QSize& size, CalamaresUtils::ImageMode mode, float opacity, const QPixmap& pixmap, QColor tint )
+{
+    cDebug( LOGVERBOSE ) << Q_FUNC_INFO << "Adding to image cache:" << image << size << mode;
+
+    QHash< qint64, QPixmap > subsubcache;
+    QHash< int, QHash< qint64, QPixmap > > subcache;
+
+    if ( s_cache.contains( image ) )
+    {
+        subcache = s_cache.value( image );
+
+        if ( subcache.contains( mode ) )
+        {
+            subsubcache = subcache.value( mode );
+
+/*            if ( subsubcache.contains( size.width() * size.height() ) )
+            {
+                Q_ASSERT( false );
+            }*/
+        }
+    }
+
+    subsubcache.insert( cacheKey( size, opacity, tint ), pixmap );
+    subcache.insert( mode, subsubcache );
+    s_cache.insert( image, subcache );
+}
diff --git a/src/libcalamaresui/utils/ImageRegistry.h b/src/libcalamaresui/utils/ImageRegistry.h
new file mode 100644
index 0000000000000000000000000000000000000000..41ed2d6ac870854de9e459d3f9f52dc246eee6ff
--- /dev/null
+++ b/src/libcalamaresui/utils/ImageRegistry.h
@@ -0,0 +1,47 @@
+/* === This file is part of Calamares - <http://github.com/calamares> ===
+ *
+ *   Copyright 2014, Teo Mrnjavac <teo@kde.org>
+ *
+ *   Originally from Tomahawk,
+ *   Copyright 2012, Christian Muehlhaeuser <muesli@tomahawk-player.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 IMAGE_REGISTRY_H
+#define IMAGE_REGISTRY_H
+
+#include <QPixmap>
+
+#include "utils/CalamaresUtilsGui.h"
+#include "UiDllMacro.h"
+
+class UIDLLEXPORT ImageRegistry
+{
+public:
+    static ImageRegistry* instance();
+
+    explicit ImageRegistry();
+
+    QIcon icon( const QString& image, CalamaresUtils::ImageMode mode = CalamaresUtils::Original );
+    QPixmap pixmap( const QString& image, const QSize& size, CalamaresUtils::ImageMode mode = CalamaresUtils::Original, float opacity = 1.0, QColor tint = QColor( 0, 0, 0, 0 ) );
+
+private:
+    qint64 cacheKey( const QSize& size, float opacity, QColor tint );
+    void putInCache( const QString& image, const QSize& size, CalamaresUtils::ImageMode mode, float opacity, const QPixmap& pixmap, QColor tint );
+
+    static ImageRegistry* s_instance;
+};
+
+#endif // IMAGE_REGISTRY_H
diff --git a/src/modules/keyboard/CMakeLists.txt b/src/modules/keyboard/CMakeLists.txt
index fdfc6695e4e8a0dcc6fca49f3bf9769a93593323..99405c99f61fa44f6ab90c42ed39f98b1f6f12d3 100644
--- a/src/modules/keyboard/CMakeLists.txt
+++ b/src/modules/keyboard/CMakeLists.txt
@@ -10,6 +10,8 @@ calamares_add_plugin( keyboard
         keyboardwidget/keyboardpreview.cpp
     UI
         KeyboardPage.ui
+    RESOURCES
+        keyboard.qrc
     LINK_LIBRARIES
         calamaresui
     SHARED_LIB
diff --git a/src/modules/keyboard/resources.qrc b/src/modules/keyboard/keyboard.qrc
similarity index 100%
rename from src/modules/keyboard/resources.qrc
rename to src/modules/keyboard/keyboard.qrc
diff --git a/src/modules/locale/CMakeLists.txt b/src/modules/locale/CMakeLists.txt
index 3fa6c00ce0d5e032b59cedb3fd06fbd357f31858..1a00821595f456988bd111a8ac8caf0223fcdb2a 100644
--- a/src/modules/locale/CMakeLists.txt
+++ b/src/modules/locale/CMakeLists.txt
@@ -10,6 +10,8 @@ calamares_add_plugin( locale
         timezonewidget/timezonewidget.cpp
         timezonewidget/localeglobal.cpp
     UI
+    RESOURCES
+        locale.qrc
     LINK_LIBRARIES
         calamaresui
     SHARED_LIB
diff --git a/src/modules/locale/resources.qrc b/src/modules/locale/locale.qrc
similarity index 100%
rename from src/modules/locale/resources.qrc
rename to src/modules/locale/locale.qrc
diff --git a/src/modules/prepare/CMakeLists.txt b/src/modules/prepare/CMakeLists.txt
index b89b26eda154cc19027d0ea6f2f807a6501b52b0..c9bad01818530dcd35f374411acfff9853c05f7b 100644
--- a/src/modules/prepare/CMakeLists.txt
+++ b/src/modules/prepare/CMakeLists.txt
@@ -9,8 +9,9 @@ calamares_add_plugin( prepare
     TYPE viewmodule
     EXPORT_MACRO PLUGINDLLEXPORT_PRO
     SOURCES
-        PrepareViewStep.cpp
+        PrepareCheckWidget.cpp
         PreparePage.cpp
+        PrepareViewStep.cpp
         partman_devices.c
     UI
     LINK_LIBRARIES
diff --git a/src/modules/prepare/PrepareCheckWidget.cpp b/src/modules/prepare/PrepareCheckWidget.cpp
new file mode 100644
index 0000000000000000000000000000000000000000..59686241f475875734880bbfa6a618d5900b2887
--- /dev/null
+++ b/src/modules/prepare/PrepareCheckWidget.cpp
@@ -0,0 +1,50 @@
+/* === This file is part of Calamares - <http://github.com/calamares> ===
+ *
+ *   Copyright 2014, Teo Mrnjavac <teo@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 "PrepareCheckWidget.h"
+
+#include "utils/CalamaresUtilsGui.h"
+#include "utils/Logger.h"
+
+#include <QBoxLayout>
+
+PrepareCheckWidget::PrepareCheckWidget( const QString &text,
+                                        bool checked,
+                                        QWidget* parent )
+    : QWidget( parent )
+{
+    QBoxLayout* mainLayout = new QHBoxLayout;
+    setLayout( mainLayout );
+
+    m_iconLabel = new QLabel( this );
+    mainLayout->addWidget( m_iconLabel );
+    m_textLabel = new QLabel( text, this );
+    mainLayout->addWidget( m_textLabel );
+    m_textLabel->setSizePolicy( QSizePolicy::Expanding, QSizePolicy::Preferred );
+
+    if ( checked )
+        m_iconLabel->setPixmap( CalamaresUtils::defaultPixmap( CalamaresUtils::Yes,
+                                                               CalamaresUtils::Original,
+                                                               QSize( m_iconLabel->height(),
+                                                                      m_iconLabel->height() ) ) );
+    else
+        m_iconLabel->setPixmap( CalamaresUtils::defaultPixmap( CalamaresUtils::No,
+                                                               CalamaresUtils::Original,
+                                                               QSize( m_iconLabel->height(),
+                                                                      m_iconLabel->height() ) ) );
+}
diff --git a/src/modules/prepare/PrepareCheckWidget.h b/src/modules/prepare/PrepareCheckWidget.h
new file mode 100644
index 0000000000000000000000000000000000000000..43efad018acf088da5bae8d43a94e59b8330b383
--- /dev/null
+++ b/src/modules/prepare/PrepareCheckWidget.h
@@ -0,0 +1,36 @@
+/* === This file is part of Calamares - <http://github.com/calamares> ===
+ *
+ *   Copyright 2014, Teo Mrnjavac <teo@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 PREPARECHECKWIDGET_H
+#define PREPARECHECKWIDGET_H
+
+#include <QLabel>
+
+class PrepareCheckWidget : public QWidget
+{
+    Q_OBJECT
+public:
+    explicit PrepareCheckWidget( const QString &text,
+                                 bool checked,
+                                 QWidget* parent = nullptr );
+private:
+    QLabel* m_textLabel;
+    QLabel* m_iconLabel;
+};
+
+#endif // PREPARECHECKWIDGET_H
diff --git a/src/modules/prepare/PreparePage.cpp b/src/modules/prepare/PreparePage.cpp
index 46f7445fa71761b7e96201ca949dfd3e678095a1..5219113773f3a417883576b6d8fc6bde48a63b92 100644
--- a/src/modules/prepare/PreparePage.cpp
+++ b/src/modules/prepare/PreparePage.cpp
@@ -18,6 +18,10 @@
 
 #include "PreparePage.h"
 
+#include "PrepareCheckWidget.h"
+
+#include "utils/CalamaresUtilsGui.h"
+
 #include <QBoxLayout>
 #include <QLabel>
 
@@ -30,16 +34,25 @@ PreparePage::PreparePage( QWidget* parent )
 
     QLabel* text = new QLabel( tr( "For best results, please ensure that this "
                                    "computer:" ), this );
-    text->setAlignment( Qt::AlignCenter );
 
-    mainLayout->addStretch();
     mainLayout->addWidget( text );
+    QHBoxLayout* spacerLayout = new QHBoxLayout;
+    mainLayout->addLayout( spacerLayout );
+    spacerLayout->addSpacing( CalamaresUtils::defaultFontHeight() * 2 );
+    m_entriesLayout = new QVBoxLayout;
+    spacerLayout->addLayout( m_entriesLayout );
+    CalamaresUtils::unmarginLayout( spacerLayout );
     mainLayout->addStretch();
 }
 
 
 void
-PreparePage::init()
+PreparePage::init( const QList< QPair< QString, bool > > &checkEntries )
 {
-
+    for ( const QPair< QString, bool >& entry : checkEntries )
+    {
+        PrepareCheckWidget* pcw = new PrepareCheckWidget( entry.first, entry.second );
+        m_entriesLayout->addWidget( pcw );
+        pcw->setSizePolicy( QSizePolicy::Expanding, QSizePolicy::Preferred );
+    }
 }
diff --git a/src/modules/prepare/PreparePage.h b/src/modules/prepare/PreparePage.h
index 6ee64c49a5b11cfdf514d91191cb099e20e68bd2..3230656d9f0416b5e7bd317bd1c8fa76876b661f 100644
--- a/src/modules/prepare/PreparePage.h
+++ b/src/modules/prepare/PreparePage.h
@@ -19,6 +19,7 @@
 #ifndef PREPAREPAGE_H
 #define PREPAREPAGE_H
 
+#include <QBoxLayout>
 #include <QWidget>
 
 class PreparePage : public QWidget
@@ -27,8 +28,10 @@ class PreparePage : public QWidget
 public:
     explicit PreparePage( QWidget* parent = nullptr );
 
-    void init();
+    void init( const QList< QPair< QString, bool > >& checkEntries );
 
+private:
+    QBoxLayout* m_entriesLayout;
 };
 
 #endif // PREPAREPAGE_H
diff --git a/src/modules/prepare/PrepareViewStep.cpp b/src/modules/prepare/PrepareViewStep.cpp
index 174c4b9e17cd5de3545b7fe63454fd9967d3459b..f49d3c0bb62f21bc92df62e6637efa4e0cabd298 100644
--- a/src/modules/prepare/PrepareViewStep.cpp
+++ b/src/modules/prepare/PrepareViewStep.cpp
@@ -97,7 +97,23 @@ PrepareViewStep::PrepareViewStep( QObject* parent )
         cDebug() << "enoughStorage, enoughRam, hasPower, hasInternet: "
                  << enoughStorage << enoughRam << hasPower << hasInternet;
 
-        m_actualWidget->init();
+        QList< QPair< QString, bool > > checkEntries;
+        checkEntries.append( qMakePair(
+            tr( "has at least %1 GB available drive space" )
+                .arg( m_requiredStorageGB ),
+            enoughStorage ) );
+        checkEntries.append( qMakePair(
+            tr( "has at least %1 GB working memory" )
+                .arg( m_requiredRamGB ),
+            enoughRam ) );
+        checkEntries.append( qMakePair(
+            tr( "is plugged in to a power source" ),
+            hasPower ) );
+        checkEntries.append( qMakePair(
+            tr( "is connected to the Internet" ),
+            hasInternet ) );
+
+        m_actualWidget->init( checkEntries );
         m_widget->layout()->removeWidget( waitingWidget );
         waitingWidget->deleteLater();
         m_widget->layout()->addWidget( m_actualWidget );
diff --git a/src/modules/users/CMakeLists.txt b/src/modules/users/CMakeLists.txt
index 4905ccf948bb1f0fd20e1b706b92b39d3dfcd799..4d4ef208fe8e40a5467e834e6f93308baa262f1a 100644
--- a/src/modules/users/CMakeLists.txt
+++ b/src/modules/users/CMakeLists.txt
@@ -13,6 +13,8 @@ calamares_add_plugin( users
         UsersPage.cpp
     UI
         page_usersetup.ui
+    RESOURCES
+        users.qrc
     LINK_LIBRARIES
         calamaresui
         ${CRYPT_LIBRARIES}
diff --git a/src/modules/users/resources.qrc b/src/modules/users/users.qrc
similarity index 100%
rename from src/modules/users/resources.qrc
rename to src/modules/users/users.qrc