Skip to content
Snippets Groups Projects
ProfilePage.qml 5.43 KiB
Newer Older
Sébastien Blin's avatar
Sébastien Blin committed
/*
 * Copyright (C) 2020 by Savoir-faire Linux
 * Author: Yang Wang <yang.wang@savoirfairelinux.com>
 *
 * This program 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.
 *
 * This program 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 this program.  If not, see <https://www.gnu.org/licenses/>.
 */

import QtQuick 2.14
import QtQuick.Layouts 1.14
Sébastien Blin's avatar
Sébastien Blin committed
import QtQuick.Controls 2.14
Sébastien Blin's avatar
Sébastien Blin committed

import "../../commoncomponents"

Rectangle {
    id: root

    property string createdAccountId: ""
    property int preferredHeight: profilePageColumnLayout.implicitHeight
    property var showBottom: false
    property alias displayName: aliasEdit.text
    property bool isRdv: false
    property alias avatarBooth: setAvatarWidget
Sébastien Blin's avatar
Sébastien Blin committed
    function initializeOnShowUp() {
Sébastien Blin's avatar
Sébastien Blin committed
        clearAllTextFields()
        saveProfileBtn.spinnerTriggered = true
Sébastien Blin's avatar
Sébastien Blin committed
    }

    function clearAllTextFields() {
        aliasEdit.clear()
    }

    function readyToSaveDetails() {
        saveProfileBtn.spinnerTriggered = false
    }

Sébastien Blin's avatar
Sébastien Blin committed
    color: JamiTheme.backgroundColor

    onCreatedAccountIdChanged: {
        setAvatarWidget.setAvatarImage(AvatarImage.Mode.FromAccount,
                                       createdAccountId)
    }
Sébastien Blin's avatar
Sébastien Blin committed

    ColumnLayout {
        id: profilePageColumnLayout

        spacing: layoutSpacing
        width: parent.width
Sébastien Blin's avatar
Sébastien Blin committed
        anchors.horizontalCenter: parent.horizontalCenter
        anchors.verticalCenter: parent.verticalCenter

        RowLayout {
            spacing: layoutSpacing
            Layout.topMargin: backButtonMargins
Sébastien Blin's avatar
Sébastien Blin committed
            Layout.preferredWidth: saveProfileBtn.width
            Layout.alignment: Qt.AlignCenter
Sébastien Blin's avatar
Sébastien Blin committed

            Label {
                text: qsTr("Profile is only shared with contacts")
                color: JamiTheme.textColor
Sébastien Blin's avatar
Sébastien Blin committed
                font.pointSize: JamiTheme.textFontSize + 3
            }

            Label {
                Layout.alignment: Qt.AlignRight

Sébastien Blin's avatar
Sébastien Blin committed
                text: qsTr("Optional")
                color: JamiTheme.whiteColor
Sébastien Blin's avatar
Sébastien Blin committed
                padding: 8

                background: Rectangle {
                    color: JamiTheme.wizardBlueButtons
Sébastien Blin's avatar
Sébastien Blin committed
                    radius: 24
                    anchors.fill: parent
                }
            }
        }

        PhotoboothView {
            id: setAvatarWidget

            Layout.alignment: Qt.AlignCenter
            Layout.preferredWidth: size
            Layout.preferredHeight: size
            boothWidth: 200
Sébastien Blin's avatar
Sébastien Blin committed
        }

        MaterialLineEdit {
            id: aliasEdit

            property string lastInitialCharacter: ""

            Layout.preferredHeight: fieldLayoutHeight
            Layout.preferredWidth: fieldLayoutWidth
            Layout.alignment: Qt.AlignCenter

Sébastien Blin's avatar
Sébastien Blin committed
            selectByMouse: true
            placeholderText: isRdv ? JamiStrings.enterRVName : qsTr("Enter your name")
            font.pointSize: 9
Sébastien Blin's avatar
Sébastien Blin committed
            font.kerning: true

            borderColorMode: MaterialLineEdit.NORMAL

            fieldLayoutWidth: saveProfileBtn.width

            onTextEdited: {
                if (!(setAvatarWidget.avatarSet)) {
                    if (text.length === 0) {
                        setAvatarWidget.setAvatarImage(AvatarImage.Mode.FromAccount,
                                                       createdAccountId)
                        return
                    }

                    if (text.length == 1 && text.charAt(0) !== lastInitialCharacter) {
                        lastInitialCharacter = text.charAt(0)
                        setAvatarWidget.setAvatarImage(AvatarImage.Mode.FromTemporaryName,
                                                       text)
                    }
                }
            }
Sébastien Blin's avatar
Sébastien Blin committed
            id: saveProfileBtn

            Layout.alignment: Qt.AlignCenter
            Layout.preferredWidth: preferredWidth
            Layout.preferredHeight: preferredHeight

            normalText: JamiStrings.saveProfile
            spinnerTriggeredtext: root.isRdv ? JamiStrings.generatingRV : qsTr("Generating account…")
Sébastien Blin's avatar
Sébastien Blin committed
        }

        MaterialButton {
            Layout.alignment: Qt.AlignCenter
            Layout.preferredWidth: preferredWidth
            Layout.preferredHeight: preferredHeight

            text: JamiStrings.skip
Sébastien Blin's avatar
Sébastien Blin committed
            enabled: saveProfileBtn.enabled
            color: enabled? JamiTheme.buttonTintedGrey : JamiTheme.buttonTintedGreyInactive
            hoveredColor: JamiTheme.buttonTintedGreyHovered
            pressedColor: JamiTheme.buttonTintedGreyPressed
Sébastien Blin's avatar
Sébastien Blin committed
            outlined: true

            onClicked: {
                leavePage()
            }
        }

        AccountCreationStepIndicator {
            Layout.topMargin: backButtonMargins
            Layout.bottomMargin: backButtonMargins
            Layout.alignment: Qt.AlignHCenter
            spacing: layoutSpacing
            steps: 3
            currentStep: 3
        }