Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
Q
qgroundcontrol
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Valentin Platzgummer
qgroundcontrol
Commits
863e2abe
Commit
863e2abe
authored
Aug 07, 2020
by
DonLakeFlyer
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
More flight mode, vtol mode, armed into main status
parent
3543cd37
Changes
14
Hide whitespace changes
Inline
Side-by-side
Showing
14 changed files
with
196 additions
and
91 deletions
+196
-91
FirmwarePlugin.cc
src/FirmwarePlugin/FirmwarePlugin.cc
+0
-3
FlightModeMenu.qml
src/QmlControls/FlightModeMenu.qml
+7
-4
QGCMenu.qml
src/QmlControls/QGCMenu.qml
+1
-1
TrajectoryPoints.cc
src/Vehicle/TrajectoryPoints.cc
+0
-1
MainRootWindow.qml
src/ui/MainRootWindow.qml
+15
-15
BatteryIndicator.qml
src/ui/toolbar/BatteryIndicator.qml
+1
-1
GPSIndicator.qml
src/ui/toolbar/GPSIndicator.qml
+1
-1
GPSRTKIndicator.qml
src/ui/toolbar/GPSRTKIndicator.qml
+1
-1
JoystickIndicator.qml
src/ui/toolbar/JoystickIndicator.qml
+1
-1
MainStatusIndicator.qml
src/ui/toolbar/MainStatusIndicator.qml
+160
-53
MainToolBar.qml
src/ui/toolbar/MainToolBar.qml
+5
-6
RCRSSIIndicator.qml
src/ui/toolbar/RCRSSIIndicator.qml
+1
-1
ROIIndicator.qml
src/ui/toolbar/ROIIndicator.qml
+2
-2
TelemetryRSSIIndicator.qml
src/ui/toolbar/TelemetryRSSIIndicator.qml
+1
-1
No files found.
src/FirmwarePlugin/FirmwarePlugin.cc
View file @
863e2abe
...
@@ -320,9 +320,6 @@ const QVariantList& FirmwarePlugin::modeIndicators(const Vehicle*)
...
@@ -320,9 +320,6 @@ const QVariantList& FirmwarePlugin::modeIndicators(const Vehicle*)
if
(
_modeIndicatorList
.
size
()
==
0
)
{
if
(
_modeIndicatorList
.
size
()
==
0
)
{
_modeIndicatorList
=
QVariantList
({
_modeIndicatorList
=
QVariantList
({
QVariant
::
fromValue
(
QUrl
::
fromUserInput
(
"qrc:/toolbar/ROIIndicator.qml"
)),
QVariant
::
fromValue
(
QUrl
::
fromUserInput
(
"qrc:/toolbar/ROIIndicator.qml"
)),
QVariant
::
fromValue
(
QUrl
::
fromUserInput
(
"qrc:/toolbar/ArmedIndicator.qml"
)),
QVariant
::
fromValue
(
QUrl
::
fromUserInput
(
"qrc:/toolbar/ModeIndicator.qml"
)),
QVariant
::
fromValue
(
QUrl
::
fromUserInput
(
"qrc:/toolbar/VTOLModeIndicator.qml"
)),
QVariant
::
fromValue
(
QUrl
::
fromUserInput
(
"qrc:/toolbar/MultiVehicleSelector.qml"
)),
QVariant
::
fromValue
(
QUrl
::
fromUserInput
(
"qrc:/toolbar/MultiVehicleSelector.qml"
)),
QVariant
::
fromValue
(
QUrl
::
fromUserInput
(
"qrc:/toolbar/LinkIndicator.qml"
)),
QVariant
::
fromValue
(
QUrl
::
fromUserInput
(
"qrc:/toolbar/LinkIndicator.qml"
)),
});
});
...
...
src/QmlControls/FlightModeMenu.qml
View file @
863e2abe
...
@@ -19,7 +19,8 @@ QGCLabel {
...
@@ -19,7 +19,8 @@ QGCLabel {
id
:
flightModeMenuLabel
id
:
flightModeMenuLabel
text
:
currentVehicle
?
currentVehicle
.
flightMode
:
qsTr
(
"
N/A
"
,
"
No data to display
"
)
text
:
currentVehicle
?
currentVehicle
.
flightMode
:
qsTr
(
"
N/A
"
,
"
No data to display
"
)
property
var
currentVehicle
:
QGroundControl
.
multiVehicleManager
.
activeVehicle
property
var
currentVehicle
:
QGroundControl
.
multiVehicleManager
.
activeVehicle
property
real
mouseAreaLeftMargin
:
0
QGCMenu
{
QGCMenu
{
id
:
flightModesMenu
id
:
flightModesMenu
...
@@ -60,8 +61,10 @@ QGCLabel {
...
@@ -60,8 +61,10 @@ QGCLabel {
}
}
MouseArea
{
MouseArea
{
visible
:
currentVehicle
&&
currentVehicle
.
flightModeSetAvailable
id
:
mouseArea
anchors.fill
:
parent
visible
:
currentVehicle
&&
currentVehicle
.
flightModeSetAvailable
onClicked
:
flightModesMenu
.
popup
()
anchors.leftMargin
:
mouseAreaLeftMargin
anchors.fill
:
parent
onClicked
:
flightModesMenu
.
popup
()
}
}
}
}
src/QmlControls/QGCMenu.qml
View file @
863e2abe
//
QtQuick.Control 1.x
Menu
//
Use old QtQuick.Control 1.x Menu to work around bug in new Qml
Menu
import
QtQuick
2.6
import
QtQuick
2.6
import
QtQuick
.
Controls
1.4
import
QtQuick
.
Controls
1.4
...
...
src/Vehicle/TrajectoryPoints.cc
View file @
863e2abe
...
@@ -59,7 +59,6 @@ void TrajectoryPoints::start(void)
...
@@ -59,7 +59,6 @@ void TrajectoryPoints::start(void)
void
TrajectoryPoints
::
stop
(
void
)
void
TrajectoryPoints
::
stop
(
void
)
{
{
qDebug
()
<<
"Stop"
<<
_points
.
count
();
disconnect
(
_vehicle
,
&
Vehicle
::
coordinateChanged
,
this
,
&
TrajectoryPoints
::
_vehicleCoordinateChanged
);
disconnect
(
_vehicle
,
&
Vehicle
::
coordinateChanged
,
this
,
&
TrajectoryPoints
::
_vehicleCoordinateChanged
);
}
}
...
...
src/ui/MainRootWindow.qml
View file @
863e2abe
...
@@ -758,20 +758,20 @@ ApplicationWindow {
...
@@ -758,20 +758,20 @@ ApplicationWindow {
//-------------------------------------------------------------------------
//-------------------------------------------------------------------------
//-- Indicator Popups
//-- Indicator Popups
function
show
PopU
p
(
item
,
dropItem
)
{
function
show
IndicatorPopu
p
(
item
,
dropItem
)
{
indicator
Dropdown
.
currentIndicator
=
dropItem
indicator
Popup
.
currentIndicator
=
dropItem
indicator
Dropdown
.
currentItem
=
item
indicator
Popup
.
currentItem
=
item
indicator
Dropdown
.
open
()
indicator
Popup
.
open
()
}
}
function
hide
PopU
p
()
{
function
hide
IndicatorPopu
p
()
{
indicator
Dropdown
.
close
()
indicator
Popup
.
close
()
indicator
Dropdown
.
currentItem
=
null
indicator
Popup
.
currentItem
=
null
indicator
Dropdown
.
currentIndicator
=
null
indicator
Popup
.
currentIndicator
=
null
}
}
Popup
{
Popup
{
id
:
indicator
Dropdown
id
:
indicator
Popup
padding
:
ScreenTools
.
defaultFontPixelWidth
*
0.75
padding
:
ScreenTools
.
defaultFontPixelWidth
*
0.75
modal
:
true
modal
:
true
focus
:
true
focus
:
true
...
@@ -786,19 +786,19 @@ ApplicationWindow {
...
@@ -786,19 +786,19 @@ ApplicationWindow {
Loader
{
Loader
{
id
:
loader
id
:
loader
onLoaded
:
{
onLoaded
:
{
var
centerX
=
mainWindow
.
contentItem
.
mapFromItem
(
indicator
Dropdown
.
currentItem
,
0
,
0
).
x
-
(
loader
.
width
*
0.5
)
var
centerX
=
mainWindow
.
contentItem
.
mapFromItem
(
indicator
Popup
.
currentItem
,
0
,
0
).
x
-
(
loader
.
width
*
0.5
)
if
((
centerX
+
indicator
Dropdown
.
width
)
>
(
mainWindow
.
width
-
ScreenTools
.
defaultFontPixelWidth
))
{
if
((
centerX
+
indicator
Popup
.
width
)
>
(
mainWindow
.
width
-
ScreenTools
.
defaultFontPixelWidth
))
{
centerX
=
mainWindow
.
width
-
indicator
Dropdown
.
width
-
ScreenTools
.
defaultFontPixelWidth
centerX
=
mainWindow
.
width
-
indicator
Popup
.
width
-
ScreenTools
.
defaultFontPixelWidth
}
}
indicator
Dropdown
.
x
=
centerX
indicator
Popup
.
x
=
centerX
}
}
}
}
onOpened
:
{
onOpened
:
{
loader
.
sourceComponent
=
indicator
Dropdown
.
currentIndicator
loader
.
sourceComponent
=
indicator
Popup
.
currentIndicator
}
}
onClosed
:
{
onClosed
:
{
loader
.
sourceComponent
=
null
loader
.
sourceComponent
=
null
indicator
Dropdown
.
currentIndicator
=
null
indicator
Popup
.
currentIndicator
=
null
}
}
}
}
}
}
src/ui/toolbar/BatteryIndicator.qml
View file @
863e2abe
...
@@ -120,7 +120,7 @@ Item {
...
@@ -120,7 +120,7 @@ Item {
MouseArea
{
MouseArea
{
anchors.fill
:
parent
anchors.fill
:
parent
onClicked
:
{
onClicked
:
{
mainWindow
.
show
PopU
p
(
_root
,
batteryInfo
)
mainWindow
.
show
IndicatorPopu
p
(
_root
,
batteryInfo
)
}
}
}
}
}
}
src/ui/toolbar/GPSIndicator.qml
View file @
863e2abe
...
@@ -109,7 +109,7 @@ Item {
...
@@ -109,7 +109,7 @@ Item {
MouseArea
{
MouseArea
{
anchors.fill
:
parent
anchors.fill
:
parent
onClicked
:
{
onClicked
:
{
mainWindow
.
show
PopU
p
(
_root
,
gpsInfo
)
mainWindow
.
show
IndicatorPopu
p
(
_root
,
gpsInfo
)
}
}
}
}
}
}
src/ui/toolbar/GPSRTKIndicator.qml
View file @
863e2abe
...
@@ -109,7 +109,7 @@ Item {
...
@@ -109,7 +109,7 @@ Item {
MouseArea
{
MouseArea
{
anchors.fill
:
parent
anchors.fill
:
parent
onClicked
:
{
onClicked
:
{
mainWindow
.
show
PopU
p
(
_root
,
gpsInfo
)
mainWindow
.
show
IndicatorPopu
p
(
_root
,
gpsInfo
)
}
}
}
}
}
}
src/ui/toolbar/JoystickIndicator.qml
View file @
863e2abe
...
@@ -91,7 +91,7 @@ Item {
...
@@ -91,7 +91,7 @@ Item {
MouseArea
{
MouseArea
{
anchors.fill
:
parent
anchors.fill
:
parent
onClicked
:
{
onClicked
:
{
mainWindow
.
show
PopU
p
(
_root
,
joystickInfo
)
mainWindow
.
show
IndicatorPopu
p
(
_root
,
joystickInfo
)
}
}
}
}
}
}
src/ui/toolbar/MainStatusIndicator.qml
View file @
863e2abe
...
@@ -16,57 +16,21 @@ import QGroundControl.MultiVehicleManager 1.0
...
@@ -16,57 +16,21 @@ import QGroundControl.MultiVehicleManager 1.0
import
QGroundControl
.
ScreenTools
1.0
import
QGroundControl
.
ScreenTools
1.0
import
QGroundControl
.
Palette
1.0
import
QGroundControl
.
Palette
1.0
Item
{
RowLayout
{
id
:
_root
id
:
_root
Layout.preferredWidth
:
mainStatusLabel
.
contentWidth
+
ScreenTools
.
defaultFontPixelWidth
spacing
:
0
property
var
_activeVehicle
:
QGroundControl
.
multiVehicleManager
.
activeVehicle
property
var
_activeVehicle
:
QGroundControl
.
multiVehicleManager
.
activeVehicle
property
real
_margins
:
ScreenTools
.
defaultFontPixelWidth
property
var
_vehicleInAir
:
_activeVehicle
?
_activeVehicle
.
flying
||
_activeVehicle
.
landing
:
false
property
bool
_vtolInFWDFlight
:
_activeVehicle
?
_activeVehicle
.
vtolInFwdFlight
:
false
Component
{
property
bool
_armed
:
_activeVehicle
?
_activeVehicle
.
armed
:
false
id
:
mainStatusInfo
property
real
_margins
:
ScreenTools
.
defaultFontPixelWidth
property
real
_spacing
:
ScreenTools
.
defaultFontPixelWidth
/
2
Rectangle
{
width
:
mainLayout
.
width
+
(
_margins
*
2
)
height
:
mainLayout
.
height
+
(
_margins
*
2
)
radius
:
ScreenTools
.
defaultFontPixelHeight
*
0.5
color
:
qgcPal
.
window
border.color
:
qgcPal
.
text
GridLayout
{
id
:
mainLayout
anchors.margins
:
_margins
anchors.top
:
parent
.
top
anchors.left
:
parent
.
left
rowSpacing
:
ScreenTools
.
defaultFontPixelWidth
/
2
columnSpacing
:
rowSpacing
rows
:
_activeVehicle
.
sysStatusSensorInfo
.
sensorNames
.
length
flow
:
GridLayout
.
TopToBottom
Repeater
{
model
:
_activeVehicle
.
sysStatusSensorInfo
.
sensorNames
QGCLabel
{
text
:
modelData
}
}
Repeater
{
model
:
_activeVehicle
.
sysStatusSensorInfo
.
sensorStatus
QGCLabel
{
text
:
modelData
}
}
}
}
}
QGCLabel
{
QGCLabel
{
id
:
mainStatusLabel
id
:
mainStatusLabel
text
:
mainStatusText
()
text
:
mainStatusText
()
font.pointSize
:
ScreenTools
.
largeFontPointSize
font.pointSize
:
_vehicleInAir
?
ScreenTools
.
defaultFontPointSize
:
ScreenTools
.
largeFontPointSize
anchors.verticalCenter
:
parent
.
verticalCenter
property
string
_commLostText
:
qsTr
(
"
Communication Lost
"
)
property
string
_commLostText
:
qsTr
(
"
Communication Lost
"
)
property
string
_readyToFlyText
:
qsTr
(
"
Ready To Fly
"
)
property
string
_readyToFlyText
:
qsTr
(
"
Ready To Fly
"
)
...
@@ -117,13 +81,156 @@ Item {
...
@@ -117,13 +81,156 @@ Item {
return
mainStatusLabel
.
_disconnectedText
return
mainStatusLabel
.
_disconnectedText
}
}
}
}
MouseArea
{
anchors.left
:
parent
.
left
anchors.right
:
parent
.
right
anchors.verticalCenter
:
parent
.
verticalCenter
height
:
_root
.
height
enabled
:
_activeVehicle
onClicked
:
mainWindow
.
showIndicatorPopup
(
mainStatusLabel
,
sensorStatusInfoComponent
)
}
}
Item
{
width
:
ScreenTools
.
defaultFontPixelWidth
height
:
1
}
QGCColoredImage
{
id
:
flightModeIcon
width
:
height
height
:
ScreenTools
.
defaultFontPixelHeight
*
0.75
fillMode
:
Image
.
PreserveAspectFit
mipmap
:
true
color
:
qgcPal
.
text
source
:
"
/qmlimages/FlightModesComponentIcon.png
"
visible
:
_activeVehicle
}
Item
{
Layout.preferredWidth
:
ScreenTools
.
defaultFontPixelWidth
*
(
_vehicleInAir
?
ScreenTools
.
largeFontPointRatio
:
1
)
/
3
height
:
1
visible
:
flightModeMenu
.
visible
}
FlightModeMenu
{
id
:
flightModeMenu
Layout.preferredHeight
:
_root
.
height
verticalAlignment
:
Text
.
AlignVCenter
font.pointSize
:
_vehicleInAir
?
ScreenTools
.
largeFontPointSize
:
ScreenTools
.
defaultFontPointSize
mouseAreaLeftMargin
:
-
(
flightModeMenu
.
x
-
flightModeIcon
.
x
)
visible
:
_activeVehicle
}
Item
{
Layout.preferredWidth
:
ScreenTools
.
defaultFontPixelWidth
*
ScreenTools
.
largeFontPointRatio
height
:
1
visible
:
vtolModeLabel
.
visible
}
}
MouseArea
{
QGCLabel
{
anchors.fill
:
parent
id
:
vtolModeLabel
enabled
:
_activeVehicle
Layout.preferredHeight
:
_root
.
height
onClicked
:
{
verticalAlignment
:
Text
.
AlignVCenter
mainWindow
.
showPopUp
(
_root
,
mainStatusInfo
)
text
:
_vtolInFWDFlight
?
qsTr
(
"
FW(vtol)
"
)
:
qsTr
(
"
MR(vtol)
"
)
font.pointSize
:
ScreenTools
.
largeFontPointSize
visible
:
_activeVehicle
?
_activeVehicle
.
vtol
&&
_vehicleInAir
:
false
QGCMouseArea
{
anchors.fill
:
parent
onClicked
:
mainWindow
.
showIndicatorPopup
(
vtolModeLabel
,
vtolTransitionComponent
)
}
}
Component
{
id
:
sensorStatusInfoComponent
Rectangle
{
width
:
mainLayout
.
width
+
(
_margins
*
2
)
height
:
mainLayout
.
height
+
(
_margins
*
2
)
radius
:
ScreenTools
.
defaultFontPixelHeight
*
0.5
color
:
qgcPal
.
window
border.color
:
qgcPal
.
text
ColumnLayout
{
id
:
mainLayout
anchors.margins
:
_margins
anchors.top
:
parent
.
top
anchors.left
:
parent
.
left
spacing
:
_spacing
QGCLabel
{
Layout.alignment
:
Qt
.
AlignHCenter
text
:
qsTr
(
"
Sensor Status
"
)
}
GridLayout
{
rowSpacing
:
_spacing
columnSpacing
:
_spacing
rows
:
_activeVehicle
.
sysStatusSensorInfo
.
sensorNames
.
length
flow
:
GridLayout
.
TopToBottom
Repeater
{
model
:
_activeVehicle
.
sysStatusSensorInfo
.
sensorNames
QGCLabel
{
text
:
modelData
}
}
Repeater
{
model
:
_activeVehicle
.
sysStatusSensorInfo
.
sensorStatus
QGCLabel
{
text
:
modelData
}
}
}
QGCButton
{
Layout.alignment
:
Qt
.
AlignHCenter
text
:
_armed
?
qsTr
(
"
Disarm
"
)
:
qsTr
(
"
Arm
"
)
onClicked
:
{
if
(
_armed
)
{
mainWindow
.
disarmVehicleRequest
()
}
else
{
mainWindow
.
armVehicleRequest
()
}
mainWindow
.
hideIndicatorPopup
()
}
}
}
}
}
Component
{
id
:
vtolTransitionComponent
Rectangle
{
width
:
mainLayout
.
width
+
(
_margins
*
2
)
height
:
mainLayout
.
height
+
(
_margins
*
2
)
radius
:
ScreenTools
.
defaultFontPixelHeight
*
0.5
color
:
qgcPal
.
window
border.color
:
qgcPal
.
text
QGCButton
{
id
:
mainLayout
anchors.margins
:
_margins
anchors.top
:
parent
.
top
anchors.left
:
parent
.
left
text
:
_vtolInFWDFlight
?
qsTr
(
"
Transition to Multi-Rotor
"
)
:
qsTr
(
"
Transition to Fixed Wing
"
)
onClicked
:
{
if
(
_vtolInFWDFlight
)
{
mainWindow
.
vtolTransitionToMRFlightRequest
()
}
else
{
mainWindow
.
vtolTransitionToFwdFlightRequest
()
}
mainWindow
.
hideIndicatorPopup
()
}
}
}
}
}
}
}
}
src/ui/toolbar/MainToolBar.qml
View file @
863e2abe
...
@@ -87,19 +87,18 @@ Rectangle {
...
@@ -87,19 +87,18 @@ Rectangle {
spacing
:
ScreenTools
.
defaultFontPixelWidth
/
2
spacing
:
ScreenTools
.
defaultFontPixelWidth
/
2
QGCToolBarButton
{
QGCToolBarButton
{
id
:
currentButton
id
:
currentButton
Layout.
fillHeight
:
true
Layout.
preferredHeight
:
viewButtonRow
.
height
onClicked
:
viewSelectDrawer
.
visible
=
true
onClicked
:
viewSelectDrawer
.
visible
=
true
}
}
MainStatusIndicator
{
MainStatusIndicator
{
Layout.
fillHeight
:
true
Layout.
preferredHeight
:
viewButtonRow
.
height
visible
:
currentToolbar
===
flyViewToolbar
visible
:
currentToolbar
===
flyViewToolbar
}
}
QGCButton
{
QGCButton
{
id
:
disconnectButton
id
:
disconnectButton
Layout.alignment
:
Qt
.
AlignVCenter
text
:
qsTr
(
"
Disconnect
"
)
text
:
qsTr
(
"
Disconnect
"
)
onClicked
:
_activeVehicle
.
disconnectInactiveVehicle
()
onClicked
:
_activeVehicle
.
disconnectInactiveVehicle
()
visible
:
_activeVehicle
&&
_communicationLost
&&
currentToolbar
===
flyViewToolbar
visible
:
_activeVehicle
&&
_communicationLost
&&
currentToolbar
===
flyViewToolbar
...
...
src/ui/toolbar/RCRSSIIndicator.qml
View file @
863e2abe
...
@@ -95,7 +95,7 @@ Item {
...
@@ -95,7 +95,7 @@ Item {
MouseArea
{
MouseArea
{
anchors.fill
:
parent
anchors.fill
:
parent
onClicked
:
{
onClicked
:
{
mainWindow
.
show
PopU
p
(
_root
,
rcRSSIInfo
)
mainWindow
.
show
IndicatorPopu
p
(
_root
,
rcRSSIInfo
)
}
}
}
}
}
}
src/ui/toolbar/ROIIndicator.qml
View file @
863e2abe
...
@@ -61,7 +61,7 @@ Item {
...
@@ -61,7 +61,7 @@ Item {
onClicked
:
{
onClicked
:
{
if
(
activeVehicle
)
if
(
activeVehicle
)
activeVehicle
.
stopGuidedModeROI
()
activeVehicle
.
stopGuidedModeROI
()
mainWindow
.
hide
PopU
p
()
mainWindow
.
hide
IndicatorPopu
p
()
}
}
}
}
}
}
...
@@ -83,7 +83,7 @@ Item {
...
@@ -83,7 +83,7 @@ Item {
MouseArea
{
MouseArea
{
anchors.fill
:
parent
anchors.fill
:
parent
onClicked
:
{
onClicked
:
{
mainWindow
.
show
PopU
p
(
_root
,
roiInfo
)
mainWindow
.
show
IndicatorPopu
p
(
_root
,
roiInfo
)
}
}
}
}
}
}
src/ui/toolbar/TelemetryRSSIIndicator.qml
View file @
863e2abe
...
@@ -86,7 +86,7 @@ Item {
...
@@ -86,7 +86,7 @@ Item {
MouseArea
{
MouseArea
{
anchors.fill
:
parent
anchors.fill
:
parent
onClicked
:
{
onClicked
:
{
mainWindow
.
show
PopU
p
(
_root
,
telemRSSIInfo
)
mainWindow
.
show
IndicatorPopu
p
(
_root
,
telemRSSIInfo
)
}
}
}
}
}
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment