2021-05-04 21:31:15 +03:00
|
|
|
import QtQuick 2.14
|
|
|
|
import QtQuick.Window 2.14
|
|
|
|
import QtQuick.Controls 2.14
|
2021-05-27 19:06:50 +02:00
|
|
|
import QtGraphicalEffects 1.13
|
2021-05-04 21:31:15 +03:00
|
|
|
|
2021-05-20 09:25:52 +03:00
|
|
|
import Sandbox 0.1
|
|
|
|
|
2021-05-04 21:31:15 +03:00
|
|
|
import StatusQ.Core 0.1
|
|
|
|
import StatusQ.Core.Theme 0.1
|
2021-05-27 19:06:50 +02:00
|
|
|
import StatusQ.Controls 0.1
|
|
|
|
import StatusQ.Components 0.1
|
|
|
|
import StatusQ.Layout 0.1
|
2021-06-01 13:01:47 +03:00
|
|
|
import StatusQ.Platform 0.1
|
2021-05-04 21:31:15 +03:00
|
|
|
|
2021-05-20 09:25:52 +03:00
|
|
|
StatusWindow {
|
2021-05-04 21:31:15 +03:00
|
|
|
id: rootWindow
|
2021-06-15 11:16:22 +02:00
|
|
|
width: Qt.platform.os == "ios" || Qt.platform.os == "android" ? Screen.width
|
|
|
|
: 1024
|
|
|
|
height: Qt.platform.os == "ios" || Qt.platform.os == "android" ? Screen.height
|
|
|
|
:840
|
2021-05-04 21:31:15 +03:00
|
|
|
visible: true
|
2021-05-27 19:06:50 +02:00
|
|
|
title: qsTr("StatusQ Documentation App")
|
2021-05-04 21:31:15 +03:00
|
|
|
|
2021-05-17 13:18:41 +03:00
|
|
|
property ThemePalette lightTheme: StatusLightTheme {}
|
2021-05-27 19:06:50 +02:00
|
|
|
property ThemePalette darkTheme: StatusDarkTheme {}
|
2021-05-17 13:18:41 +03:00
|
|
|
|
2021-05-27 19:06:50 +02:00
|
|
|
readonly property real maxFactor: 2.0
|
|
|
|
readonly property real minFactor: 0.5
|
2021-05-04 21:31:15 +03:00
|
|
|
|
2021-05-27 19:06:50 +02:00
|
|
|
property real factor: 1.0
|
2021-05-17 13:18:41 +03:00
|
|
|
|
2021-05-27 19:06:50 +02:00
|
|
|
Component.onCompleted: {
|
|
|
|
Theme.palette = lightTheme
|
|
|
|
apiDocsButton.checked = true
|
2021-06-01 13:01:47 +03:00
|
|
|
|
|
|
|
rootWindow.updatePosition();
|
2021-05-27 19:06:50 +02:00
|
|
|
}
|
2021-05-17 13:18:41 +03:00
|
|
|
|
2021-05-27 19:06:50 +02:00
|
|
|
StatusAppLayout {
|
|
|
|
id: appLayout
|
|
|
|
anchors.fill: parent
|
|
|
|
|
|
|
|
appNavBar: StatusAppNavBar {
|
|
|
|
height: rootWindow.height
|
2021-06-03 16:14:52 +02:00
|
|
|
|
|
|
|
navBarChatButton: StatusNavBarTabButton {
|
|
|
|
icon.name: "refresh"
|
|
|
|
tooltip.text: "Reload App"
|
|
|
|
onClicked: app.restartQml()
|
|
|
|
}
|
|
|
|
|
2021-05-27 19:06:50 +02:00
|
|
|
navBarTabButtons: [
|
|
|
|
StatusNavBarTabButton {
|
|
|
|
id: apiDocsButton
|
|
|
|
icon.name: "edit"
|
|
|
|
tooltip.text: "API Documentation"
|
|
|
|
onClicked: {
|
|
|
|
stackView.clear()
|
|
|
|
stackView.push(libraryDocumentationCmp)
|
|
|
|
checked = !checked
|
|
|
|
demoAppButton.checked = false
|
|
|
|
}
|
2021-05-31 14:55:01 +02:00
|
|
|
},
|
|
|
|
StatusNavBarTabButton {
|
|
|
|
id: demoAppButton
|
|
|
|
icon.name: "status"
|
|
|
|
tooltip.text: "Demo Application"
|
|
|
|
checked: stackView.currentItem == demoAppCmp
|
|
|
|
onClicked: {
|
|
|
|
stackView.clear()
|
|
|
|
stackView.push(demoAppCmp)
|
|
|
|
checked = !checked
|
|
|
|
apiDocsButton.checked = false
|
|
|
|
}
|
2021-05-27 19:06:50 +02:00
|
|
|
}
|
|
|
|
]
|
2021-05-05 09:37:01 +02:00
|
|
|
}
|
2021-05-17 13:18:41 +03:00
|
|
|
|
2021-05-27 19:06:50 +02:00
|
|
|
appView: StackView {
|
|
|
|
id: stackView
|
|
|
|
anchors.fill: parent
|
|
|
|
initialItem: libraryDocumentationCmp
|
2021-05-17 13:18:41 +03:00
|
|
|
}
|
|
|
|
|
2021-05-27 19:06:50 +02:00
|
|
|
ThemeSwitch {
|
|
|
|
anchors.top: parent.top
|
2021-05-21 14:38:47 +02:00
|
|
|
anchors.topMargin: 32
|
2021-05-27 19:06:50 +02:00
|
|
|
anchors.right: parent.right
|
|
|
|
anchors.rightMargin: 32
|
|
|
|
onCheckedChanged: {
|
|
|
|
if (Theme.palette === rootWindow.lightTheme) {
|
|
|
|
Theme.palette = rootWindow.darkTheme
|
|
|
|
} else {
|
|
|
|
Theme.palette = rootWindow.lightTheme
|
2021-05-04 21:31:15 +03:00
|
|
|
}
|
|
|
|
}
|
2021-05-27 19:06:50 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Component {
|
|
|
|
id: libraryDocumentationCmp
|
|
|
|
|
|
|
|
StatusAppTwoPanelLayout {
|
|
|
|
|
|
|
|
leftPanel: Item {
|
|
|
|
anchors.fill: parent
|
|
|
|
ScrollView {
|
|
|
|
anchors.top: parent.top
|
|
|
|
anchors.bottom: parent.bottom
|
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
contentHeight: navigation.height + 56
|
|
|
|
contentWidth: navigation.width
|
|
|
|
clip: true
|
|
|
|
Column {
|
|
|
|
id: navigation
|
|
|
|
anchors.top: parent.top
|
|
|
|
anchors.topMargin: 48
|
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
spacing: 0
|
|
|
|
|
2021-06-17 15:04:18 +02:00
|
|
|
StatusListSectionHeadline { text: "StatusQ.Core" }
|
2021-05-27 19:06:50 +02:00
|
|
|
StatusNavigationListItem {
|
|
|
|
title: "Icons"
|
|
|
|
selected: page.sourceComponent == iconsComponent
|
|
|
|
onClicked: page.sourceComponent = iconsComponent
|
|
|
|
}
|
|
|
|
|
2021-06-17 15:04:18 +02:00
|
|
|
StatusListSectionHeadline { text: "StatusQ.Layout" }
|
2021-05-27 19:06:50 +02:00
|
|
|
StatusNavigationListItem {
|
|
|
|
title: "Layouts"
|
|
|
|
selected: page.sourceComponent == layoutComponent
|
|
|
|
onClicked: page.sourceComponent = layoutComponent
|
|
|
|
}
|
feat(Layout): introduce StatusAppNavBar
This commit introduces a new `StatusAppNavBar` component that can be used
to create a Status application's tab bar for dedicated tab sections such as
chat, profile, wallet etc.
The component is build in a way that it support declarative and imperative usage
where necessary.
In its most simple form, a `StatusAppNavBar` comes with a single tab button
for the chat section. Such button has to be of type `StatusNavBarTabButton`:
```qml
import StatusQ.Layout 0.1
StatusAppNavBar {
navBarChatButton: StatusNavBarTabButton {
icon.name: "chat"
badge.value: 33
badge.visible: true
tooltip.text: "Chat"
}
}
```
In addition, it's possible to specify a list of `StatusNavBarTabButton` for
other sections of the application using the `navBarTabButtons` property:
```qml
StatusAppNavBar {
...
navBarTabButtons: [
StatusNavBarTabButton {
icon.name: "wallet"
tooltip.text: "Wallet"
},
StatusNavBarTabButton {
icon.name: "browser"
tooltip.text: "Browser"
},
StatusNavBarTabButton {
icon.name: "status-update"
tooltip.text: "Timeline"
}
]
}
```
Lastly, when desired to render tabs for Status community, which can grow
in size, `StatusAppNavBar` exposes a list via the `navBarCommunityTabButtons`
property that can have a `model` and a `delegate`. The `delegate` should also
be a `StatusNavBarTabButton`:
```qml
StatusAppNavBar {
...
navBarCommunityTabButtons.model: someModel.communities
navBarCommunityTabButtons.delegate: StatusNavBarTabButton {
name: model.name
tooltip.text: model.name
anchors.horizontalCenter: parent.horizontalCenter
}
}
```
The amount of community tab buttons can grow as they need until their dedicated
area becomes scrollable, at which point all `navBarTabButtons` will stick to the
bottom of `StatusAppNavBar`.
Closes #18
2021-05-11 16:25:46 +02:00
|
|
|
|
2021-06-17 15:04:18 +02:00
|
|
|
StatusListSectionHeadline { text: "StatusQ.Controls" }
|
2021-05-27 19:06:50 +02:00
|
|
|
StatusNavigationListItem {
|
|
|
|
title: "Buttons"
|
|
|
|
selected: page.sourceComponent == buttonsComponent
|
|
|
|
onClicked: page.sourceComponent = buttonsComponent
|
|
|
|
}
|
|
|
|
StatusNavigationListItem {
|
|
|
|
title: "Controls"
|
|
|
|
selected: page.sourceComponent == controlsComponent
|
|
|
|
onClicked: page.sourceComponent = controlsComponent
|
|
|
|
}
|
2021-06-17 15:04:18 +02:00
|
|
|
StatusListSectionHeadline { text: "StatusQ.Components" }
|
2021-05-27 19:06:50 +02:00
|
|
|
StatusNavigationListItem {
|
|
|
|
title: "List Items"
|
|
|
|
selected: page.sourceComponent == listItemsComponent
|
|
|
|
onClicked: page.sourceComponent = listItemsComponent
|
|
|
|
}
|
2021-06-14 13:30:42 +02:00
|
|
|
StatusNavigationListItem {
|
|
|
|
title: "StatusChatInfoToolBar"
|
|
|
|
selected: page.sourceComponent == chatInfoToolBarComponent
|
|
|
|
onClicked: page.sourceComponent = chatInfoToolBarComponent
|
|
|
|
}
|
2021-05-27 19:06:50 +02:00
|
|
|
StatusNavigationListItem {
|
|
|
|
title: "Others"
|
|
|
|
selected: page.sourceComponent == othersComponent
|
|
|
|
onClicked: page.sourceComponent = othersComponent
|
2021-05-04 21:31:15 +03:00
|
|
|
}
|
2021-06-17 15:04:18 +02:00
|
|
|
StatusListSectionHeadline { text: "StatusQ.Popup" }
|
2021-06-02 12:41:31 +02:00
|
|
|
StatusNavigationListItem {
|
|
|
|
title: "StatusPopupMenu"
|
|
|
|
selected: page.sourceComponent == popupMenuComponent
|
|
|
|
onClicked: page.sourceComponent = popupMenuComponent
|
|
|
|
}
|
2021-06-14 15:10:36 +03:00
|
|
|
|
|
|
|
StatusNavigationListItem {
|
|
|
|
title: "StatusModal"
|
|
|
|
selected: page.sourceComponent == statusModalComponent
|
|
|
|
onClicked: page.sourceComponent = statusModalComponent
|
|
|
|
}
|
2021-05-04 21:31:15 +03:00
|
|
|
}
|
|
|
|
}
|
2021-05-27 19:06:50 +02:00
|
|
|
}
|
2021-05-04 21:31:15 +03:00
|
|
|
|
2021-05-27 19:06:50 +02:00
|
|
|
rightPanel: Item {
|
|
|
|
id: rightPanel
|
|
|
|
anchors.fill: parent
|
|
|
|
ScrollView {
|
2021-07-08 14:42:08 +03:00
|
|
|
anchors.fill: parent
|
2021-05-27 19:06:50 +02:00
|
|
|
contentHeight: (pageWrapper.height + pageWrapper.anchors.topMargin) * rootWindow.factor
|
2021-07-08 14:42:08 +03:00
|
|
|
contentWidth: (pageWrapper.width * rootWindow.factor)
|
2021-05-27 19:06:50 +02:00
|
|
|
clip: true
|
|
|
|
|
|
|
|
Item {
|
|
|
|
id: pageWrapper
|
|
|
|
width: rightPanel.width
|
|
|
|
anchors.top: parent.top
|
|
|
|
anchors.topMargin: 64
|
|
|
|
height: Math.max(rootWindow.height, page.height + 128)
|
|
|
|
scale: rootWindow.factor
|
|
|
|
Loader {
|
|
|
|
id: page
|
|
|
|
active: true
|
|
|
|
anchors.centerIn: parent
|
|
|
|
sourceComponent: iconsComponent
|
2021-05-17 13:18:41 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2021-05-04 21:31:15 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Action {
|
|
|
|
shortcut: "CTRL+="
|
|
|
|
onTriggered: {
|
|
|
|
if (rootWindow.factor < 2.0)
|
|
|
|
rootWindow.factor += 0.2
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Action {
|
|
|
|
shortcut: "CTRL+-"
|
|
|
|
onTriggered: {
|
|
|
|
if (rootWindow.factor > 0.5)
|
|
|
|
rootWindow.factor -= 0.2
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Action {
|
|
|
|
shortcut: "CTRL+0"
|
|
|
|
onTriggered: {
|
|
|
|
rootWindow.factor = 1.0
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Component {
|
|
|
|
id: iconsComponent
|
2021-05-27 19:06:50 +02:00
|
|
|
Icons { iconColor: Theme.palette.primaryColor1 }
|
2021-05-04 21:31:15 +03:00
|
|
|
}
|
2021-05-05 09:37:01 +02:00
|
|
|
|
2021-05-06 11:20:50 +02:00
|
|
|
Component {
|
|
|
|
id: controlsComponent
|
2021-05-27 19:06:50 +02:00
|
|
|
Controls {}
|
2021-05-06 11:20:50 +02:00
|
|
|
}
|
|
|
|
|
2021-05-21 15:14:08 +02:00
|
|
|
Component {
|
|
|
|
id: listItemsComponent
|
2021-05-27 19:06:50 +02:00
|
|
|
ListItems {}
|
2021-05-21 15:14:08 +02:00
|
|
|
}
|
|
|
|
|
feat(Layout): introduce StatusAppNavBar
This commit introduces a new `StatusAppNavBar` component that can be used
to create a Status application's tab bar for dedicated tab sections such as
chat, profile, wallet etc.
The component is build in a way that it support declarative and imperative usage
where necessary.
In its most simple form, a `StatusAppNavBar` comes with a single tab button
for the chat section. Such button has to be of type `StatusNavBarTabButton`:
```qml
import StatusQ.Layout 0.1
StatusAppNavBar {
navBarChatButton: StatusNavBarTabButton {
icon.name: "chat"
badge.value: 33
badge.visible: true
tooltip.text: "Chat"
}
}
```
In addition, it's possible to specify a list of `StatusNavBarTabButton` for
other sections of the application using the `navBarTabButtons` property:
```qml
StatusAppNavBar {
...
navBarTabButtons: [
StatusNavBarTabButton {
icon.name: "wallet"
tooltip.text: "Wallet"
},
StatusNavBarTabButton {
icon.name: "browser"
tooltip.text: "Browser"
},
StatusNavBarTabButton {
icon.name: "status-update"
tooltip.text: "Timeline"
}
]
}
```
Lastly, when desired to render tabs for Status community, which can grow
in size, `StatusAppNavBar` exposes a list via the `navBarCommunityTabButtons`
property that can have a `model` and a `delegate`. The `delegate` should also
be a `StatusNavBarTabButton`:
```qml
StatusAppNavBar {
...
navBarCommunityTabButtons.model: someModel.communities
navBarCommunityTabButtons.delegate: StatusNavBarTabButton {
name: model.name
tooltip.text: model.name
anchors.horizontalCenter: parent.horizontalCenter
}
}
```
The amount of community tab buttons can grow as they need until their dedicated
area becomes scrollable, at which point all `navBarTabButtons` will stick to the
bottom of `StatusAppNavBar`.
Closes #18
2021-05-11 16:25:46 +02:00
|
|
|
Component {
|
|
|
|
id: layoutComponent
|
2021-05-27 19:06:50 +02:00
|
|
|
Layout {}
|
feat(Layout): introduce StatusAppNavBar
This commit introduces a new `StatusAppNavBar` component that can be used
to create a Status application's tab bar for dedicated tab sections such as
chat, profile, wallet etc.
The component is build in a way that it support declarative and imperative usage
where necessary.
In its most simple form, a `StatusAppNavBar` comes with a single tab button
for the chat section. Such button has to be of type `StatusNavBarTabButton`:
```qml
import StatusQ.Layout 0.1
StatusAppNavBar {
navBarChatButton: StatusNavBarTabButton {
icon.name: "chat"
badge.value: 33
badge.visible: true
tooltip.text: "Chat"
}
}
```
In addition, it's possible to specify a list of `StatusNavBarTabButton` for
other sections of the application using the `navBarTabButtons` property:
```qml
StatusAppNavBar {
...
navBarTabButtons: [
StatusNavBarTabButton {
icon.name: "wallet"
tooltip.text: "Wallet"
},
StatusNavBarTabButton {
icon.name: "browser"
tooltip.text: "Browser"
},
StatusNavBarTabButton {
icon.name: "status-update"
tooltip.text: "Timeline"
}
]
}
```
Lastly, when desired to render tabs for Status community, which can grow
in size, `StatusAppNavBar` exposes a list via the `navBarCommunityTabButtons`
property that can have a `model` and a `delegate`. The `delegate` should also
be a `StatusNavBarTabButton`:
```qml
StatusAppNavBar {
...
navBarCommunityTabButtons.model: someModel.communities
navBarCommunityTabButtons.delegate: StatusNavBarTabButton {
name: model.name
tooltip.text: model.name
anchors.horizontalCenter: parent.horizontalCenter
}
}
```
The amount of community tab buttons can grow as they need until their dedicated
area becomes scrollable, at which point all `navBarTabButtons` will stick to the
bottom of `StatusAppNavBar`.
Closes #18
2021-05-11 16:25:46 +02:00
|
|
|
}
|
|
|
|
|
2021-05-05 09:37:01 +02:00
|
|
|
Component {
|
|
|
|
id: othersComponent
|
2021-05-27 19:06:50 +02:00
|
|
|
Others {}
|
2021-05-17 13:18:41 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
Component {
|
|
|
|
id: buttonsComponent
|
2021-05-27 19:06:50 +02:00
|
|
|
Buttons {}
|
2021-05-05 09:37:01 +02:00
|
|
|
}
|
2021-05-31 14:55:01 +02:00
|
|
|
|
2021-06-02 12:41:31 +02:00
|
|
|
Component {
|
|
|
|
id: popupMenuComponent
|
|
|
|
StatusPopupMenuPage {}
|
|
|
|
}
|
|
|
|
|
2021-06-14 13:30:42 +02:00
|
|
|
Component {
|
|
|
|
id: chatInfoToolBarComponent
|
|
|
|
StatusChatInfoToolBarPage {}
|
|
|
|
}
|
|
|
|
|
2021-06-14 15:10:36 +03:00
|
|
|
Component {
|
|
|
|
id: statusModalComponent
|
|
|
|
Popups {}
|
|
|
|
}
|
|
|
|
|
2021-05-31 14:55:01 +02:00
|
|
|
Component {
|
|
|
|
id: demoAppCmp
|
|
|
|
|
|
|
|
Rectangle {
|
|
|
|
anchors.fill: parent
|
|
|
|
color: Theme.palette.baseColor3
|
|
|
|
DemoApp {
|
|
|
|
id: demoApp
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
}
|
|
|
|
DropShadow {
|
|
|
|
anchors.fill: demoApp
|
|
|
|
source: demoApp
|
|
|
|
horizontalOffset: 0
|
|
|
|
verticalOffset: 5
|
|
|
|
radius: 20
|
|
|
|
samples: 20
|
|
|
|
color: "#22000000"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2021-06-01 13:01:47 +03:00
|
|
|
|
|
|
|
StatusMacTrafficLights {
|
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.top: parent.top
|
|
|
|
anchors.margins: 13
|
|
|
|
|
|
|
|
onClose: {
|
|
|
|
rootWindow.close()
|
|
|
|
}
|
|
|
|
|
|
|
|
onMinimised: {
|
|
|
|
rootWindow.showMinimized()
|
|
|
|
}
|
|
|
|
|
|
|
|
onMaximized: {
|
|
|
|
rootWindow.toggleFullScreen()
|
|
|
|
}
|
|
|
|
}
|
2021-05-04 21:31:15 +03:00
|
|
|
}
|