import QtQuick 2.15 import QtQuick.Controls 2.15 import QtQuick.Layouts 1.15 import QtGraphicalEffects 1.15 Flickable { property bool doesntEmbed: Qt.platform.os === "android" || Qt.platform.os === "linux" || Qt.platform.os === "osx" || Qt.platform.os === "unix" || Qt.platform.os === "windows" contentHeight: main.height FontLoader { id: bold source: "Roboto/Roboto-Bold.ttf" } FontLoader { id: regular source: "Roboto/Roboto-Regular.ttf" } ColumnLayout { id: main anchors { top: parent.top left: parent.left right: parent.right } RowLayout { ColumnLayout { Layout.leftMargin: 15 Layout.rightMargin: 15 Rectangle { Layout.fillWidth: true implicitHeight: editProfile.height radius: 8 border { width: 1 color: "#1a000000" } ColumnLayout { id: editProfile anchors { left: parent.left right: parent.right } Label { id: cardHeader Layout.fillWidth: true text: qsTr("Edit Profile") padding: 16 font { family: doesntEmbed ? "Roboto" : bold.name weight: Font .Bold pointSize: 23 } } Rectangle { Layout.fillWidth: true height: 1 border { width: .5 color: "#0a000000" } } ColumnLayout { Layout.topMargin: 16 Layout.leftMargin: 20 Layout.rightMargin: 20 Layout.bottomMargin: 16 Label { Layout.fillWidth: true Layout.bottomMargin: 8 text: qsTr("Profile picture") color: "#747579" font { family: doesntEmbed ? "Roboto" : regular.name pointSize: 15 } } RowLayout { Image { id: avatar Layout.rightMargin: 25.6 source: "https://eduport.webestica.com/assets/images/avatar/07.jpg" sourceSize { width: 82 height: 82 } layer.enabled: true layer.effect: OpacityMask { maskSource: Rectangle { width: 82 height: 82 radius: 82 } } } Button { id: uploadButton horizontalPadding: 16 verticalPadding: 8 contentItem: Text { color: uploadButton.down ? "#ffffff" : "#066ac9" text: qsTr("Change") horizontalAlignment: Text .AlignHCenter verticalAlignment: Text .AlignVCenter font { family: doesntEmbed ? "Roboto" : regular.name pointSize: 15 } } background: Rectangle { radius: 5.2 color: uploadButton.down ? "#066ac9" : Qt.rgba(.0235, .416, .788, .1) border { color: uploadButton.down ? "#066ac9" : "transparent" width: 1 } } } } } ColumnLayout { Layout.topMargin: 16 Layout.leftMargin: 20 Layout.rightMargin: 20 Layout.bottomMargin: 16 Label { Layout.fillWidth: true Layout.bottomMargin: 8 text: qsTr("Full name") color: "#747579" font { family: doesntEmbed ? "Roboto" : regular.name pointSize: 15 } } Rectangle { Layout.fillWidth: true implicitHeight: firstName.height radius: 5.2 border { width: 1 color: "#dde0e3" } TextField { id: firstName text: "Lori" placeholderText: qsTr("First name") width: parent.width / 2 anchors.left: parent.left background: Rectangle { color: "transparent" } } Rectangle { width: 1 height: firstName.height anchors.horizontalCenter: parent.horizontalCenter border { width: .5 color: "#88dde0e3" } } TextField { id: lastName text: "Stevens" placeholderText: qsTr("Last name") width: parent.width / 2 anchors.right: parent.right background: Rectangle { color: "transparent" } } } } ColumnLayout { Layout.topMargin: 16 Layout.leftMargin: 20 Layout.rightMargin: 20 Layout.bottomMargin: 16 Label { Layout.fillWidth: true Layout.bottomMargin: 8 text: qsTr("Username") color: "#747579" font { family: doesntEmbed ? "Roboto" : regular.name pointSize: 15 } } Rectangle { Layout.fillWidth: true implicitHeight: userName.height radius: 5.2 border { width: 1 color: "#dde0e3" } Label { id: domainName text: "Eduport.com" height: userName.height width: parent.width / 2 anchors.left: parent.left verticalAlignment: Text.AlignVCenter topPadding: 6 leftPadding: 12 rightPadding: 12 bottomPadding: 6 background: Rectangle { color: "#e9ecef" } font { family: doesntEmbed ? "Roboto" : regular.name pointSize: 15 } } Rectangle { width: 1 height: userName.height anchors.horizontalCenter: parent.horizontalCenter border { width: .5 color: "#88dde0e3" } } TextField { id: userName text: "loristev" width: parent.width / 2 anchors.right: parent.right topPadding: 8 leftPadding: 16 rightPadding: 16 bottomPadding: 8 background: Rectangle { color: "transparent" } font { family: doesntEmbed ? "Roboto" : regular.name pointSize: 15 } } } } ColumnLayout { Layout.topMargin: 16 Layout.leftMargin: 20 Layout.rightMargin: 20 Layout.bottomMargin: 16 Label { Layout.fillWidth: true Layout.bottomMargin: 8 text: qsTr("Email id") color: "#747579" font { family: doesntEmbed ? "Roboto" : regular.name pointSize: 15 } } RowLayout { } } ColumnLayout { Layout.topMargin: 16 Layout.leftMargin: 20 Layout.rightMargin: 20 Layout.bottomMargin: 16 Label { Layout.fillWidth: true Layout.bottomMargin: 8 text: qsTr("Phone number") color: "#747579" font { family: doesntEmbed ? "Roboto" : regular.name pointSize: 15 } } RowLayout { } } ColumnLayout { Layout.topMargin: 16 Layout.leftMargin: 20 Layout.rightMargin: 20 Layout.bottomMargin: 16 Label { Layout.fillWidth: true Layout.bottomMargin: 8 text: qsTr("Location") color: "#747579" font { family: doesntEmbed ? "Roboto" : regular.name pointSize: 15 } } RowLayout { } } } } } } } }