Refactor ContentView to add media browser
This commit is contained in:
@@ -111,6 +111,16 @@ class Provider(QObject):
|
|||||||
def getShow(self, id) -> Show:
|
def getShow(self, id) -> Show:
|
||||||
return self._shows[id]
|
return self._shows[id]
|
||||||
|
|
||||||
|
@pyqtProperty(list)
|
||||||
|
def showsAlphabetic(self) -> list[int]:
|
||||||
|
return [
|
||||||
|
elem[0]
|
||||||
|
for elem in sorted(
|
||||||
|
[(id, show) for id, show in self._shows.items()],
|
||||||
|
key=lambda elem: elem[1].title,
|
||||||
|
)
|
||||||
|
]
|
||||||
|
|
||||||
@pyqtProperty(list)
|
@pyqtProperty(list)
|
||||||
def recentlyAdded(self) -> list[int]:
|
def recentlyAdded(self) -> list[int]:
|
||||||
return self._recently_added
|
return self._recently_added
|
||||||
|
|||||||
@@ -1,11 +1,14 @@
|
|||||||
import QtQuick 2.12
|
import QtQuick 2.12
|
||||||
|
|
||||||
|
import Ikinuki.Client 1.0
|
||||||
|
|
||||||
import "./BrowserView"
|
import "./BrowserView"
|
||||||
|
|
||||||
Row {
|
Row {
|
||||||
|
required property Database db
|
||||||
property int selectedView: 0
|
property int selectedView: 0
|
||||||
property int selectedProvider: 0
|
property int selectedProvider: 0
|
||||||
property var db
|
property bool browse: false
|
||||||
Sidebar {
|
Sidebar {
|
||||||
id: sidebar
|
id: sidebar
|
||||||
maximized: selectedView == 0
|
maximized: selectedView == 0
|
||||||
@@ -15,7 +18,7 @@ Row {
|
|||||||
ContentView {
|
ContentView {
|
||||||
id: view
|
id: view
|
||||||
viewSelected: selectedView == 1
|
viewSelected: selectedView == 1
|
||||||
currentIndex: selectedProvider
|
currentIndex: selectedProvider + (browse ? 3 : 0)
|
||||||
providers: db.Providers
|
providers: db.Providers
|
||||||
}
|
}
|
||||||
function mod(n, m) {
|
function mod(n, m) {
|
||||||
@@ -26,11 +29,14 @@ Row {
|
|||||||
if (event.key == Qt.Key_Right) {
|
if (event.key == Qt.Key_Right) {
|
||||||
selectedView = 1;
|
selectedView = 1;
|
||||||
} else if (event.key == Qt.Key_Down) {
|
} else if (event.key == Qt.Key_Down) {
|
||||||
selectedProvider = mod(selectedProvider + 1, db.Providers.length)
|
selectedProvider = mod(selectedProvider + 1, db.Providers.length);
|
||||||
} else if (event.key == Qt.Key_Up) {
|
} else if (event.key == Qt.Key_Up) {
|
||||||
selectedProvider = mod(selectedProvider - 1, db.Providers.length)
|
selectedProvider = mod(selectedProvider - 1, db.Providers.length);
|
||||||
|
} else if (event.key == Qt.Key_Return) {
|
||||||
|
browse = true;
|
||||||
|
selectedView = 1;
|
||||||
} else {
|
} else {
|
||||||
return
|
return;
|
||||||
}
|
}
|
||||||
event.accepted = true;
|
event.accepted = true;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -9,7 +9,7 @@ import "./ContentView"
|
|||||||
|
|
||||||
StackLayout {
|
StackLayout {
|
||||||
id: tabView
|
id: tabView
|
||||||
property var providers
|
property var providers: []
|
||||||
property bool viewSelected
|
property bool viewSelected
|
||||||
state: viewSelected ? "selected" : "deselected"
|
state: viewSelected ? "selected" : "deselected"
|
||||||
property int ySelect: 0
|
property int ySelect: 0
|
||||||
@@ -18,7 +18,13 @@ StackLayout {
|
|||||||
|
|
||||||
Repeater {
|
Repeater {
|
||||||
model: providers
|
model: providers
|
||||||
ContentViewTab{
|
ProviderHome {
|
||||||
|
provider: modelData
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Repeater {
|
||||||
|
model: providers
|
||||||
|
ProviderBrowse {
|
||||||
provider: modelData
|
provider: modelData
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -49,9 +55,12 @@ StackLayout {
|
|||||||
]
|
]
|
||||||
|
|
||||||
Keys.onPressed: (event)=> {
|
Keys.onPressed: (event)=> {
|
||||||
tabView.children[currentIndex].Keys.pressed(event);
|
var x = currentIndex > 2 ? currentIndex + 1 : currentIndex;
|
||||||
if (tabView.children[currentIndex].viewExit) {
|
//tabView.children[currentIndex].Keys.pressed(event);
|
||||||
tabView.children[currentIndex].viewExit = false;
|
tabView.children[x].Keys.pressed(event);
|
||||||
|
if (tabView.children[x].viewExit) {
|
||||||
|
tabView.children[x].viewExit = false;
|
||||||
|
parent.browse = false;
|
||||||
parent.selectedView = 0;
|
parent.selectedView = 0;
|
||||||
}
|
}
|
||||||
event.accepted = true;
|
event.accepted = true;
|
||||||
|
|||||||
@@ -0,0 +1,86 @@
|
|||||||
|
import QtQuick 2.12
|
||||||
|
import QtQuick.Layouts 1.12
|
||||||
|
import QtQuick.Controls 1.4
|
||||||
|
import QtQuick.Controls 2.15
|
||||||
|
|
||||||
|
import Ikinuki.Client 1.0
|
||||||
|
|
||||||
|
import "./ProviderBrowse"
|
||||||
|
|
||||||
|
Rectangle {
|
||||||
|
id: root
|
||||||
|
property var provider
|
||||||
|
property bool viewExit: false
|
||||||
|
property int currentView: 0
|
||||||
|
anchors.fill: parent
|
||||||
|
color: "#22282A"
|
||||||
|
Row {
|
||||||
|
anchors.fill: parent
|
||||||
|
Item {
|
||||||
|
height: parent.height
|
||||||
|
width: parent.width * 0.025
|
||||||
|
}
|
||||||
|
Column {
|
||||||
|
width: parent.width * 0.95
|
||||||
|
height: parent.height
|
||||||
|
Item {
|
||||||
|
height: 40
|
||||||
|
width: parent.width
|
||||||
|
}
|
||||||
|
CoverGrid {
|
||||||
|
id: coverGrid
|
||||||
|
height: parent.height - 80
|
||||||
|
width: parent.width
|
||||||
|
provider: root.provider
|
||||||
|
shows: root.provider.showsAlphabetic
|
||||||
|
selected: currentView == 0
|
||||||
|
}
|
||||||
|
Item {
|
||||||
|
height: 40
|
||||||
|
width: parent.width
|
||||||
|
}
|
||||||
|
}
|
||||||
|
AlphabetSelector {
|
||||||
|
id: alphabetSelector
|
||||||
|
height: parent.height
|
||||||
|
width: parent.width * 0.025
|
||||||
|
selected: currentView == 1
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Keys.onPressed: (event)=> {
|
||||||
|
if (currentView == 0) { // grid
|
||||||
|
if (event.key == Qt.Key_Left) {
|
||||||
|
if (coverGrid.xIndex == 0) {
|
||||||
|
viewExit = true;
|
||||||
|
} else {
|
||||||
|
coverGrid.xIndex--;
|
||||||
|
}
|
||||||
|
} else if (event.key == Qt.Key_Right) {
|
||||||
|
if (coverGrid.xIndex == coverGrid.numColumns - 1) {
|
||||||
|
currentView = 1;
|
||||||
|
} else {
|
||||||
|
coverGrid.xIndex++;
|
||||||
|
}
|
||||||
|
} else if (event.key == Qt.Key_Down) {
|
||||||
|
coverGrid.yIndex++;
|
||||||
|
} else if (event.key == Qt.Key_Up) {
|
||||||
|
coverGrid.yIndex--;
|
||||||
|
}
|
||||||
|
} else if (currentView == 1) { // alphabet
|
||||||
|
if (event.key == Qt.Key_Left) {
|
||||||
|
currentView = 0;
|
||||||
|
} else if (event.key == Qt.Key_Up) {
|
||||||
|
if (alphabetSelector.yIndex > 0) {
|
||||||
|
alphabetSelector.yIndex--;
|
||||||
|
}
|
||||||
|
} else if (event.key == Qt.Key_Down) {
|
||||||
|
if (alphabetSelector.yIndex < alphabetSelector.letters.length - 1)
|
||||||
|
alphabetSelector.yIndex++;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
event.accepted = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,67 @@
|
|||||||
|
import QtQuick 2.12
|
||||||
|
import QtQuick.Controls 2.15
|
||||||
|
import QtGraphicalEffects 1.12
|
||||||
|
|
||||||
|
Column {
|
||||||
|
property int yIndex: 0
|
||||||
|
property bool selected
|
||||||
|
property var letters: ['#', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z']
|
||||||
|
Item {
|
||||||
|
height: 20
|
||||||
|
width: parent.width
|
||||||
|
}
|
||||||
|
ScrollView {
|
||||||
|
height: parent.height - 30
|
||||||
|
width: parent.width
|
||||||
|
ScrollBar.vertical.position: {
|
||||||
|
if (yIndex > 20) {
|
||||||
|
return (5 - (25 - yIndex)) * (0.048);
|
||||||
|
} else {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Flickable {
|
||||||
|
clip: true
|
||||||
|
Column {
|
||||||
|
spacing: 10
|
||||||
|
Repeater {
|
||||||
|
model: letters
|
||||||
|
Item {
|
||||||
|
width: 40
|
||||||
|
height: 40
|
||||||
|
anchors.horizontalCenter: parent.horizontalCenter
|
||||||
|
property bool s: selected && (index == yIndex)
|
||||||
|
DropShadow {
|
||||||
|
anchors.fill: selector
|
||||||
|
verticalOffset: 5
|
||||||
|
samples: 20
|
||||||
|
color: "black"
|
||||||
|
opacity: 0.5
|
||||||
|
source: selector
|
||||||
|
visible: s
|
||||||
|
}
|
||||||
|
Rectangle {
|
||||||
|
id: selector
|
||||||
|
anchors.fill: parent
|
||||||
|
color: "white"
|
||||||
|
visible: s
|
||||||
|
radius: 10
|
||||||
|
}
|
||||||
|
Text {
|
||||||
|
anchors.horizontalCenter: parent.horizontalCenter
|
||||||
|
anchors.verticalCenter: parent.verticalCenter
|
||||||
|
anchors.verticalCenterOffset: 4
|
||||||
|
text: modelData
|
||||||
|
color: s ? "black" : "gray"
|
||||||
|
font.pointSize: 18
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Item {
|
||||||
|
height: 20
|
||||||
|
width: parent.width
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,100 @@
|
|||||||
|
import QtQuick 2.12
|
||||||
|
import QtQuick.Controls 1.4
|
||||||
|
import QtGraphicalEffects 1.12
|
||||||
|
|
||||||
|
|
||||||
|
Item {
|
||||||
|
property var show
|
||||||
|
property bool elemSelected
|
||||||
|
property int baseHeight: 350
|
||||||
|
property int childHeight: baseHeight
|
||||||
|
property int childWidth: baseHeight * 0.68
|
||||||
|
property int childHeightExpanded: baseHeight * 15 / 14
|
||||||
|
property int childWidthExpanded: (baseHeight * 15 / 14) * 0.68
|
||||||
|
property int borderWidth: 3
|
||||||
|
property int borderRadius: 1
|
||||||
|
property int borderRectHeight: childHeight + (borderWidth * 2)
|
||||||
|
property int borderRectWidth: childWidth + (borderWidth * 2)
|
||||||
|
property int borderRectHeightExpanded: childHeightExpanded + (borderWidth * 2)
|
||||||
|
property int borderRectWidthExpanded: childWidthExpanded + (borderWidth * 2)
|
||||||
|
|
||||||
|
height: baseHeight * 1.15
|
||||||
|
width: (baseHeight * 8 / 7) * 0.68
|
||||||
|
Item {
|
||||||
|
id: parentElem
|
||||||
|
state: elemSelected ? "selected" : "deselected"
|
||||||
|
anchors.horizontalCenter: parent.horizontalCenter
|
||||||
|
anchors.fill: parent
|
||||||
|
DropShadow {
|
||||||
|
id: dropShadow
|
||||||
|
anchors.fill: img
|
||||||
|
verticalOffset: 15
|
||||||
|
samples: 80
|
||||||
|
opacity: 0.5
|
||||||
|
color: "black"
|
||||||
|
source: img
|
||||||
|
}
|
||||||
|
Rectangle {
|
||||||
|
id: rect
|
||||||
|
color: "transparent"
|
||||||
|
border.color: "orange"
|
||||||
|
anchors.horizontalCenter: parent.horizontalCenter
|
||||||
|
anchors.verticalCenter: parent.verticalCenter
|
||||||
|
radius: borderRadius
|
||||||
|
}
|
||||||
|
Image {
|
||||||
|
id: img
|
||||||
|
anchors.horizontalCenter: parent.horizontalCenter
|
||||||
|
anchors.verticalCenter: parent.verticalCenter
|
||||||
|
source: show.poster
|
||||||
|
mipmap: true
|
||||||
|
}
|
||||||
|
states: [
|
||||||
|
State {
|
||||||
|
name: "deselected"
|
||||||
|
PropertyChanges {
|
||||||
|
target: rect
|
||||||
|
border.width: 0
|
||||||
|
height: borderRectHeight
|
||||||
|
width: borderRectWidth
|
||||||
|
}
|
||||||
|
PropertyChanges {
|
||||||
|
target: dropShadow
|
||||||
|
visible: false
|
||||||
|
}
|
||||||
|
PropertyChanges {
|
||||||
|
target: img
|
||||||
|
width: childWidth
|
||||||
|
height: childHeight
|
||||||
|
}
|
||||||
|
},
|
||||||
|
State {
|
||||||
|
name: "selected"
|
||||||
|
PropertyChanges {
|
||||||
|
target: rect
|
||||||
|
border.width: borderWidth
|
||||||
|
height: borderRectHeightExpanded
|
||||||
|
width: borderRectWidthExpanded
|
||||||
|
}
|
||||||
|
PropertyChanges {
|
||||||
|
target: dropShadow
|
||||||
|
visible: true
|
||||||
|
}
|
||||||
|
PropertyChanges {
|
||||||
|
target: img
|
||||||
|
width: childWidthExpanded
|
||||||
|
height: childHeightExpanded
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
transitions: [
|
||||||
|
Transition {
|
||||||
|
NumberAnimation {
|
||||||
|
properties: "border.width,width,height"
|
||||||
|
duration: 100
|
||||||
|
easing.type: Easing.Linear
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,27 @@
|
|||||||
|
import QtQuick 2.12
|
||||||
|
import QtQuick.Layouts 1.12
|
||||||
|
import QtQuick.Controls 1.4
|
||||||
|
import QtQuick.Controls 2.15
|
||||||
|
|
||||||
|
import Ikinuki.Client 1.0
|
||||||
|
|
||||||
|
Grid {
|
||||||
|
id: root
|
||||||
|
clip: true
|
||||||
|
property bool selected
|
||||||
|
property int yIndex: 0
|
||||||
|
property int xIndex: 0
|
||||||
|
property int numColumns: 6
|
||||||
|
property var provider
|
||||||
|
property var shows: []
|
||||||
|
columns: numColumns
|
||||||
|
topPadding: 20
|
||||||
|
Repeater {
|
||||||
|
id: repeater
|
||||||
|
model: shows
|
||||||
|
BrowseShow {
|
||||||
|
show: provider.getShow(modelData)
|
||||||
|
elemSelected: selected && (index == (yIndex * numColumns + xIndex))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
+6
-5
@@ -5,9 +5,10 @@ import QtQuick.Controls 2.15
|
|||||||
|
|
||||||
import Ikinuki.Client 1.0
|
import Ikinuki.Client 1.0
|
||||||
|
|
||||||
import "./ContentViewTab"
|
import "./ProviderHome"
|
||||||
|
|
||||||
Rectangle {
|
Rectangle {
|
||||||
|
id: root
|
||||||
property var provider
|
property var provider
|
||||||
property int ySelect: 0
|
property int ySelect: 0
|
||||||
property int xSelect: 0
|
property int xSelect: 0
|
||||||
@@ -49,14 +50,14 @@ Rectangle {
|
|||||||
width: parent.width
|
width: parent.width
|
||||||
Element {
|
Element {
|
||||||
title: "In Progress"
|
title: "In Progress"
|
||||||
provider: modelData
|
provider: root.provider
|
||||||
repeaterModel: modelData.inProgress
|
repeaterModel: provider.inProgress
|
||||||
elemSelected: viewSelected && (0 == ySelect)
|
elemSelected: viewSelected && (0 == ySelect)
|
||||||
}
|
}
|
||||||
Element {
|
Element {
|
||||||
title: "Recently Added"
|
title: "Recently Added"
|
||||||
provider: modelData
|
provider: root.provider
|
||||||
repeaterModel: modelData.recentlyAdded
|
repeaterModel: provider.recentlyAdded
|
||||||
elemSelected: viewSelected && (1 == ySelect)
|
elemSelected: viewSelected && (1 == ySelect)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
+1
@@ -3,6 +3,7 @@ import QtQuick.Controls 1.4
|
|||||||
import QtQuick.Controls 2.15
|
import QtQuick.Controls 2.15
|
||||||
|
|
||||||
Column {
|
Column {
|
||||||
|
id: root
|
||||||
property var title
|
property var title
|
||||||
property var provider
|
property var provider
|
||||||
property var repeaterModel
|
property var repeaterModel
|
||||||
Reference in New Issue
Block a user