import QtQuick 2.4 import FlightGear.Launcher 1.0 import "." Item { id: root signal showSelectedAircraft(); signal showSelectedLocation(); Rectangle { anchors.fill: parent color: "#7f7f7f" } readonly property string __aircraftDescription: _launcher.selectedAircraftInfo.description PreviewImage { id: preview anchors.centerIn: parent // over-zoom the preview to fill the entire space available readonly property double scale: Math.max(root.width / sourceSize.width, root.height / sourceSize.height) width: height * aspectRatio height: scale * sourceSize.height property var urlsList: _launcher.defaultSplashUrls() property int __currentUrl: 0 Binding on urlsList { when: _launcher.selectedAircraftInfo.previews.length > 0 value: _launcher.selectedAircraftInfo.previews } onUrlsListChanged: { __currentUrl = 0; } Timer { running: true interval: 8000 repeat: true onTriggered: { var len = preview.urlsList.length preview.__currentUrl = (preview.__currentUrl + 1) % len } } function currentUrl() { if (urlsList.length <= __currentUrl) return ""; return urlsList[__currentUrl]; } visible: imageUrl != "" imageUrl: currentUrl() } Text { id: logoText font.pointSize: Style.strutSize * 2 font.italic: true font.bold: true anchors { left: parent.left right: parent.right top: parent.top margins: Style.strutSize } fontSizeMode: Text.Fit text: "FlightGear " + _launcher.versionString color: "white" style: Text.Outline styleColor: "black" } ClickableText { anchors { left: logoText.left right: logoText.right } // anchoring to logoText bottom doesn't work as expected because of // dynamic text sizing, so bind it manually y: logoText.y + Style.margin + logoText.contentHeight wrapMode: Text.WordWrap text: "Licenced under the GNU Public License (GPL) - click for more info" baseTextColor: "white" style: Text.Outline styleColor: "black" font.bold: true font.pixelSize: Style.subHeadingFontPixelSize onClicked: { _launcher.launchUrl("http://home.flightgear.org/about/"); } } Rectangle { id: summaryPanel color: "transparent" border.width: 1 border.color: Style.frameColor clip: true anchors { left: parent.left right: parent.right bottom: parent.bottom margins: Style.strutSize } height: summaryGrid.height + Style.margin * 2 // set opacity here only, so we don't make the whole summary pannel translucent Rectangle { id: background anchors.fill: parent z: -1 opacity: Style.panelOpacity color: "white" } Grid { id: summaryGrid columns: 3 columnSpacing: Style.margin rowSpacing: Style.margin readonly property int middleColumnWidth: summaryGrid.width - (locationLabel.width + Style.margin * 2 + aircraftHistoryPopup.width) anchors { left: parent.left right: parent.right top: parent.top margins: Style.margin } // aircraft name row StyledText { text: qsTr("Aircraft:") horizontalAlignment: Text.AlignRight font.pixelSize: Style.headingFontPixelSize } // TODO - make clickable, jump to to the aircraft in the installed // aircraft list ClickableText { text: _launcher.selectedAircraftInfo.name === "" ? qsTr("No aircraft selected") : _launcher.selectedAircraftInfo.name enabled: _launcher.selectedAircraftInfo.name !== "" font.pixelSize: Style.headingFontPixelSize onClicked: root.showSelectedAircraft(); } HistoryPopup { id: aircraftHistoryPopup model: _launcher.aircraftHistory enabled: !_launcher.aircraftHistory.isEmpty onSelected: { _launcher.selectedAircraft = _launcher.aircraftHistory.uriAt(index) } } // empty space in next row (thumbnail, long aircraft description) Item { width: 1; height: 1 } Item { id: aircraftDetailsRow width: summaryGrid.middleColumnWidth height: Math.max(thumbnail.height, aircraftDescriptionText.height) ThumbnailImage { id: thumbnail aircraftUri: _launcher.selectedAircraft maximumSize.width: 172 maximumSize.height: 128 } StyledText { id: aircraftDescriptionText anchors { left: thumbnail.right leftMargin: Style.margin right: parent.right } text: root.__aircraftDescription visible: root.__aircraftDescription != "" wrapMode: Text.WordWrap maximumLineCount: 5 elide: Text.ElideRight } } Item { width: 1; height: 1 } // aircraft state row, if enabled Item { width: 1; height: 1 visible: stateSelectionGroup.visible } Column { id: stateSelectionGroup visible: _launcher.selectedAircraftInfo.hasStates width: summaryGrid.middleColumnWidth spacing: Style.margin Component.onCompleted: updateComboFromController(); function updateComboFromController() { stateSelectionCombo.currentIndex = _launcher.selectedAircraftInfo.statesModel.indexForTag(_launcher.selectedAircraftState) } PopupChoice { id: stateSelectionCombo model: _launcher.selectedAircraftInfo.statesModel displayRole: "name" label: qsTr("State:") width: parent.width headerText: qsTr("Default state") function select(index) { if (index === -1) { _launcher.selectedAircraftState = ""; } else { _launcher.selectedAircraftState = model.tagForState(index); } } } StyledText { id: stateDescriptionText wrapMode: Text.WordWrap maximumLineCount: 5 elide: Text.ElideRight width: parent.width text: _launcher.selectedAircraftInfo.statesModel.descriptionForState(stateSelectionCombo.currentIndex) } Connections { target: _launcher.selectedAircraftInfo onInfoChanged: stateSelectionGroup.updateComboFromController() } Connections { target: _launcher onSelectedAircraftStateChanged: stateSelectionGroup.updateComboFromController() } // of connections } Item { width: 1; height: 1 visible: stateSelectionGroup.visible } // location summary row StyledText { id: locationLabel text: qsTr("Location:") horizontalAlignment: Text.AlignRight font.pixelSize: Style.headingFontPixelSize } ClickableText { text: _launcher.location.description font.pixelSize: Style.headingFontPixelSize width: summaryGrid.middleColumnWidth onClicked: root.showSelectedLocation() } HistoryPopup { id: locationHistoryPopup model: _launcher.locationHistory enabled: !_launcher.aircraftHistory.isEmpty onSelected: { _launcher.restoreLocation(_launcher.locationHistory.locationAt(index)) } } // settings summary row StyledText { text: qsTr("Settings:") horizontalAlignment: Text.AlignRight font.pixelSize: Style.headingFontPixelSize } StyledText { text: _launcher.combinedSummary.join(", ") font.pixelSize: Style.headingFontPixelSize wrapMode: Text.WordWrap maximumLineCount: 2 elide: Text.ElideRight width: summaryGrid.middleColumnWidth } Item { width: 1; height: 1 } } } }