// SPDX-FileCopyrightText: 2021 Nheko Contributors // SPDX-FileCopyrightText: 2022 Nheko Contributors // SPDX-FileCopyrightText: 2023 Nheko Contributors // // SPDX-License-Identifier: GPL-3.0-or-later import QtQuick 2.12 import QtQuick.Controls 2.5 import QtQuick.Layouts 1.12 import im.nheko 1.0 Container { //Component.onCompleted: { // parent.width = Qt.binding(function() { return calculatedWidth; }) //} id: container property bool singlePageMode: width < 800 property int splitterGrabMargin: Nheko.paddingSmall property alias pageIndex: view.currentIndex property Component handle property Component handleToucharea onSinglePageModeChanged: if (!singlePageMode) pageIndex = 0 Component.onCompleted: { for (var i = 0; i < count - 1; i++) { let handle_ = handle.createObject(contentChildren[i]); let split_ = handleToucharea.createObject(contentChildren[i]); contentChildren[i].width = Qt.binding(function() { return split_.calculatedWidth; }); contentChildren[i].splitterWidth = Qt.binding(function() { return handle_.width; }); } contentChildren[count - 1].width = Qt.binding(function() { if (container.singlePageMode) { return container.width; } else { var w = container.width; for (var i = 0; i < count - 1; i++) { if (contentChildren[i].width) w = w - contentChildren[i].width; } return w; } }); contentChildren[count - 1].splitterWidth = 0; for (var i = 0; i < count; i++) { contentChildren[i].height = Qt.binding(function() { return container.height; }); contentChildren[i].children[0].height = Qt.binding(function() { return container.height; }); } } handle: Rectangle { z: 3 color: Nheko.theme.separator height: container.height width: visible ? 1 : 0 anchors.right: parent.right } handleToucharea: Item { id: splitter property int minimumWidth: parent.minimumWidth property int maximumWidth: parent.maximumWidth property int collapsedWidth: parent.collapsedWidth property bool collapsible: parent.collapsible property int calculatedWidth: { if (!visible) return 0; else if (container.singlePageMode) return container.width; else return (collapsible && x < minimumWidth) ? collapsedWidth : x; } enabled: !container.singlePageMode height: container.height width: 1 x: parent.preferredWidth z: 3 CursorShape { height: parent.height width: container.splitterGrabMargin * 2 x: -container.splitterGrabMargin cursorShape: Qt.SizeHorCursor } DragHandler { id: dragHandler enabled: !container.singlePageMode xAxis.enabled: true yAxis.enabled: false xAxis.minimum: splitter.minimumWidth - 1 xAxis.maximum: splitter.maximumWidth margin: container.splitterGrabMargin grabPermissions: PointerHandler.CanTakeOverFromAnything | PointerHandler.ApprovesTakeOverByHandlersOfSameType onActiveChanged: { if (!active) { splitter.x = splitter.calculatedWidth; splitter.parent.preferredWidth = splitter.calculatedWidth; } } } HoverHandler { enabled: !container.singlePageMode margin: container.splitterGrabMargin } } contentItem: ListView { id: view model: container.contentModel snapMode: ListView.SnapOneItem orientation: ListView.Horizontal highlightRangeMode: ListView.StrictlyEnforceRange interactive: singlePageMode highlightMoveDuration: (container.singlePageMode && !Settings.reducedMotion) ? 200 : 0 currentIndex: container.singlePageMode ? container.pageIndex : 0 boundsBehavior: Flickable.StopAtBounds } }