2019-07-08 13:52:41 +10:00
|
|
|
// Copyright 2019 miruka
|
|
|
|
// This file is part of harmonyqml, licensed under LGPLv3.
|
|
|
|
|
2019-07-13 19:39:01 +10:00
|
|
|
import QtQuick 2.12
|
|
|
|
import QtQuick.Layouts 1.12
|
2019-04-29 05:18:36 +10:00
|
|
|
import "../Base"
|
2019-03-26 18:19:55 +11:00
|
|
|
|
2019-05-12 07:51:00 +10:00
|
|
|
HRectangle {
|
2019-03-26 18:19:55 +11:00
|
|
|
id: sidePane
|
2019-07-16 22:52:26 +10:00
|
|
|
clip: true // Avoid artifacts when collapsed
|
|
|
|
visible: mainUI.accountsPresent
|
2019-04-29 01:01:38 +10:00
|
|
|
|
2019-07-16 22:52:26 +10:00
|
|
|
|
|
|
|
// Properties that may be set externally
|
|
|
|
|
|
|
|
property int parentWidth: parent.width
|
|
|
|
onParentWidthChanged: if (canAutoSize) { width = getWidth() }
|
|
|
|
|
|
|
|
property bool canAutoSize: true
|
|
|
|
|
|
|
|
|
|
|
|
// Pane state properties - should not be modified
|
2019-07-12 12:25:50 +10:00
|
|
|
|
2019-07-16 22:36:11 +10:00
|
|
|
readonly property bool reduced: width < 1
|
|
|
|
readonly property bool collapsed:
|
|
|
|
width < theme.sidePane.collapsedWidth + theme.spacing
|
|
|
|
|
2019-07-16 19:29:47 +10:00
|
|
|
property int currentSpacing: collapsed ? 0 : theme.spacing
|
2019-07-13 08:17:02 +10:00
|
|
|
Behavior on currentSpacing { HNumberAnimation {} }
|
2019-05-13 05:57:18 +10:00
|
|
|
|
2019-07-16 22:52:26 +10:00
|
|
|
|
|
|
|
// Width functions and animations
|
|
|
|
|
|
|
|
function getWidth() {
|
|
|
|
var ts = theme.sidePane
|
|
|
|
return parentWidth * ts.autoWidthRatio < ts.autoCollapseBelowWidth ?
|
|
|
|
ts.collapsedWidth :
|
|
|
|
Math.min(parentWidth * ts.autoWidthRatio, ts.maximumAutoWidth)
|
|
|
|
}
|
|
|
|
|
|
|
|
Behavior on width {
|
|
|
|
HNumberAnimation {
|
|
|
|
// Don't slow down the user manually resizing
|
|
|
|
duration: (
|
|
|
|
canAutoSize &&
|
|
|
|
parentWidth * 0.3 < theme.sidePane.autoReduceBelowWidth * 1.2
|
|
|
|
) ? theme.animationDuration : 0
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Pane content
|
|
|
|
|
2019-04-29 05:18:36 +10:00
|
|
|
HColumnLayout {
|
2019-03-26 18:19:55 +11:00
|
|
|
anchors.fill: parent
|
|
|
|
|
|
|
|
AccountList {
|
|
|
|
Layout.fillWidth: true
|
|
|
|
Layout.fillHeight: true
|
2019-05-03 04:20:21 +10:00
|
|
|
|
2019-07-13 07:06:37 +10:00
|
|
|
spacing: currentSpacing
|
|
|
|
bottomMargin: currentSpacing
|
2019-03-26 18:19:55 +11:00
|
|
|
}
|
|
|
|
|
2019-07-03 03:59:52 +10:00
|
|
|
PaneToolBar {
|
|
|
|
id: paneToolBar
|
|
|
|
}
|
2019-03-26 18:19:55 +11:00
|
|
|
}
|
|
|
|
}
|