import QtQuick 2.15 import QtQuick.Controls 2.15 import QtQuick.Layouts 1.15 Flickable { property alias checkoutAlert: alert property alias checkoutLogin: login property alias checkoutName: name property alias checkoutEmail: email property alias checkoutMobile: mobile property alias checkoutCountry: country property alias checkoutState: province property alias checkoutPostal: postal property alias checkoutAddress: address property alias checkoutBanks: banks property alias checkoutTotalValue: totalValue property alias checkoutPlaceOrder: placeOrder property alias checkoutPremium: premium contentHeight: body.height ColumnLayout { id: body anchors { top: parent.top left: parent.left right: parent.right } HeaderToolBar { Layout.fillWidth: true } GridLayout { columns: width < 1200 ? 1 : 2 rows: width < 1200 ? 2 : 1 columnSpacing: 0 rowSpacing: 0 Layout.fillWidth: true ColumnLayout { RowLayout { id: alert Layout.alignment: Qt.AlignHCenter Label { text: qsTr("Already have an account?") font.pointSize: 15 } Text { id: login text: "" + qsTr("Log in") + "" font.pointSize: 15 font.underline: false } } Rectangle { Layout.fillWidth: true implicitHeight: personal.height Layout.margins: 16 radius: 8 ColumnLayout { id: personal anchors { left: parent.left right: parent.right } Label { text: qsTr("Personal Details") font.pointSize: 22 font.family: "roboto" Layout.fillWidth: true Layout.rightMargin: 16 Layout.leftMargin: 16 Layout.topMargin: 16 } GridLayout { Layout.margins: 16 columns: width < 768 ? 1 : 2 rows: width < 768 ? 4 : 7 columnSpacing: 0 rowSpacing: 16 ColumnLayout { Label { text: qsTr("Your name *") font.pointSize: 12 font.family: "roboto" Layout.fillWidth: true } Rectangle { implicitHeight: 56 color: "#f5f7f9" radius: 8 border.width: 0 Layout.fillWidth: true RowLayout { anchors.fill: parent TextField { id: name placeholderText: qsTr("Name") font.pointSize: 16 font.family: "roboto" Layout.fillWidth: true Layout.fillHeight: true background: Rectangle { color: "transparent" } } } } } ColumnLayout { Label { text: qsTr("Email address *") font.pointSize: 12 font.family: "roboto" Layout.fillWidth: true } Rectangle { implicitHeight: 56 color: "#f5f7f9" radius: 8 border.width: 0 Layout.fillWidth: true RowLayout { anchors.fill: parent TextField { id: email placeholderText: qsTr("Email") font.pointSize: 16 font.family: "roboto" Layout.fillWidth: true Layout.fillHeight: true background: Rectangle { color: "transparent" } } } } } ColumnLayout { Label { text: qsTr("Mobile number *") font.pointSize: 12 font.family: "roboto" Layout.fillWidth: true } Rectangle { implicitHeight: 56 color: "#f5f7f9" radius: 8 border.width: 0 Layout.fillWidth: true RowLayout { anchors.fill: parent TextField { id: mobile placeholderText: qsTr("Mobile number") font.pointSize: 16 font.family: "roboto" Layout.fillWidth: true Layout.fillHeight: true background: Rectangle { color: "transparent" } } } } } ColumnLayout { Label { text: qsTr("Select country *") font.pointSize: 12 font.family: "roboto" Layout.fillWidth: true } Rectangle { implicitHeight: 56 color: "#f5f7f9" radius: 8 border.width: 0 Layout.fillWidth: true RowLayout { anchors.fill: parent TextField { id: country placeholderText: qsTr("Select country") font.pointSize: 16 font.family: "roboto" Layout.fillWidth: true Layout.fillHeight: true background: Rectangle { color: "transparent" } } } } } ColumnLayout { Label { text: qsTr("Select state *") font.pointSize: 12 font.family: "roboto" Layout.fillWidth: true } Rectangle { implicitHeight: 56 color: "#f5f7f9" radius: 8 border.width: 0 Layout.fillWidth: true RowLayout { anchors.fill: parent TextField { id: province placeholderText: qsTr("Select state") font.pointSize: 16 font.family: "roboto" Layout.fillWidth: true Layout.fillHeight: true background: Rectangle { color: "transparent" } } } } } ColumnLayout { Label { text: qsTr("Postal code *") font.pointSize: 12 font.family: "roboto" Layout.fillWidth: true } Rectangle { implicitHeight: 56 color: "#f5f7f9" radius: 8 border.width: 0 Layout.fillWidth: true RowLayout { anchors.fill: parent TextField { id: postal placeholderText: qsTr("PIN code") font.pointSize: 16 font.family: "roboto" Layout.fillWidth: true Layout.fillHeight: true background: Rectangle { color: "transparent" } } } } } ColumnLayout { Label { text: qsTr("Address *") font.pointSize: 12 font.family: "roboto" Layout.fillWidth: true } Rectangle { implicitHeight: 56 color: "#f5f7f9" radius: 8 border.width: 0 Layout.fillWidth: true RowLayout { anchors.fill: parent TextField { id: address placeholderText: qsTr("Address") font.pointSize: 16 font.family: "roboto" Layout.fillWidth: true Layout.fillHeight: true background: Rectangle { color: "transparent" } } } } } } ColumnLayout { Label { text: qsTr("Payment method") font.pointSize: 22 font.family: "roboto" Layout.fillWidth: true Layout.margins: 16 } ColumnLayout { Rectangle { implicitHeight: paymentCard.height Layout.margins:16 Layout.fillWidth: true border.width: 1 radius: 8 border.color: "#4d000000" ColumnLayout { id: paymentCard anchors { left: parent.left right: parent.right } Label { text: qsTr("Credit or Debit Card") font.pointSize: 16 font.family: "roboto" Layout.fillWidth: true } } } Frame { Layout.fillWidth: true ColumnLayout { anchors.fill: parent Label { text: qsTr("Pay with Net Banking") font.pointSize: 15 Layout.fillWidth: true } ColumnLayout { Label { text: qsTr("In order to complete your transaction, we will transfer you over to Eduport secure servers.") font.pointSize: 15 wrapMode: Text.Wrap Layout.fillWidth: true } Label { text: qsTr("Select your bank from the drop-down list and click proceed to continue with your payment.") font.pointSize: 15 wrapMode: Text.Wrap Layout.fillWidth: true } ComboBox { id: banks font.pointSize: 15 model: ListModel { ListElement { label: "Please choose one" } ListElement { label: "Bank of America" } ListElement { label: "Bank of India" } ListElement { label: "Bank of London" } } delegate: ItemDelegate { contentItem: Text { text: label font.pointSize: 14 } } } } } } } } } } } GridLayout { columns: width < 786 ? 1 : 2 rows: width < 786 ? 2 : 1 columnSpacing: 0 rowSpacing: 0 Layout.alignment: Qt.AlignTop Frame { Layout.fillWidth: true ColumnLayout { anchors.fill: parent Label { text: qsTr("Order Summary") font.pointSize: 21 Layout.fillWidth: true } ColumnLayout { Item { Layout.fillWidth: true implicitHeight: codeLabel.implicitHeight + codeValue.implicitHeight Label { id: codeLabel text: qsTr("Transaction code") font.pointSize: 15 anchors.verticalCenter: parent.verticalCenter } Label { id: codeValue text: "AB12365E" font.pointSize: 15 anchors { right: parent.right verticalCenter: parent.verticalCenter } } } RowLayout { TextField { placeholderText: qsTr("COUPON CODE") font.pointSize: 15 Layout.fillWidth: true } Button { text: qsTr("Apply") font.pointSize: 15 } } } ColumnLayout { Item { Layout.fillWidth: true implicitHeight: priceLabel.implicitHeight + priceValue.implicitHeight Label { id: priceLabel text: qsTr("Original Price") font.pointSize: 15 anchors.verticalCenter: parent.verticalCenter } Label { id: priceValue text: "$500" font.pointSize: 15 anchors { right: parent.right verticalCenter: parent.verticalCenter } } } Item { Layout.fillWidth: true implicitHeight: discountLabel.implicitHeight + discountValue.implicitHeight Label { id: discountLabel text: qsTr("Coupon Discount") font.pointSize: 15 anchors.verticalCenter: parent.verticalCenter } Label { id: discountValue text: "-" + "$20" font.pointSize: 15 anchors { right: parent.right verticalCenter: parent.verticalCenter } } } Item { Layout.fillWidth: true implicitHeight: totalLabel.implicitHeight + totalValue.implicitHeight Label { id: totalLabel text: qsTr("Total") font.pointSize: 21 anchors.verticalCenter: parent.verticalCenter } Label { id: totalValue text: "$480" font.pointSize: 21 anchors { right: parent.right verticalCenter: parent.verticalCenter } } } } Button { id: placeOrder text: qsTr("Place Order") font.pointSize: 15 Layout.fillWidth: true } } } Frame { id: premium Layout.fillWidth: true Layout.alignment: Qt.AlignTop ColumnLayout { anchors.fill: parent Label { text: qsTr("Access 25K Online courses from 120 institutions, Start today!") font.pointSize: 21 wrapMode: Text.Wrap Layout.fillWidth: true } Label { text: qsTr("Here is the description of premium features which will allow users to get benefits and save a lot of money") font.pointSize: 15 wrapMode: Text.Wrap Layout.fillWidth: true } Button { text: qsTr("Purchase Premium") font.pointSize: 13 Layout.fillWidth: true } } } } } } }