Skip to content
Snippets Groups Projects
ProfilePage.qml 5.39 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
import net.jami.Adapters 1.0
import net.jami.Helpers 1.0
Sébastien Blin's avatar
Sébastien Blin committed

import "../../commoncomponents"

Rectangle {
    id: root

    // trigger a default avatar prior to account generation
    property string createdAccountId: "dummy"
    property int preferredHeight: profilePageColumnLayout.implicitHeight
    property bool 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() {
        createdAccountId = "dummy"
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

    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
            onVisibleChanged: {
                if (visible)
                    LRCInstance.currentAccountAvatarSet = false
            }
Sébastien Blin's avatar
Sébastien Blin committed
        }

        MaterialLineEdit {
            id: aliasEdit

            property string lastFirstChar
            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
                if (LRCInstance.currentAccountAvatarSet)
                    return
                if (text.length === 0) {
                    lastFirstChar = ""
                    AccountAdapter.setCurrAccDisplayName(lastFirstChar)
                } else if (text.length == 1 && text.charAt(0) !== lastFirstChar) {
                    lastFirstChar = text.charAt(0)
                    AccountAdapter.setCurrAccDisplayName(lastFirstChar)
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: {
                AccountAdapter.setCurrentAccountAvatarBase64()
                aliasEdit.clear()
                saveProfile()
        AccountCreationStepIndicator {
            Layout.topMargin: backButtonMargins
            Layout.bottomMargin: backButtonMargins
            Layout.alignment: Qt.AlignHCenter
            spacing: layoutSpacing
            steps: 3
            currentStep: 3
        }