mirror of
https://github.com/status-im/status-desktop.git
synced 2025-01-21 20:09:37 +00:00
feat(SQ/StatusDotsLoadingIndicator): Created new 3 dots loading animation
- Created new loading animation component. - Added documentation and page in `stroybook`.
This commit is contained in:
parent
cb924053c6
commit
736f315c49
@ -129,6 +129,10 @@ ListModel {
|
||||
title: "StatusMessage"
|
||||
section: "Components"
|
||||
}
|
||||
ListElement {
|
||||
title: "StatusDotsLoadingIndicator"
|
||||
section: "Components"
|
||||
}
|
||||
ListElement {
|
||||
title: "BrowserSettings"
|
||||
section: "Settings"
|
||||
|
46
storybook/pages/StatusDotsLoadingIndicatorPage.qml
Normal file
46
storybook/pages/StatusDotsLoadingIndicatorPage.qml
Normal file
@ -0,0 +1,46 @@
|
||||
import QtQuick 2.14
|
||||
import QtQuick.Controls 2.14
|
||||
import QtQuick.Layouts 1.14
|
||||
|
||||
import StatusQ.Components 0.1
|
||||
import StatusQ.Core.Theme 0.1
|
||||
|
||||
|
||||
SplitView {
|
||||
id: root
|
||||
|
||||
SplitView {
|
||||
orientation: Qt.Vertical
|
||||
SplitView.fillWidth: true
|
||||
ColumnLayout {
|
||||
anchors.margins: 100
|
||||
anchors.fill: parent
|
||||
spacing: 100
|
||||
|
||||
StatusDotsLoadingIndicator {
|
||||
dotsDiameter: 5
|
||||
duration: 500
|
||||
dotsColor: "blue"
|
||||
}
|
||||
|
||||
StatusDotsLoadingIndicator {
|
||||
dotsDiameter: 15
|
||||
duration: 1000
|
||||
dotsColor: "orange"
|
||||
spacing: 16
|
||||
}
|
||||
|
||||
StatusDotsLoadingIndicator {
|
||||
dotsDiameter: 30
|
||||
duration: 1500
|
||||
dotsColor: "green"
|
||||
spacing: 30
|
||||
}
|
||||
|
||||
// filler
|
||||
Item {
|
||||
Layout.fillHeight: true
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
BIN
ui/StatusQ/doc/src/images/status_dots_loading_indicator.png
Normal file
BIN
ui/StatusQ/doc/src/images/status_dots_loading_indicator.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 6.3 KiB |
@ -0,0 +1,91 @@
|
||||
import QtQuick 2.14
|
||||
import QtQuick.Layouts 1.14
|
||||
import QtQuick.Controls 2.14
|
||||
|
||||
import StatusQ.Core.Theme 0.1
|
||||
|
||||
/*!
|
||||
\qmltype StatusDotsLoadingIndicator
|
||||
\inherits Control
|
||||
\inqmlmodule StatusQ.Components
|
||||
\since StatusQ.Components 0.1
|
||||
\brief It is a 3 dots loading animation.
|
||||
|
||||
The \c StatusDotsLoadingIndicator displays 3 dots blinking animation.
|
||||
|
||||
Example of how the control looks like:
|
||||
\image status_dots_loading_indicator.png
|
||||
|
||||
Example of how to use it:
|
||||
|
||||
\qml
|
||||
StatusDotsLoadingIndicator {
|
||||
dotsDiameter: 5
|
||||
duration: 1000
|
||||
dotsColor: "orange"
|
||||
}
|
||||
\endqml
|
||||
|
||||
For a list of components available see StatusQ.
|
||||
*/
|
||||
Control {
|
||||
id: root
|
||||
|
||||
/*!
|
||||
\qmlproperty string StatusDotsLoadingIndicator::dotsDiameter
|
||||
This property holds the diameter of the dots.
|
||||
*/
|
||||
property double dotsDiameter: 4.5
|
||||
|
||||
/*!
|
||||
\qmlproperty string StatusDotsLoadingIndicator::duration
|
||||
This property holds the duration of the animation.
|
||||
*/
|
||||
property int duration: 1500
|
||||
|
||||
/*!
|
||||
\qmlproperty string StatusDotsLoadingIndicator::dotsColor
|
||||
This property holds the color of the dots.
|
||||
*/
|
||||
property color dotsColor: Theme.palette.baseColor1
|
||||
|
||||
QtObject {
|
||||
id: d
|
||||
|
||||
readonly property double opacity1: 1
|
||||
readonly property double opacity2: 0.6
|
||||
readonly property double opacity3: 0.2
|
||||
}
|
||||
|
||||
spacing: 2
|
||||
|
||||
component DotItem: Rectangle{
|
||||
id: dotItem
|
||||
|
||||
property double maxOpacity
|
||||
|
||||
width: root.dotsDiameter
|
||||
height: width
|
||||
radius: width / 2
|
||||
color: root.dotsColor
|
||||
|
||||
SequentialAnimation {
|
||||
id: blinkingAnimation
|
||||
|
||||
loops: Animation.Infinite
|
||||
running: visible
|
||||
NumberAnimation { target: dotItem; property: "opacity"; to: 0; duration: root.duration;}
|
||||
NumberAnimation { target: dotItem; property: "opacity"; to: dotItem.maxOpacity; duration: root.duration;}
|
||||
}
|
||||
|
||||
Component.onCompleted: blinkingAnimation.start()
|
||||
}
|
||||
|
||||
contentItem: RowLayout {
|
||||
spacing: root.spacing
|
||||
|
||||
DotItem { id: firstDot; maxOpacity: d.opacity1}
|
||||
DotItem { id: secondDot; maxOpacity: d.opacity2}
|
||||
DotItem { id: thirdDot; maxOpacity: d.opacity3}
|
||||
}
|
||||
}
|
@ -15,6 +15,7 @@ StatusEmoji 0.1 StatusEmoji.qml
|
||||
StatusContactVerificationIcons 0.1 StatusContactVerificationIcons.qml
|
||||
StatusDateGroupLabel 0.1 StatusDateGroupLabel.qml
|
||||
StatusDescriptionListItem 0.1 StatusDescriptionListItem.qml
|
||||
StatusDotsLoadingIndicator 0.1 StatusDotsLoadingIndicator.qml
|
||||
StatusLetterIdenticon 0.1 StatusLetterIdenticon.qml
|
||||
StatusListItem 0.1 StatusListItem.qml
|
||||
StatusListSectionHeadline 0.1 StatusListSectionHeadline.qml
|
||||
|
Loading…
x
Reference in New Issue
Block a user