You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
neroshop/qml/pages/HomePage.qml

241 lines
18 KiB

// consists of the navigational bar with menus and search bar
import QtQuick 2.12//2.7 //(QtQuick 2.7 is lowest version for Qt 5.7)
import QtQuick.Controls 2.12 // StackView
import QtQuick.Layouts 1.12 // GridLayout
import QtQuick.Shapes 1.3 // (since Qt 5.10) // Shape
import QtGraphicalEffects 1.12//Qt5Compat.GraphicalEffects 1.15//= Qt6// ColorOverlay
import "../components" as NeroshopComponents // Tooltip
Page {
id: homePage
background: Rectangle {
color: "transparent" // Make transparent to blend in with theme
}
ScrollView {
id: scrollView
anchors.fill: parent
anchors.margins: 20
ScrollBar.vertical.policy: ScrollBar.AsNeeded//ScrollBar.AlwaysOn
clip: true
GridLayout {
anchors.fill: parent
// Banner
NeroshopComponents.Banner {
id: homeBanner
Layout.preferredWidth: scrollView.width////parent.width // will not fill page if you use parent.width. Use scrollView.width instead
Layout.row: 0 // sets the row position
NeroshopComponents.BannerItem {
Rectangle {
id: firstPage
anchors.fill: parent
color: "blue"
//Image {
// anchors.fill: parent
// source: "https://revuo-xmr.com/img/img-issue151.png"//"file:///" + neroshopAppDirPath + "/img-issue150.png"//""
/*MouseArea { // This does not work :(
anchors.fill: parent
onClicked: Qt.openUrlExternally("https://revuo-xmr.com/issue-150.html") //...handling the clicked signal of the MouseArea
cursorShape: Qt.PointingHandCursor
}*/
//}
}
}
NeroshopComponents.BannerItem {
Rectangle {
id: secondPage
anchors.fill: parent
color: "red"
}
}
NeroshopComponents.BannerItem {
Rectangle {
id: thirdPage
anchors.fill: parent
color: "purple"
}
}
} // Banner
Text {
Layout.row: 2
Layout.topMargin: 10
text: "Categories"
color: (NeroshopComponents.Style.darkTheme) ? "#ffffff" : "#000000"
font.bold: true
font.pointSize: 16
}
Flow {
Layout.row: 3
Layout.preferredWidth: parent.width////scrollView.width
Layout.maximumWidth: scrollView.width////mainWindow.width
Layout.topMargin: 10
spacing: 5
//Layout.alignment: Qt.AlignHCenter | Qt.AlignTop // does nothing
Repeater {
id: categoryRepeater
model: Backend.getCategoryList()
delegate: Rectangle {
implicitWidth: 150//200
implicitHeight: 90//implicitWidth / 2
color: NeroshopComponents.Style.getColorsFromTheme()[1]
radius: 5//3
border.color: hovered ? "white" : "transparent"
property bool hovered: false
// TODO: replace catalog tooltip with normal text
NeroshopComponents.Hint {/*TextArea {
id: categoryNameText
text: modelData.name
color: (NeroshopComponents.Style.darkTheme) ? "#ffffff" : "#000000"
readOnly: true
wrapMode: TextEdit.Wrap
width: parent.width
verticalAlignment: TextEdit.AlignVCenter
anchors.top: parent.top
anchors.topMargin: 10*/
visible: parent.hovered
height: contentHeight + 20; width: contentWidth + 20
text: qsTr(modelData.name)
pointer.visible: false; delay: 0
}
Image {
id: categoryThumbnail
source: (modelData.thumbnail == "NULL") ? "qrc:/images/image_gallery.png" : modelData.thumbnail
anchors.horizontalCenter: parent.horizontalCenter
anchors.top: parent.top//anchors.bottom: categoryNameText.bottom
anchors.topMargin: 10//anchors.bottomMargin: 20////anchors.centerIn: parent
fillMode: Image.PreserveAspectFit
width: 32; height: 32
}
Rectangle {
anchors.bottom: parent.bottom//categoryRepeater.itemAt(index).children[0].bottom
anchors.bottomMargin: 10//20
anchors.horizontalCenter: parent.horizontalCenter
implicitWidth: 75
implicitHeight: 25
color: parent.color//"#000000"
radius: 5
border.color: "#ffffff"
Text {
text: Backend.getCategoryProductCount(modelData.id) // Number of products that fall under this particular category
color: "#ffffff"
anchors.horizontalCenter: parent.horizontalCenter
anchors.verticalCenter: parent.verticalCenter
}
}
MouseArea {
anchors.fill: parent
hoverEnabled: true
onEntered: parent.hovered = true
onExited: parent.hovered = false
onClicked: {
if(Backend.getCategoryProductCount(modelData.id) <= 0) return;
navBar.uncheckAllButtons()
pageLoader.setSource("qrc:/qml/pages/CatalogPage.qml", { "model": Backend.getListingsByCategory(modelData.id) })
}
cursorShape: Qt.PointingHandCursor
}
}
}
}
// Recent listings
Item {
Layout.row: 4
Layout.alignment: Qt.AlignTop
Layout.topMargin: 10
Layout.preferredWidth: childrenRect.width
Layout.preferredHeight: childrenRect.height
Layout.maximumWidth: scrollView.width
visible: itemsRepeater.count > 0
Column {
spacing: 10
Text {
text: "Recently added"//"Recent listings"
color: (NeroshopComponents.Style.darkTheme) ? "#ffffff" : "#000000"
font.bold: true
font.pointSize: 16
}
Flow {
width: parent.parent.parent.width////scrollView.width
spacing: 5
Repeater {
id: itemsRepeater
model: Backend.getListingsByMostRecentLimit(6)
delegate: Rectangle {
implicitWidth: 200
implicitHeight: implicitWidth
color: NeroshopComponents.Style.getColorsFromTheme()[1]
radius: 3
Image {
source: "file:///" + modelData.product_image_file//"qrc:/images/image_gallery.png"
anchors.centerIn: parent
width: parent.width - 10; height: parent.height - 10//width: 128; height: 128
fillMode: Image.PreserveAspectFit
mipmap: true
//asynchronous: true
MouseArea {
anchors.fill: parent
//hoverEnabled: true
acceptedButtons: Qt.LeftButton
onClicked: {
//navBar.uncheckAllButtons()
pageLoader.setSource("qrc:/qml/pages/ProductPage.qml", { "model": modelData })
}
cursorShape: Qt.PointingHandCursor
}
}
}
}
}
}
}
/* Item {
Layout.row: 5
Layout.alignment: Qt.AlignTop
Layout.topMargin: 10
Layout.preferredWidth: childrenRect.width
Layout.preferredHeight: childrenRect.height
Layout.maximumWidth: scrollView.width
Column {
spacing: 10
Text {
text: "Recently added"//"Recent listings"//"Featured items"//"Best sellers"//"On Sale"//"Recommended items"//"Shop by Category"
color: (NeroshopComponents.Style.darkTheme) ? "#ffffff" : "#000000"
font.bold: true
font.pointSize: 16
}
Flow {
width: parent.parent.parent.width//scrollView.width
spacing: 5
Repeater {
id: itemsRepeater
model: 16//6
delegate: Rectangle {
implicitWidth: 200
implicitHeight: implicitWidth
color: NeroshopComponents.Style.getColorsFromTheme()[1]
radius: 3
Image {
source: "qrc:/images/image_gallery.png"
anchors.centerIn: parent
}
}
}
}
}
}*/
} // GridLayout
} // ScrollView
}