matrixion/resources/qml/NhekoBusyIndicator.qml

72 lines
1.8 KiB
QML
Raw Permalink Normal View History

2021-03-05 02:35:15 +03:00
// SPDX-FileCopyrightText: 2021 Nheko Contributors
// SPDX-FileCopyrightText: 2022 Nheko Contributors
// SPDX-FileCopyrightText: 2023 Nheko Contributors
//
2021-03-05 02:35:15 +03:00
// SPDX-License-Identifier: GPL-3.0-or-later
import QtQuick 2.9
2020-11-15 06:52:49 +03:00
import QtQuick.Controls 2.3
import QtQuick.Layouts 1.2
2021-05-13 09:23:56 +03:00
import im.nheko 1.0
2020-11-15 06:52:49 +03:00
BusyIndicator {
id: control
contentItem: Item {
2020-11-16 01:14:47 +03:00
implicitWidth: 64
implicitHeight: 64
2020-11-15 06:52:49 +03:00
Item {
id: item
height: Math.min(parent.height, parent.width)
width: height
opacity: control.running ? 1 : 0
RotationAnimator {
target: item
running: control.visible && control.running
from: 0
to: 360
loops: Animation.Infinite
duration: 2000
}
Repeater {
id: repeater
model: 6
Rectangle {
implicitWidth: radius * 2
implicitHeight: radius * 2
radius: item.height / 6
2021-05-13 09:23:56 +03:00
color: Nheko.colors.text
2020-11-15 06:52:49 +03:00
opacity: (index + 2) / (repeater.count + 2)
transform: [
Translate {
y: -Math.min(item.width, item.height) * 0.5 + item.height / 6
},
Rotation {
angle: index / repeater.count * 360
origin.x: item.height / 2
origin.y: item.height / 2
}
]
}
}
Behavior on opacity {
OpacityAnimator {
duration: 250
}
}
}
}
}