replace tabgroup

This commit is contained in:
Sam Hadow 2024-03-13 02:50:37 +01:00
parent 4177681d46
commit c67558e03b
2 changed files with 141 additions and 234 deletions

View File

@ -18,7 +18,7 @@ include(ECMOptionalAddSubdirectory)
include(FeatureSummary) include(FeatureSummary)
include(CheckIncludeFiles) include(CheckIncludeFiles)
set(KF5_MIN_VERSION "6.0.0") set(KF5_MIN_VERSION "5.2.0")
find_package(KF5 ${KF5_MIN_VERSION} REQUIRED COMPONENTS find_package(KF5 ${KF5_MIN_VERSION} REQUIRED COMPONENTS
Plasma Plasma
I18n I18n

View File

@ -22,12 +22,12 @@
import QtQuick 2.3 import QtQuick 2.3
import org.kde.plasma.plasmoid 2.0 import org.kde.plasma.plasmoid 2.0
import QtQuick.Layouts 1.1 import QtQuick.Layouts 1.1
import org.kde.plasma.core as PlasmaCore import org.kde.plasma.plasmoid as PlasmaCore
import org.kde.ksvg as KSvg import org.kde.ksvg as KSvg
import org.kde.plasma.plasma5support as Plasma5Support import org.kde.plasma.plasma5support as Plasma5Support
import org.kde.kirigami as Kirigami import org.kde.kirigami 2.20 as Kirigami
import org.kde.plasma.components as PlasmaComponents import org.kde.plasma.components 3.0 as PlasmaComponents
import org.kde.plasma.extras as PlasmaExtras import org.kde.plasma.extras 2.0 as PlasmaExtras
import org.kde.kquickcontrolsaddons 2.0 import org.kde.kquickcontrolsaddons 2.0
import org.kde.plasma.private.kicker 0.1 as Kicker import org.kde.plasma.private.kicker 0.1 as Kicker
@ -125,274 +125,181 @@ Item {
id: mainArea id: mainArea
anchors.topMargin: mainTabGroup.state == "top" ? Kirigami.Units.smallSpacing : 0 anchors.topMargin: mainTabGroup.state == "top" ? Kirigami.Units.smallSpacing : 0
PlasmaComponents.TabGroup { Kirigami.Page {
id: mainTabGroup id: mainPage
currentTab: favoritesPage
anchors { // Set anchors
fill: parent anchors.fill: parent
}
//pages // Create a row for the tab buttons
FavoritesView { Kirigami.PageRow {
id: favoritesPage id: tabRow
}
PlasmaExtras.ConditionalLoader {
id: applicationsPage
when: mainTabGroup.currentTab == applicationsPage
source: Qt.resolvedUrl("ApplicationsView.qml")
}
PlasmaExtras.ConditionalLoader {
id: systemPage
when: mainTabGroup.currentTab == systemPage
source: Qt.resolvedUrl("ComputerView.qml")
}
PlasmaExtras.ConditionalLoader {
id: recentlyUsedPage
when: mainTabGroup.currentTab == recentlyUsedPage
source: Qt.resolvedUrl("RecentlyUsedView.qml")
}
PlasmaExtras.ConditionalLoader {
id: oftenUsedPage
when: mainTabGroup.currentTab == oftenUsedPage
source: Qt.resolvedUrl("OftenUsedView.qml")
}
PlasmaExtras.ConditionalLoader {
id: leavePage
when: mainTabGroup.currentTab == leavePage
source: Qt.resolvedUrl("LeaveView.qml")
}
PlasmaExtras.ConditionalLoader {
id: searchPage
when: root.state == "Search"
//when: mainTabGroup.currentTab == searchPage || root.state == "Search"
source: Qt.resolvedUrl("SearchView.qml")
}
state: { // Set row orientation based on plasmoid location
orientation: {
switch (plasmoid.location) { switch (plasmoid.location) {
case PlasmaCore.Types.LeftEdge: case PlasmaCore.Types.LeftEdge:
return LayoutMirroring.enabled ? "right" : "left";
case PlasmaCore.Types.TopEdge:
return "top";
case PlasmaCore.Types.RightEdge: case PlasmaCore.Types.RightEdge:
return LayoutMirroring.enabled ? "left" : "right"; return Qt.Horizontal
case PlasmaCore.Types.BottomEdge:
default: default:
return "bottom"; return Qt.Vertical
} }
} }
// Add tab buttons
PlasmaComponents.Button {
text: i18n("Favorites")
onClicked: mainPage.currentIndex = 0
}
PlasmaComponents.Button {
text: i18n("Applications")
onClicked: mainPage.currentIndex = 1
}
PlasmaComponents.Button {
text: i18n("Computer")
onClicked: mainPage.currentIndex = 2
}
PlasmaComponents.Button {
text: i18n("Recently Used")
onClicked: mainPage.currentIndex = 3
}
PlasmaComponents.Button {
text: i18n("Often Used")
onClicked: mainPage.currentIndex = 4
}
PlasmaComponents.Button {
text: i18n("Leave")
onClicked: mainPage.currentIndex = 5
}
PlasmaComponents.Button {
text: i18n("Search")
onClicked: root.state = "Search"
}
}
// Add pages
Kirigami.Page {
id: favoritesPage
anchors.fill: parent
visible: mainPage.currentIndex === 0
// Add contents of the Favorites view here
}
Kirigami.Page {
id: applicationsPage
anchors.fill: parent
visible: mainPage.currentIndex === 1
// Add contents of the Applications view here
}
Kirigami.Page {
id: computerPage
anchors.fill: parent
visible: mainPage.currentIndex === 2
// Add contents of the Computer view here
}
Kirigami.Page {
id: recentlyUsedPage
anchors.fill: parent
visible: mainPage.currentIndex === 3
// Add contents of the Recently Used view here
}
Kirigami.Page {
id: oftenUsedPage
anchors.fill: parent
visible: mainPage.currentIndex === 4
// Add contents of the Often Used view here
}
Kirigami.Page {
id: leavePage
anchors.fill: parent
visible: mainPage.currentIndex === 5
// Add contents of the Leave view here
}
Kirigami.Page {
id: searchPage
anchors.fill: parent
visible: root.state === "Search"
// Add contents of the Search view here
}
// Handle the plasmoid location states
states: [ states: [
State { State {
name: "left" name: "left"
AnchorChanges { PropertyChanges {
target: header target: tabRow
anchors { rotation: 0
left: root.left
top: undefined
right: root.right
bottom: root.bottom
}
} }
PropertyChanges { PropertyChanges {
target: header target: tabRow
width: header.implicitWidth
location: PlasmaExtras.PlasmoidHeading.Location.Footer
}
AnchorChanges {
target: mainArea
anchors { anchors {
left: tabBar.right left: parent.left
top: root.top top: parent.top
right: root.right bottom: parent.bottom
bottom: header.top
}
}
PropertyChanges {
target: tabBar
width: (tabBar.opacity == 0) ? 0 : Kirigami.Units.gridUnit * 5
}
AnchorChanges {
target: tabBar
anchors {
left: root.left
top: root.top
right: undefined
bottom: header.top
}
}
PropertyChanges {
target:tabBarSeparator
width: tabBarSeparatorLine.elementSize("vertical-line").width
elementId: "vertical-line"
}
AnchorChanges {
target: tabBarSeparator
anchors {
left: tabBar.right
top: tabBar.top
bottom:tabBar.bottom
} }
} }
}, },
State { State {
name: "top" name: "top"
AnchorChanges { PropertyChanges {
target: header target: tabRow
anchors { rotation: -90
left: root.left
top: undefined
right: root.right
bottom: root.bottom
}
} }
PropertyChanges { PropertyChanges {
target: header target: tabRow
height: header.implicitHeight
location: PlasmaExtras.PlasmoidHeading.Location.Footer
}
AnchorChanges {
target: mainArea
anchors { anchors {
left: root.left top: parent.top
top: tabBar.bottom left: parent.left
right: root.right right: parent.right
bottom: header.top
}
}
PropertyChanges {
target: tabBar
height: (tabBar.opacity == 0) ? 0 : Kirigami.Units.gridUnit * 5
}
AnchorChanges {
target: tabBar
anchors {
left: root.left
top: root.top
right: root.right
bottom: undefined
}
}
PropertyChanges {
target:tabBarSeparator
height: tabBarSeparatorLine.elementSize("horizontal-line").height
elementId: "horizontal-line"
}
AnchorChanges {
target: tabBarSeparator
anchors {
left: tabBar.left
right: tabBar.right
top: tabBar.bottom
} }
} }
}, },
State { State {
name: "right" name: "right"
AnchorChanges { PropertyChanges {
target: header target: tabRow
anchors { rotation: 180
left: root.left
top: undefined
right: root.right
bottom: root.bottom
}
} }
PropertyChanges { PropertyChanges {
target: header target: tabRow
width: header.implicitWidth
location: PlasmaExtras.PlasmoidHeading.Location.Footer
}
AnchorChanges {
target: mainArea
anchors { anchors {
left: root.left right: parent.right
top: root.top top: parent.top
right: tabBar.left bottom: parent.bottom
bottom: header.top
}
}
PropertyChanges {
target: tabBar
width: (tabBar.opacity == 0) ? 0 : Kirigami.Units.gridUnit * 5
}
AnchorChanges {
target: tabBar
anchors {
left: undefined
top: root.top
right: root.right
bottom: header.top
}
}
PropertyChanges {
target:tabBarSeparator
width: tabBarSeparatorLine.elementSize("vertical-line").width
elementId: "vertical-line"
}
AnchorChanges {
target: tabBarSeparator
anchors {
right: tabBar.left
top: tabBar.top
bottom: tabBar.bottom
} }
} }
}, },
State { State {
name: "bottom" name: "bottom"
AnchorChanges { PropertyChanges {
target: header target: tabRow
anchors { rotation: 90
left: root.left
top: root.top
right: root.right
bottom: undefined
}
} }
PropertyChanges { PropertyChanges {
target: header target: tabRow
height: header.implicitHeight
location: PlasmaExtras.PlasmoidHeading.Location.Header
}
AnchorChanges {
target: mainArea
anchors { anchors {
left: root.left bottom: parent.bottom
top: header.bottom left: parent.left
right: root.right right: parent.right
bottom: tabBar.top
}
}
PropertyChanges {
target: tabBar
height: (tabBar.opacity == 0) ? 0 : Kirigami.Units.gridUnit * 5
}
AnchorChanges {
target: tabBar
anchors {
left: root.left
top: undefined
right: root.right
bottom: root.bottom
}
}
PropertyChanges {
target:tabBarSeparator
height: tabBarSeparatorLine.elementSize("horizontal-line").height
elementId: "horizontal-line"
}
AnchorChanges {
target: tabBarSeparator
anchors {
bottom: tabBar.top
left: tabBar.left
right: tabBar.right
} }
} }
} }
] ]
} // mainTabGroup
// Set initial plasmoid state
state: {
switch (plasmoid.location) {
case PlasmaCore.Types.LeftEdge:
return "left"
case PlasmaCore.Types.TopEdge:
return "top"
case PlasmaCore.Types.RightEdge:
return "right"
case PlasmaCore.Types.BottomEdge:
default:
return "bottom"
}
}
}
} }
PlasmaComponents.TabBar { PlasmaComponents.TabBar {