diff --git a/sandbox/StatusExpandableSettingsItemPage.qml b/sandbox/StatusExpandableSettingsItemPage.qml
index 501f30e1..9af00c48 100644
--- a/sandbox/StatusExpandableSettingsItemPage.qml
+++ b/sandbox/StatusExpandableSettingsItemPage.qml
@@ -11,35 +11,46 @@ Column {
leftPadding: 20
rightPadding: 20
- StatusExpandableSettingsItem {
+ Rectangle {
+ width: parent.width
+ height: 30
+ color: Theme.palette.baseColor2
+ StatusBaseText {
+ anchors.verticalCenter: parent.verticalCenter
+ text: "Type Primary"
+ color: Theme.palette.directColor1
+ }
+ }
+
+ StatusExpandableItem {
anchors.horizontalCenter: parent.horizontalCenter
expandable: false
icon.name: "seed-phrase"
- primaryText: qsTr("Back up seed phrase")
- secondaryText: qsTr("Back up your seed phrase now to secure this account ajhaDH SDHSAHDLSADBSA,DLISAHDLASD ADASDHASLDHALSDHAS DAS,DASJDGLIASGD")
+ primaryText: "Back up seed phrase"
+ secondaryText: "Back up your seed phrase now to secure this account ajhaDH SDHSAHDLSADBSA,DLISAHDLASD ADASDHASLDHALSDHAS DAS,DASJDGLIASGD"
button.text: qsTr("Back up seed phrase")
}
- StatusExpandableSettingsItem {
+ StatusExpandableItem {
anchors.horizontalCenter: parent.horizontalCenter
expandable: true
icon.name: "secret"
- primaryText: qsTr("Account signing phrase")
- secondaryText: qsTr("View your signing phrase and ensure that you never get scammed")
+ primaryText: "Account signing phrase"
+ secondaryText: "View your signing phrase and ensure that you never get scammed. View your signing phrase and ensure that you never get scammed."
expandableComponent: notImplemented
}
- StatusExpandableSettingsItem {
+ StatusExpandableItem {
anchors.horizontalCenter: parent.horizontalCenter
expandable: true
icon.name: "seed-phrase"
- primaryText: qsTr("View private key")
- secondaryText: qsTr("Back up your seed phrase now to secure this account")
+ primaryText: "View private key"
+ secondaryText: "Back up your seed phrase now to secure this account"
expandableComponent: notImplemented
- button.text: qsTr("View private key")
+ button.text: "View private key"
button.icon.name: "tiny/public-chat"
button.onClicked: {
// To-do open enter password Modal
@@ -47,6 +58,78 @@ Column {
}
}
+ Rectangle {
+ width: parent.width
+ height: 30
+ color: Theme.palette.baseColor2
+ StatusBaseText {
+ anchors.verticalCenter: parent.verticalCenter
+ text: "Type Secondary"
+ color: Theme.palette.directColor1
+ }
+ }
+
+ StatusExpandableItem {
+ anchors.horizontalCenter: parent.horizontalCenter
+
+ type: StatusExpandableItem.Type.Secondary
+ expandable: true
+ image.source: "https://pbs.twimg.com/profile_images/1369221718338895873/T_5fny6o_400x400.jpg"
+ primaryText: "CryptoKitties"
+ additionalText: "1456 USD"
+ expandableComponent: notImplemented
+ }
+
+ StatusExpandableItem {
+ anchors.horizontalCenter: parent.horizontalCenter
+
+ type: StatusExpandableItem.Type.Secondary
+ expandable: true
+ image.source: "https://pbs.twimg.com/profile_images/1369221718338895873/T_5fny6o_400x400.jpg"
+ primaryText: "Adding Really long text to test scenario of having very long text along with tertiary text"
+ additionalText: "564.90 USD"
+ expandableComponent: notImplemented
+ }
+
+ StatusExpandableItem {
+ anchors.horizontalCenter: parent.horizontalCenter
+
+ type: StatusExpandableItem.Type.Secondary
+ expandable: true
+ primaryText: "CryptoKitties"
+ additionalText: "1456 USD"
+ expandableComponent: notImplemented
+ }
+
+ Rectangle {
+ width: parent.width
+ height: 30
+ color: Theme.palette.baseColor2
+ StatusBaseText {
+ anchors.verticalCenter: parent.verticalCenter
+ text: "Type Tertiary"
+ color: Theme.palette.directColor1
+ }
+ }
+
+ StatusExpandableItem {
+ anchors.horizontalCenter: parent.horizontalCenter
+
+ type: StatusExpandableItem.Type.Tertiary
+ expandable: true
+ primaryText: "CryptoKitties"
+ expandableComponent: notImplemented
+ }
+
+ StatusExpandableItem {
+ anchors.horizontalCenter: parent.horizontalCenter
+
+ type: StatusExpandableItem.Type.Tertiary
+ expandable: true
+ primaryText: "Rescue Moon"
+ expandableComponent: notImplemented
+ }
+
Component {
id: notImplemented
Rectangle {
diff --git a/sandbox/main.qml b/sandbox/main.qml
index 4357b5cd..0ed4bd98 100644
--- a/sandbox/main.qml
+++ b/sandbox/main.qml
@@ -170,7 +170,7 @@ StatusWindow {
onClicked: page.sourceComponent = othersComponent
}
StatusNavigationListItem {
- title: "StatusExpandableSettingsItem"
+ title: "StatusExpandableItem"
selected: page.sourceComponent == settingsComponent
onClicked: page.sourceComponent = settingsComponent
}
diff --git a/src/StatusQ/Components/StatusExpandableItem.qml b/src/StatusQ/Components/StatusExpandableItem.qml
new file mode 100644
index 00000000..46067e1a
--- /dev/null
+++ b/src/StatusQ/Components/StatusExpandableItem.qml
@@ -0,0 +1,229 @@
+import QtQuick 2.14
+import StatusQ.Core 0.1
+import StatusQ.Controls 0.1
+import StatusQ.Core.Theme 0.1
+import StatusQ.Components 0.1
+
+Rectangle {
+ id: statusExpandableItem
+
+ property alias primaryText: primaryText.text
+ property alias secondaryText: secondaryText.text
+ property alias additionalText: additionalText.text
+ property alias button: button
+ property alias expandableComponent: expandableRegion.sourceComponent
+
+ property int type: StatusExpandableItem.Type.Primary
+ property bool expandable: true
+ property bool expanded: false
+
+ property StatusIconSettings icon: StatusIconSettings {
+ color: Theme.palette.directColor1
+ background: StatusIconBackgroundSettings {
+ width: 32
+ height: 32
+ color: Theme.palette.primaryColor2
+ }
+ }
+ property StatusImageSettings image: StatusImageSettings {
+ width: 40
+ height: 40
+ }
+
+ enum Type {
+ Primary, // 0
+ Secondary, // 1
+ Tertiary // 2
+ }
+
+ implicitWidth: 718
+
+ radius: (statusExpandableItem.type === StatusExpandableItem.Type.Primary) ? 8 : 0
+ color: "transparent"
+ border.color: (statusExpandableItem.type === StatusExpandableItem.Type.Primary) ? Theme.palette.baseColor2 : "transparent"
+ state: "COLLAPSED"
+ clip: true
+
+ Rectangle {
+ id: separatorRect
+ anchors.top: parent.top
+ anchors.horizontalCenter: parent.horizontalCenter
+ width: parent.width
+ height: 1
+
+ color: Theme.palette.baseColor2
+ visible: (statusExpandableItem.type === StatusExpandableItem.Type.Tertiary)
+ }
+
+ Loader {
+ id: identicon
+ anchors.top: parent.top
+ anchors.topMargin: 25
+ anchors.left: parent.left
+ anchors.leftMargin: (statusExpandableItem.type === StatusExpandableItem.Type.Secondary) ? 0 : 11
+ active: (statusExpandableItem.type !== StatusExpandableItem.Type.Tertiary)
+ sourceComponent: !!statusExpandableItem.image.source.toString() ? roundedImage :
+ !!statusExpandableItem.icon.name.toString() ? roundedIcon : letterIdenticon
+ }
+
+ Component {
+ id: roundedImage
+ StatusRoundedImage {
+ image.source: statusExpandableItem.image.source
+ }
+ }
+
+ Component {
+ id: roundedIcon
+ StatusRoundIcon {
+ icon.background.width: statusExpandableItem.icon.background.width
+ icon.background.height: statusExpandableItem.icon.background.height
+ icon.background.color: statusExpandableItem.icon.background.color
+ icon.color: statusExpandableItem.icon.color
+ icon.name: statusExpandableItem.icon.name
+ }
+ }
+
+ Component {
+ id: letterIdenticon
+ StatusLetterIdenticon {
+ height: 40
+ width: 40
+ name: primaryText.text
+ letterSize: 20
+ color: Theme.palette.miscColor5
+ }
+ }
+
+ StatusBaseText {
+ id: primaryText
+ anchors.top: (statusExpandableItem.type === StatusExpandableItem.Type.Primary) ||
+ (statusExpandableItem.type === StatusExpandableItem.Type.Tertiary) ? parent.top : undefined
+ anchors.topMargin: (statusExpandableItem.type === StatusExpandableItem.Type.Tertiary) ? 29 : 17
+ anchors.left: identicon.active ? identicon.right : parent.left
+ anchors.leftMargin: (statusExpandableItem.type === StatusExpandableItem.Type.Primary) ? 10 : 16
+
+ anchors.verticalCenter: (statusExpandableItem.type === StatusExpandableItem.Type.Secondary) ? identicon.verticalCenter : undefined
+
+ width: !!additionalText.text ? (button.visible ? parent.width - icon.background.width - button.width - additionalText.contentWidth - 110 :
+ parent.width - icon.background.width - additionalText.contentWidth - 110) :
+ (button.visible ? parent.width - icon.background.width - button.width - 70 :
+ parent.width - icon.background.width - 70)
+
+ font.weight: (statusExpandableItem.type === StatusExpandableItem.Type.Primary) ? Font.Medium : Font.Normal
+ font.pixelSize: (statusExpandableItem.type === StatusExpandableItem.Type.Primary) ? 15 : 17
+ lineHeight: (statusExpandableItem.type === StatusExpandableItem.Type.Primary) ? 22 : 24
+ lineHeightMode: Text.FixedHeight
+ elide: Text.ElideRight
+ color: (statusExpandableItem.type === StatusExpandableItem.Type.Tertiary) ? Theme.palette.baseColor1 : Theme.palette.directColor1
+ }
+
+ StatusBaseText {
+ id: secondaryText
+ anchors.top: primaryText.bottom
+ anchors.topMargin: 4
+ anchors.left: primaryText.left
+ anchors.right: primaryText.right
+
+ font.pixelSize: 15
+ lineHeight: 22
+ lineHeightMode: Text.FixedHeight
+ elide: Text.ElideRight
+ color: Theme.palette.directColor3
+ }
+
+ StatusBaseText {
+ id: additionalText
+ anchors.verticalCenter: primaryText.verticalCenter
+ anchors.verticalCenterOffset: 2
+ anchors.right: expandImage.left
+ anchors.rightMargin: 16
+
+ font.pixelSize: 15
+ lineHeight: 24
+ lineHeightMode: Text.FixedHeight
+ elide: Text.ElideRight
+ color: Theme.palette.baseColor1
+ }
+
+ StatusButton {
+ id: button
+ anchors.top: parent.top
+ anchors.topMargin: 19
+ anchors.right: parent.right
+ anchors.rightMargin: 16
+ visible: !!text
+ }
+
+ StatusIcon {
+ id: expandImage
+ anchors.verticalCenter: (statusExpandableItem.type === StatusExpandableItem.Type.Tertiary) ?
+ primaryText.verticalCenter : identicon.verticalCenter
+ anchors.verticalCenterOffset:(statusExpandableItem.type === StatusExpandableItem.Type.Tertiary) ? -3 : -1
+ anchors.right: parent.right
+ anchors.rightMargin: (statusExpandableItem.type === StatusExpandableItem.Type.Primary) ? 23 : 6
+ visible: expandable && !button.visible
+ color: (statusExpandableItem.type === StatusExpandableItem.Type.Tertiary) ?
+ Theme.palette.baseColor1 :
+ Theme.palette.directColor1
+ }
+
+ MouseArea {
+ anchors.fill: parent
+ onClicked: {
+ if(expandable) {
+ expanded = !expanded
+ }
+ }
+ cursorShape: Qt.PointingHandCursor
+ visible: !button.visible && expandable
+ }
+
+ Loader {
+ id: expandableRegion
+ anchors.top: secondaryText.bottom
+ anchors.topMargin: 16
+ anchors.left: parent.left
+ anchors.leftMargin: (statusExpandableItem.type === StatusExpandableItem.Type.Primary) ? 48 : 0
+ anchors.right: parent.right
+ anchors.rightMargin: (statusExpandableItem.type === StatusExpandableItem.Type.Primary) ? 16 : 0
+ active: false
+ }
+
+ onExpandedChanged: {
+ if(expanded) {
+ state = "EXPANDED"
+ }
+ else {
+ state = "COLLAPSED"
+ }
+ }
+
+ states: [
+ State {
+ name: "EXPANDED"
+ PropertyChanges {target: expandImage; icon: "chevron-up"}
+ PropertyChanges {target: statusExpandableItem; height: 82 + expandableRegion.height + 22}
+ PropertyChanges {target: expandableRegion; active: true}
+ },
+ State {
+ name: "COLLAPSED"
+ PropertyChanges {target: expandImage; icon: "chevron-down"}
+ PropertyChanges {target: statusExpandableItem; height: 82}
+ PropertyChanges {target: expandableRegion; active: false}
+ }
+ ]
+
+ transitions: [
+ Transition {
+ from: "COLLAPSED"
+ to: "EXPANDED"
+ NumberAnimation { properties: "height"; duration: 200 }
+ },
+ Transition {
+ from: "EXPANDED"
+ to: "COLLAPSED"
+ NumberAnimation { properties: "height"; duration: 200 }
+ }
+ ]
+}
diff --git a/src/StatusQ/Components/StatusExpandableSettingsItem.qml b/src/StatusQ/Components/StatusExpandableSettingsItem.qml
deleted file mode 100644
index 111e6e5d..00000000
--- a/src/StatusQ/Components/StatusExpandableSettingsItem.qml
+++ /dev/null
@@ -1,155 +0,0 @@
-import QtQuick 2.14
-import StatusQ.Core 0.1
-import StatusQ.Controls 0.1
-import StatusQ.Core.Theme 0.1
-import StatusQ.Components 0.1
-
-Rectangle {
- id: statusExpandableSettingsItem
-
- property alias primaryText: primaryText.text
- property alias secondaryText: secondaryText.text
- property alias button: button
- property alias expandableComponent: expandableRegion.sourceComponent
-
- property bool expandable: true
- property bool expanded: false
- property StatusIconSettings icon: StatusIconSettings {
- color: Theme.palette.directColor1
- background: StatusIconBackgroundSettings {
- width: 32
- height: 32
- color: Theme.palette.primaryColor2
- }
- }
-
- implicitWidth: 718
-
- radius: 8
- color: "transparent"
- border.color: Theme.palette.baseColor2
- state: "COLLAPSED"
- clip: true
-
- StatusRoundIcon {
- id: roundIcon
- anchors.top: parent.top
- anchors.topMargin: 25
- anchors.left: parent.left
- anchors.leftMargin: 11
-
- icon.background.width: statusExpandableSettingsItem.icon.background.width
- icon.background.height: statusExpandableSettingsItem.icon.background.height
- icon.background.color: statusExpandableSettingsItem.icon.background.color
- icon.color: statusExpandableSettingsItem.icon.color
- icon.name: statusExpandableSettingsItem.icon.name
- }
-
- StatusBaseText {
- id: primaryText
- anchors.top: parent.top
- anchors.topMargin: 17
- anchors.left: roundIcon.right
- anchors.leftMargin: 10
-
- width: button.visible ? parent.width - icon.background.width - button.width - 70 :
- parent.width - icon.background.width - 70
-
- font.weight: Font.Medium
- font.pixelSize: 15
- lineHeight: 22
- lineHeightMode: Text.FixedHeight
- elide: Text.ElideRight
- color: Theme.palette.directColor1
- }
-
- StatusBaseText {
- id: secondaryText
- anchors.top: primaryText.bottom
- anchors.topMargin: 4
- anchors.left: primaryText.left
- anchors.right: primaryText.right
-
- font.pixelSize: 15
- lineHeight: 22
- lineHeightMode: Text.FixedHeight
- elide: Text.ElideRight
- color: Theme.palette.directColor3
- }
-
- StatusButton {
- id: button
- anchors.top: parent.top
- anchors.topMargin: 19
- anchors.right: parent.right
- anchors.rightMargin: 16
- visible: !!text
- }
-
- StatusIcon {
- id: expandImage
- anchors.top: parent.top
- anchors.topMargin: 36
- anchors.right: parent.right
- anchors.rightMargin: 23
- visible: expandable && !button.visible
- color: Theme.palette.directColor1
- }
-
- Loader {
- id: expandableRegion
- anchors.top: secondaryText.bottom
- anchors.topMargin: 16
- anchors.left: parent.left
- anchors.leftMargin: 48
- width: parent.width - 64
- }
-
- MouseArea {
- anchors.fill: parent
- onClicked: {
- if(expandable) {
- expanded = !expanded
- }
- }
- cursorShape: Qt.PointingHandCursor
- visible: !button.visible && expandable
- }
-
- onExpandedChanged: {
- if(expanded) {
- state = "EXPANDED"
- }
- else {
- state = "COLLAPSED"
- }
- }
-
- states: [
- State {
- name: "EXPANDED"
- PropertyChanges {target: expandImage; icon: "chevron-up"}
- PropertyChanges {target: statusExpandableSettingsItem; height: 82 + expandableRegion.height + 22}
- PropertyChanges {target: expandableRegion; active: true}
- },
- State {
- name: "COLLAPSED"
- PropertyChanges {target: expandImage; icon: "chevron-down"}
- PropertyChanges {target: statusExpandableSettingsItem; height: 82}
- PropertyChanges {target: expandableRegion; active: false}
- }
- ]
-
- transitions: [
- Transition {
- from: "COLLAPSED"
- to: "EXPANDED"
- NumberAnimation { properties: "height"; duration: 200 }
- },
- Transition {
- from: "EXPANDED"
- to: "COLLAPSED"
- NumberAnimation { properties: "height"; duration: 200 }
- }
- ]
-}
diff --git a/src/StatusQ/Components/qmldir b/src/StatusQ/Components/qmldir
index ccc42fd9..78e2b203 100644
--- a/src/StatusQ/Components/qmldir
+++ b/src/StatusQ/Components/qmldir
@@ -20,4 +20,4 @@ StatusRoundIcon 0.1 StatusRoundIcon.qml
StatusRoundedImage 0.1 StatusRoundedImage.qml
StatusMacWindowButtons 0.1 StatusMacWindowButtons.qml
StatusListItemBadge 0.1 StatusListItemBadge.qml
-StatusExpandableSettingsItem 0.1 StatusExpandableSettingsItem.qml
+StatusExpandableItem 0.1 StatusExpandableItem.qml
diff --git a/statusq.qrc b/statusq.qrc
index c8684033..a8271195 100644
--- a/statusq.qrc
+++ b/statusq.qrc
@@ -266,7 +266,7 @@
src/assets/img/icons/windows_titlebar/status.svg
src/StatusQ/Controls/StatusSwitchTabButton.qml
src/StatusQ/Controls/StatusSwitchTabBar.qml
- src/StatusQ/Components/StatusExpandableSettingsItem.qml
+ src/StatusQ/Components/StatusExpandableItem.qml
src/assets/img/icons/snt.svg