import QtQuick import QtQuick.Controls import qs.Common import qs.Modals.Common import qs.Services import qs.Widgets DankModal { id: root layerNamespace: "dms:network-info-wired" property bool networkWiredInfoModalVisible: false property string networkID: "" property var networkData: null function showNetworkInfo(id, data) { networkID = id networkData = data networkWiredInfoModalVisible = true open() NetworkService.fetchWiredNetworkInfo(data.uuid) } function hideDialog() { networkWiredInfoModalVisible = false close() networkID = "" networkData = null } visible: networkWiredInfoModalVisible width: 600 height: 500 enableShadow: true onBackgroundClicked: hideDialog() onVisibleChanged: { if (!visible) { networkID = "" networkData = null } } content: Component { Item { anchors.fill: parent Column { anchors.fill: parent anchors.margins: Theme.spacingL spacing: Theme.spacingL Row { width: parent.width Column { width: parent.width - 40 spacing: Theme.spacingXS StyledText { text: I18n.tr("Network Information") font.pixelSize: Theme.fontSizeLarge color: Theme.surfaceText font.weight: Font.Medium } StyledText { text: `Details for "${networkID}"` font.pixelSize: Theme.fontSizeMedium color: Theme.surfaceTextMedium width: parent.width elide: Text.ElideRight } } DankActionButton { iconName: "close" iconSize: Theme.iconSize - 4 iconColor: Theme.surfaceText onClicked: root.hideDialog() } } Rectangle { id: detailsRect width: parent.width height: parent.height - 140 radius: Theme.cornerRadius color: Theme.surfaceHover border.color: Theme.outlineStrong border.width: 1 clip: true DankFlickable { anchors.fill: parent anchors.margins: Theme.spacingM contentHeight: detailsText.contentHeight StyledText { id: detailsText width: parent.width text: NetworkService.networkWiredInfoDetails && NetworkService.networkWiredInfoDetails.replace(/\\n/g, '\n') || "No information available" font.pixelSize: Theme.fontSizeMedium color: Theme.surfaceText wrapMode: Text.WordWrap } } } Item { width: parent.width height: 40 Rectangle { anchors.right: parent.right anchors.verticalCenter: parent.verticalCenter width: Math.max(70, closeText.contentWidth + Theme.spacingM * 2) height: 36 radius: Theme.cornerRadius color: closeArea.containsMouse ? Qt.darker(Theme.primary, 1.1) : Theme.primary StyledText { id: closeText anchors.centerIn: parent text: I18n.tr("Close") font.pixelSize: Theme.fontSizeMedium color: Theme.background font.weight: Font.Medium } MouseArea { id: closeArea anchors.fill: parent hoverEnabled: true cursorShape: Qt.PointingHandCursor onClicked: root.hideDialog() } Behavior on color { ColorAnimation { duration: Theme.shortDuration easing.type: Theme.standardEasing } } } } } } } }