import QtQuick import QtQuick.Controls import QtQuick.Layouts import SortFilterProxyModel 0.2 import PageEnum 1.0 import ContainerProps 1.0 import ProtocolProps 1.0 import "./" import "../Controls2" import "../Controls2/TextTypes" import "../Config" import "../Components" PageType { id: root SortFilterProxyModel { id: proxyContainersModel sourceModel: ContainersModel filters: [ ValueFilter { roleName: "isCurrentlyProcessed" value: true } ] } FlickableType { anchors.fill: parent contentHeight: content.height Column { id: content anchors.top: parent.top anchors.left: parent.left anchors.right: parent.right ListView { id: processedContainerListView width: parent.width height: contentItem.height currentIndex: -1 clip: true interactive: false model: proxyContainersModel delegate: Item { implicitWidth: processedContainerListView.width implicitHeight: (delegateContent.implicitHeight > root.height) ? delegateContent.implicitHeight : root.height ColumnLayout { id: delegateContent anchors.fill: parent anchors.rightMargin: 16 anchors.leftMargin: 16 BackButtonType { id: backButton Layout.topMargin: 20 Layout.rightMargin: -16 Layout.leftMargin: -16 } HeaderType { id: header Layout.fillWidth: true headerText: qsTr("Installing %1").arg(name) descriptionText: description } BasicButtonType { id: showDetailsButton Layout.topMargin: 16 Layout.leftMargin: -8 implicitHeight: 32 defaultColor: "transparent" hoveredColor: Qt.rgba(1, 1, 1, 0.08) pressedColor: Qt.rgba(1, 1, 1, 0.12) disabledColor: "#878B91" textColor: "#FBB26A" text: qsTr("More detailed") onClicked: { showDetailsDrawer.open() } } DrawerType { id: showDetailsDrawer width: parent.width height: parent.height * 0.9 BackButtonType { id: showDetailsBackButton anchors.top: parent.top anchors.left: parent.left anchors.right: parent.right anchors.topMargin: 16 backButtonFunction: function() { showDetailsDrawer.close() } } FlickableType { anchors.top: showDetailsBackButton.bottom anchors.left: parent.left anchors.right: parent.right anchors.bottom: parent.bottom contentHeight: { var emptySpaceHeight = parent.height - showDetailsBackButton.implicitHeight - showDetailsBackButton.anchors.topMargin return (showDetailsDrawerContent.height > emptySpaceHeight) ? showDetailsDrawerContent.height : emptySpaceHeight } ColumnLayout { id: showDetailsDrawerContent anchors.top: parent.top anchors.left: parent.left anchors.right: parent.right anchors.rightMargin: 16 anchors.leftMargin: 16 Header2Type { id: showDetailsDrawerHeader Layout.fillWidth: true Layout.topMargin: 16 headerText: name } ParagraphTextType { Layout.fillWidth: true Layout.topMargin: 16 Layout.bottomMargin: 16 text: detailedDescription textFormat: Text.MarkdownText } Rectangle { Layout.fillHeight: true color: "transparent" } BasicButtonType { Layout.fillWidth: true Layout.bottomMargin: 32 text: qsTr("Close") onClicked: function() { showDetailsDrawer.close() } } } } } ParagraphTextType { id: transportProtoHeader Layout.topMargin: 16 text: qsTr("Network protocol") } TransportProtoSelector { id: transportProtoSelector Layout.fillWidth: true rootWidth: root.width } TextFieldWithHeaderType { id: port Layout.fillWidth: true Layout.topMargin: 16 headerText: qsTr("Port") textField.maximumLength: 5 textField.validator: IntValidator { bottom: 1; top: 65535 } } Rectangle { Layout.fillHeight: true color: "transparent" } BasicButtonType { id: installButton Layout.fillWidth: true Layout.bottomMargin: 32 text: qsTr("Install") onClicked: function() { PageController.goToPage(PageEnum.PageSetupWizardInstalling); InstallController.install(dockerContainer, port.textFieldText, transportProtoSelector.currentIndex) } } Component.onCompleted: { var defaultContainerProto = ContainerProps.defaultProtocol(dockerContainer) if (ProtocolProps.defaultPort(defaultContainerProto) < 0) { port.visible = false } else { port.textFieldText = ProtocolProps.defaultPort(defaultContainerProto) } transportProtoSelector.currentIndex = ProtocolProps.defaultTransportProto(defaultContainerProto) port.enabled = ProtocolProps.defaultPortChangeable(defaultContainerProto) var protocolSelectorVisible = ProtocolProps.defaultTransportProtoChangeable(defaultContainerProto) transportProtoSelector.visible = protocolSelectorVisible transportProtoHeader.visible = protocolSelectorVisible } } } } } } }