mirror of
https://github.com/zhuzichu520/FluentUI.git
synced 2025-01-22 20:04:32 +08:00
Compare commits
4 Commits
c2b845658d
...
fe08b08c1f
Author | SHA1 | Date | |
---|---|---|---|
|
fe08b08c1f | ||
|
ef96618151 | ||
|
be34220652 | ||
|
5cf0812562 |
@ -70,8 +70,8 @@ FluScrollablePage{
|
|||||||
}
|
}
|
||||||
|
|
||||||
FluFrame{
|
FluFrame{
|
||||||
width: 500
|
Layout.preferredWidth: 500
|
||||||
height: 370
|
Layout.preferredHeight: 370
|
||||||
padding: 10
|
padding: 10
|
||||||
Layout.topMargin: 20
|
Layout.topMargin: 20
|
||||||
FluChart{
|
FluChart{
|
||||||
|
@ -71,7 +71,7 @@ FluScrollablePage{
|
|||||||
anchors.centerIn: parent
|
anchors.centerIn: parent
|
||||||
text: "Acrylic"
|
text: "Acrylic"
|
||||||
color: "#FFFFFF"
|
color: "#FFFFFF"
|
||||||
font.bold: true
|
font: FluTextStyle.Subtitle
|
||||||
}
|
}
|
||||||
MouseArea {
|
MouseArea {
|
||||||
property point clickPos: Qt.point(0,0)
|
property point clickPos: Qt.point(0,0)
|
||||||
|
@ -58,6 +58,7 @@ FluContentPage {
|
|||||||
FluText {
|
FluText {
|
||||||
id:item_name
|
id:item_name
|
||||||
font.pixelSize: 10
|
font.pixelSize: 10
|
||||||
|
font.family: FluTextStyle.family
|
||||||
anchors.horizontalCenter: parent.horizontalCenter
|
anchors.horizontalCenter: parent.horizontalCenter
|
||||||
anchors.top: item_icon.bottom
|
anchors.top: item_icon.bottom
|
||||||
width:parent.width
|
width:parent.width
|
||||||
|
@ -103,7 +103,6 @@ FluScrollablePage{
|
|||||||
horizontalAlignment: Qt.AlignHCenter
|
horizontalAlignment: Qt.AlignHCenter
|
||||||
text:model.title
|
text:model.title
|
||||||
color: FluColors.Grey10
|
color: FluColors.Grey10
|
||||||
font.pixelSize: 15
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -122,6 +122,7 @@ FluScrollablePage{
|
|||||||
Layout.leftMargin: 20
|
Layout.leftMargin: 20
|
||||||
color: FluColors.Grey120
|
color: FluColors.Grey120
|
||||||
font.pixelSize: 12
|
font.pixelSize: 12
|
||||||
|
font.family: FluTextStyle.family
|
||||||
wrapMode: Text.WrapAnywhere
|
wrapMode: Text.WrapAnywhere
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -42,8 +42,7 @@ FluContentPage{
|
|||||||
FluText{
|
FluText{
|
||||||
color:"#FFFFFF"
|
color:"#FFFFFF"
|
||||||
text:model.index
|
text:model.index
|
||||||
font.bold: true
|
font: FluTextStyle.Title
|
||||||
font.pixelSize: 18
|
|
||||||
anchors.centerIn: parent
|
anchors.centerIn: parent
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -41,7 +41,7 @@ FluWindow {
|
|||||||
}
|
}
|
||||||
FluText{
|
FluText{
|
||||||
text: qsTr("Drag in a qml file")
|
text: qsTr("Drag in a qml file")
|
||||||
font.pixelSize: 26
|
font: FluTextStyle.Title
|
||||||
anchors.centerIn: parent
|
anchors.centerIn: parent
|
||||||
visible: !loader.itemLodaer().item && loader.statusMode === FluStatusLayoutType.Success
|
visible: !loader.itemLodaer().item && loader.statusMode === FluStatusLayoutType.Success
|
||||||
}
|
}
|
||||||
|
@ -101,7 +101,7 @@ FluWindow {
|
|||||||
width: 186
|
width: 186
|
||||||
FluMenuItem{
|
FluMenuItem{
|
||||||
text: qsTr("Open in Separate Window")
|
text: qsTr("Open in Separate Window")
|
||||||
font.pixelSize: 12
|
font: FluTextStyle.Caption
|
||||||
onClicked: {
|
onClicked: {
|
||||||
FluRouter.navigate("/pageWindow",{title:modelData.title,url:modelData.url})
|
FluRouter.navigate("/pageWindow",{title:modelData.title,url:modelData.url})
|
||||||
}
|
}
|
||||||
|
@ -33,7 +33,7 @@ Q_IMPORT_QML_PLUGIN(FluentUIPlugin)
|
|||||||
int main(int argc, char *argv[])
|
int main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
::SetUnhandledExceptionFilter(MyUnhandledExceptionFilter);
|
// ::SetUnhandledExceptionFilter(MyUnhandledExceptionFilter);
|
||||||
qputenv("QT_QPA_PLATFORM","windows:darkmode=2");
|
qputenv("QT_QPA_PLATFORM","windows:darkmode=2");
|
||||||
#endif
|
#endif
|
||||||
#if (QT_VERSION >= QT_VERSION_CHECK(6, 0, 0))
|
#if (QT_VERSION >= QT_VERSION_CHECK(6, 0, 0))
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
#include "FluColors.h"
|
#include "FluColors.h"
|
||||||
|
#include "FluTools.h"
|
||||||
|
|
||||||
FluColors::FluColors(QObject *parent):QObject{parent}{
|
FluColors::FluColors(QObject *parent):QObject{parent}{
|
||||||
Transparent(QColor(0, 0, 0, 0));
|
Transparent(QColor(0, 0, 0, 0));
|
||||||
@ -111,17 +112,12 @@ FluColors::FluColors(QObject *parent):QObject{parent}{
|
|||||||
|
|
||||||
FluAccentColor* FluColors::createAccentColor(QColor primaryColor){
|
FluAccentColor* FluColors::createAccentColor(QColor primaryColor){
|
||||||
FluAccentColor *accentColor = new FluAccentColor(this);
|
FluAccentColor *accentColor = new FluAccentColor(this);
|
||||||
accentColor->darkest(withOpacity(primaryColor,0.7));
|
accentColor->darkest(FluTools::getInstance()->withOpacity(primaryColor,0.7));
|
||||||
accentColor->darker(withOpacity(primaryColor,0.8));
|
accentColor->darker(FluTools::getInstance()->withOpacity(primaryColor,0.8));
|
||||||
accentColor->dark(withOpacity(primaryColor,0.9));
|
accentColor->dark(FluTools::getInstance()->withOpacity(primaryColor,0.9));
|
||||||
accentColor->normal(primaryColor);
|
accentColor->normal(primaryColor);
|
||||||
accentColor->light(withOpacity(primaryColor,0.9));
|
accentColor->light(FluTools::getInstance()->withOpacity(primaryColor,0.9));
|
||||||
accentColor->lighter(withOpacity(primaryColor,0.8));
|
accentColor->lighter(FluTools::getInstance()->withOpacity(primaryColor,0.8));
|
||||||
accentColor->lightest(withOpacity(primaryColor,0.7));
|
accentColor->lightest(FluTools::getInstance()->withOpacity(primaryColor,0.7));
|
||||||
return accentColor;
|
return accentColor;
|
||||||
}
|
}
|
||||||
|
|
||||||
QColor FluColors::withOpacity(QColor color,qreal opacity){
|
|
||||||
int alpha = qRound(opacity * 255) & 0xff;
|
|
||||||
return QColor::fromRgba((alpha << 24) | (color.rgba() & 0xffffff));
|
|
||||||
}
|
|
||||||
|
@ -3,6 +3,7 @@
|
|||||||
|
|
||||||
#include <QObject>
|
#include <QObject>
|
||||||
#include <QtQml/qqml.h>
|
#include <QtQml/qqml.h>
|
||||||
|
|
||||||
#include "FluAccentColor.h"
|
#include "FluAccentColor.h"
|
||||||
#include "stdafx.h"
|
#include "stdafx.h"
|
||||||
#include "singleton.h"
|
#include "singleton.h"
|
||||||
@ -50,7 +51,6 @@ class FluColors : public QObject
|
|||||||
QML_SINGLETON
|
QML_SINGLETON
|
||||||
private:
|
private:
|
||||||
explicit FluColors(QObject *parent = nullptr);
|
explicit FluColors(QObject *parent = nullptr);
|
||||||
QColor withOpacity(QColor color,qreal opacity);
|
|
||||||
public:
|
public:
|
||||||
SINGLETON(FluColors)
|
SINGLETON(FluColors)
|
||||||
Q_INVOKABLE FluAccentColor* createAccentColor(QColor primaryColor);
|
Q_INVOKABLE FluAccentColor* createAccentColor(QColor primaryColor);
|
||||||
|
@ -76,7 +76,7 @@ void FluFrameless::componentComplete(){
|
|||||||
HWND hwnd = reinterpret_cast<HWND>(window()->winId());
|
HWND hwnd = reinterpret_cast<HWND>(window()->winId());
|
||||||
DWORD style = ::GetWindowLongPtr(hwnd, GWL_STYLE);
|
DWORD style = ::GetWindowLongPtr(hwnd, GWL_STYLE);
|
||||||
if(_fixSize){
|
if(_fixSize){
|
||||||
::SetWindowLongPtr(hwnd, GWL_STYLE, style | WS_THICKFRAME);
|
::SetWindowLongPtr(hwnd, GWL_STYLE, style | WS_THICKFRAME | WS_CAPTION);
|
||||||
for (int i = 0; i < qApp->screens().count(); ++i) {
|
for (int i = 0; i < qApp->screens().count(); ++i) {
|
||||||
connect( qApp->screens().at(i),&QScreen::logicalDotsPerInchChanged,this,[=]{
|
connect( qApp->screens().at(i),&QScreen::logicalDotsPerInchChanged,this,[=]{
|
||||||
SetWindowPos(hwnd,nullptr,0,0,0,0,SWP_NOZORDER | SWP_NOOWNERZORDER | SWP_NOMOVE | SWP_FRAMECHANGED);
|
SetWindowPos(hwnd,nullptr,0,0,0,0,SWP_NOZORDER | SWP_NOOWNERZORDER | SWP_NOMOVE | SWP_FRAMECHANGED);
|
||||||
@ -228,12 +228,6 @@ bool FluFrameless::nativeEventFilter(const QByteArray &eventType, void *message,
|
|||||||
return true;
|
return true;
|
||||||
}else if(uMsg == WM_GETMINMAXINFO){
|
}else if(uMsg == WM_GETMINMAXINFO){
|
||||||
MINMAXINFO* minmaxInfo = reinterpret_cast<MINMAXINFO *>(lParam);
|
MINMAXINFO* minmaxInfo = reinterpret_cast<MINMAXINFO *>(lParam);
|
||||||
#if QT_VERSION >= QT_VERSION_CHECK(6,0,0)
|
|
||||||
minmaxInfo->ptMaxPosition.x = 0;
|
|
||||||
minmaxInfo->ptMaxPosition.y = 0;
|
|
||||||
minmaxInfo->ptMaxSize.x = 0;
|
|
||||||
minmaxInfo->ptMaxSize.y = 0;
|
|
||||||
#else
|
|
||||||
auto pixelRatio = window()->devicePixelRatio();
|
auto pixelRatio = window()->devicePixelRatio();
|
||||||
auto geometry = window()->screen()->availableGeometry();
|
auto geometry = window()->screen()->availableGeometry();
|
||||||
RECT rect;
|
RECT rect;
|
||||||
@ -242,7 +236,6 @@ bool FluFrameless::nativeEventFilter(const QByteArray &eventType, void *message,
|
|||||||
minmaxInfo->ptMaxPosition.y = rect.top - offsetXY.x();
|
minmaxInfo->ptMaxPosition.y = rect.top - offsetXY.x();
|
||||||
minmaxInfo->ptMaxSize.x = geometry.width()*pixelRatio + offsetXY.x() * 2;
|
minmaxInfo->ptMaxSize.x = geometry.width()*pixelRatio + offsetXY.x() * 2;
|
||||||
minmaxInfo->ptMaxSize.y = geometry.height()*pixelRatio + offsetXY.y() * 2;
|
minmaxInfo->ptMaxSize.y = geometry.height()*pixelRatio + offsetXY.y() * 2;
|
||||||
#endif
|
|
||||||
return false;
|
return false;
|
||||||
}else if(uMsg == WM_NCRBUTTONDOWN){
|
}else if(uMsg == WM_NCRBUTTONDOWN){
|
||||||
if (wParam == HTCAPTION) {
|
if (wParam == HTCAPTION) {
|
||||||
|
@ -1,35 +1,47 @@
|
|||||||
#include "FluTextStyle.h"
|
#include "FluTextStyle.h"
|
||||||
|
|
||||||
FluTextStyle::FluTextStyle(QObject *parent):QObject{parent}{
|
FluTextStyle::FluTextStyle(QObject *parent):QObject{parent}{
|
||||||
|
_family = QFont().defaultFamily();
|
||||||
|
#ifdef Q_OS_WIN
|
||||||
|
_family = "微软雅黑";
|
||||||
|
#endif
|
||||||
|
|
||||||
QFont caption;
|
QFont caption;
|
||||||
|
caption.setFamily(_family);
|
||||||
caption.setPixelSize(12);
|
caption.setPixelSize(12);
|
||||||
Caption(caption);
|
Caption(caption);
|
||||||
|
|
||||||
QFont body;
|
QFont body;
|
||||||
|
body.setFamily(_family);
|
||||||
body.setPixelSize(13);
|
body.setPixelSize(13);
|
||||||
Body(body);
|
Body(body);
|
||||||
|
|
||||||
QFont bodyStrong;
|
QFont bodyStrong;
|
||||||
|
bodyStrong.setFamily(_family);
|
||||||
bodyStrong.setPixelSize(13);
|
bodyStrong.setPixelSize(13);
|
||||||
bodyStrong.setWeight(QFont::DemiBold);
|
bodyStrong.setWeight(QFont::DemiBold);
|
||||||
BodyStrong(bodyStrong);
|
BodyStrong(bodyStrong);
|
||||||
|
|
||||||
QFont subtitle;
|
QFont subtitle;
|
||||||
|
subtitle.setFamily(_family);
|
||||||
subtitle.setPixelSize(20);
|
subtitle.setPixelSize(20);
|
||||||
subtitle.setWeight(QFont::DemiBold);
|
subtitle.setWeight(QFont::DemiBold);
|
||||||
Subtitle(subtitle);
|
Subtitle(subtitle);
|
||||||
|
|
||||||
QFont title;
|
QFont title;
|
||||||
|
title.setFamily(_family);
|
||||||
title.setPixelSize(28);
|
title.setPixelSize(28);
|
||||||
title.setWeight(QFont::DemiBold);
|
title.setWeight(QFont::DemiBold);
|
||||||
Title(title);
|
Title(title);
|
||||||
|
|
||||||
QFont titleLarge;
|
QFont titleLarge;
|
||||||
|
titleLarge.setFamily(_family);
|
||||||
titleLarge.setPixelSize(40);
|
titleLarge.setPixelSize(40);
|
||||||
titleLarge.setWeight(QFont::DemiBold);
|
titleLarge.setWeight(QFont::DemiBold);
|
||||||
TitleLarge(titleLarge);
|
TitleLarge(titleLarge);
|
||||||
|
|
||||||
QFont display;
|
QFont display;
|
||||||
|
display.setFamily(_family);
|
||||||
display.setPixelSize(68);
|
display.setPixelSize(68);
|
||||||
display.setWeight(QFont::DemiBold);
|
display.setWeight(QFont::DemiBold);
|
||||||
Display(display);
|
Display(display);
|
||||||
|
@ -14,6 +14,7 @@ class FluTextStyle : public QObject
|
|||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
public:
|
public:
|
||||||
|
Q_PROPERTY_AUTO(QString,family)
|
||||||
Q_PROPERTY_AUTO(QFont,Caption);
|
Q_PROPERTY_AUTO(QFont,Caption);
|
||||||
Q_PROPERTY_AUTO(QFont,Body);
|
Q_PROPERTY_AUTO(QFont,Body);
|
||||||
Q_PROPERTY_AUTO(QFont,BodyStrong);
|
Q_PROPERTY_AUTO(QFont,BodyStrong);
|
||||||
|
@ -119,8 +119,9 @@ QUrl FluTools::getUrlByFilePath(const QString& path){
|
|||||||
return QUrl::fromLocalFile(path);
|
return QUrl::fromLocalFile(path);
|
||||||
}
|
}
|
||||||
|
|
||||||
QColor FluTools::colorAlpha(const QColor& color,qreal alpha){
|
QColor FluTools::withOpacity(const QColor& color,qreal opacity){
|
||||||
return QColor(color.red(),color.green(),color.blue(),255*alpha);
|
int alpha = qRound(opacity * 255) & 0xff;
|
||||||
|
return QColor::fromRgba((alpha << 24) | (color.rgba() & 0xffffff));
|
||||||
}
|
}
|
||||||
|
|
||||||
QString FluTools::md5(QString text){
|
QString FluTools::md5(QString text){
|
||||||
|
@ -39,7 +39,7 @@ public:
|
|||||||
Q_INVOKABLE QRect getVirtualGeometry();
|
Q_INVOKABLE QRect getVirtualGeometry();
|
||||||
Q_INVOKABLE QString getApplicationDirPath();
|
Q_INVOKABLE QString getApplicationDirPath();
|
||||||
Q_INVOKABLE QUrl getUrlByFilePath(const QString& path);
|
Q_INVOKABLE QUrl getUrlByFilePath(const QString& path);
|
||||||
Q_INVOKABLE QColor colorAlpha(const QColor&,qreal alpha);
|
Q_INVOKABLE QColor withOpacity(const QColor&,qreal alpha);
|
||||||
Q_INVOKABLE QString md5(QString text);
|
Q_INVOKABLE QString md5(QString text);
|
||||||
Q_INVOKABLE QString sha256(QString text);
|
Q_INVOKABLE QString sha256(QString text);
|
||||||
Q_INVOKABLE QString toBase64(QString text);
|
Q_INVOKABLE QString toBase64(QString text);
|
||||||
|
@ -126,6 +126,7 @@ void FluentUI::registerTypes(const char *uri){
|
|||||||
qmlRegisterType(QUrl("qrc:/qt/qml/FluentUI/Controls/FluEvent.qml"),uri,major,minor,"FluEvent");
|
qmlRegisterType(QUrl("qrc:/qt/qml/FluentUI/Controls/FluEvent.qml"),uri,major,minor,"FluEvent");
|
||||||
qmlRegisterType(QUrl("qrc:/qt/qml/FluentUI/Controls/FluSheet.qml"),uri,major,minor,"FluSheet");
|
qmlRegisterType(QUrl("qrc:/qt/qml/FluentUI/Controls/FluSheet.qml"),uri,major,minor,"FluSheet");
|
||||||
qmlRegisterType(QUrl("qrc:/qt/qml/FluentUI/Controls/FluGroupBox.qml"),uri,major,minor,"FluGroupBox");
|
qmlRegisterType(QUrl("qrc:/qt/qml/FluentUI/Controls/FluGroupBox.qml"),uri,major,minor,"FluGroupBox");
|
||||||
|
qmlRegisterType(QUrl("qrc:/qt/qml/FluentUI/Controls/FluControlBackground.qml"),uri,major,minor,"FluControlBackground");
|
||||||
qmlRegisterSingletonType(QUrl("qrc:/qt/qml/FluentUI/Controls/FluRouter.qml"),uri,major,minor,"FluRouter");
|
qmlRegisterSingletonType(QUrl("qrc:/qt/qml/FluentUI/Controls/FluRouter.qml"),uri,major,minor,"FluRouter");
|
||||||
qmlRegisterSingletonType(QUrl("qrc:/qt/qml/FluentUI/Controls/FluEventBus.qml"),uri,major,minor,"FluEventBus");
|
qmlRegisterSingletonType(QUrl("qrc:/qt/qml/FluentUI/Controls/FluEventBus.qml"),uri,major,minor,"FluEventBus");
|
||||||
|
|
||||||
@ -148,11 +149,6 @@ void FluentUI::registerTypes(const char *uri){
|
|||||||
}
|
}
|
||||||
|
|
||||||
void FluentUI::initializeEngine(QQmlEngine *engine, const char *uri){
|
void FluentUI::initializeEngine(QQmlEngine *engine, const char *uri){
|
||||||
#ifdef Q_OS_WIN
|
|
||||||
QFont font;
|
|
||||||
font.setFamily("微软雅黑");
|
|
||||||
QGuiApplication::setFont(font);
|
|
||||||
#endif
|
|
||||||
engine->rootContext()->setContextProperty("FluApp",FluApp::getInstance());
|
engine->rootContext()->setContextProperty("FluApp",FluApp::getInstance());
|
||||||
engine->rootContext()->setContextProperty("FluColors",FluColors::getInstance());
|
engine->rootContext()->setContextProperty("FluColors",FluColors::getInstance());
|
||||||
engine->rootContext()->setContextProperty("FluTheme",FluTheme::getInstance());
|
engine->rootContext()->setContextProperty("FluTheme",FluTheme::getInstance());
|
||||||
|
@ -7,7 +7,7 @@ Button {
|
|||||||
property string contentDescription: ""
|
property string contentDescription: ""
|
||||||
property color normalColor: FluTheme.dark ? Qt.rgba(62/255,62/255,62/255,1) : Qt.rgba(254/255,254/255,254/255,1)
|
property color normalColor: FluTheme.dark ? Qt.rgba(62/255,62/255,62/255,1) : Qt.rgba(254/255,254/255,254/255,1)
|
||||||
property color hoverColor: FluTheme.dark ? Qt.rgba(68/255,68/255,68/255,1) : Qt.rgba(246/255,246/255,246/255,1)
|
property color hoverColor: FluTheme.dark ? Qt.rgba(68/255,68/255,68/255,1) : Qt.rgba(246/255,246/255,246/255,1)
|
||||||
property color disableColor: FluTheme.dark ? Qt.rgba(59/255,59/255,59/255,1) : Qt.rgba(244/255,244/255,244/255,1)
|
property color disableColor: FluTheme.dark ? Qt.rgba(59/255,59/255,59/255,1) : Qt.rgba(251/255,251/255,251/255,1)
|
||||||
property color dividerColor: FluTheme.dark ? Qt.rgba(80/255,80/255,80/255,1) : Qt.rgba(233/255,233/255,233/255,1)
|
property color dividerColor: FluTheme.dark ? Qt.rgba(80/255,80/255,80/255,1) : Qt.rgba(233/255,233/255,233/255,1)
|
||||||
property color textColor: {
|
property color textColor: {
|
||||||
if(FluTheme.dark){
|
if(FluTheme.dark){
|
||||||
@ -38,18 +38,17 @@ Button {
|
|||||||
horizontalPadding:12
|
horizontalPadding:12
|
||||||
font:FluTextStyle.Body
|
font:FluTextStyle.Body
|
||||||
focusPolicy:Qt.TabFocus
|
focusPolicy:Qt.TabFocus
|
||||||
background: Rectangle{
|
background: FluControlBackground{
|
||||||
implicitWidth: 28
|
implicitWidth: 30
|
||||||
implicitHeight: 28
|
implicitHeight: 30
|
||||||
border.color: control.dividerColor
|
|
||||||
border.width: 1
|
|
||||||
radius: 4
|
radius: 4
|
||||||
color:{
|
color: {
|
||||||
if(!enabled){
|
if(!enabled){
|
||||||
return disableColor
|
return disableColor
|
||||||
}
|
}
|
||||||
return hovered ? hoverColor :normalColor
|
return hovered ? hoverColor :normalColor
|
||||||
}
|
}
|
||||||
|
shadow: !pressed && enabled
|
||||||
FluFocusRectangle{
|
FluFocusRectangle{
|
||||||
visible: control.activeFocus
|
visible: control.activeFocus
|
||||||
radius:4
|
radius:4
|
||||||
|
@ -449,7 +449,7 @@ FluButton {
|
|||||||
DayOfWeekRow {
|
DayOfWeekRow {
|
||||||
id: dayOfWeekRow
|
id: dayOfWeekRow
|
||||||
locale: FluApp.locale
|
locale: FluApp.locale
|
||||||
font.bold: false
|
font: FluTextStyle.Body
|
||||||
delegate: Label {
|
delegate: Label {
|
||||||
text: model.shortName
|
text: model.shortName
|
||||||
font: dayOfWeekRow.font
|
font: dayOfWeekRow.font
|
||||||
|
@ -45,7 +45,7 @@ T.ComboBox {
|
|||||||
topPadding: 6 - control.padding
|
topPadding: 6 - control.padding
|
||||||
bottomPadding: 6 - control.padding
|
bottomPadding: 6 - control.padding
|
||||||
renderType: FluTheme.nativeText ? Text.NativeRendering : Text.QtRendering
|
renderType: FluTheme.nativeText ? Text.NativeRendering : Text.QtRendering
|
||||||
selectionColor: FluTools.colorAlpha(FluTheme.primaryColor,0.5)
|
selectionColor: FluTools.withOpacity(FluTheme.primaryColor,0.5)
|
||||||
selectedTextColor: color
|
selectedTextColor: color
|
||||||
text: control.editable ? control.editText : control.displayText
|
text: control.editable ? control.editText : control.displayText
|
||||||
enabled: control.editable
|
enabled: control.editable
|
||||||
@ -67,7 +67,13 @@ T.ComboBox {
|
|||||||
bottomInset:1
|
bottomInset:1
|
||||||
rightInset:1
|
rightInset:1
|
||||||
background: FluTextBoxBackground{
|
background: FluTextBoxBackground{
|
||||||
borderWidth: 0
|
border.width: 0
|
||||||
|
bottomMargin: {
|
||||||
|
if(!control.editable){
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
return contentItem && contentItem.activeFocus ? 2 : 1
|
||||||
|
}
|
||||||
inputItem: contentItem
|
inputItem: contentItem
|
||||||
}
|
}
|
||||||
Component.onCompleted: {
|
Component.onCompleted: {
|
||||||
|
46
src/Qt5/imports/FluentUI/Controls/FluControlBackground.qml
Normal file
46
src/Qt5/imports/FluentUI/Controls/FluControlBackground.qml
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
import QtQuick 2.15
|
||||||
|
import QtQuick.Controls 2.15
|
||||||
|
import FluentUI 1.0
|
||||||
|
|
||||||
|
Item{
|
||||||
|
id:control
|
||||||
|
property int radius: 4
|
||||||
|
property bool shadow: true
|
||||||
|
property alias border: d.border
|
||||||
|
property var bottomMargin: undefined
|
||||||
|
property var topMargin: undefined
|
||||||
|
property var leftMargin: undefined
|
||||||
|
property var rightMargin: undefined
|
||||||
|
property color color: FluTheme.dark ? Qt.rgba(42/255,42/255,42/255,1) : Qt.rgba(254/255,254/255,254/255,1)
|
||||||
|
property alias gradient : rect_border.gradient
|
||||||
|
Rectangle{
|
||||||
|
id:d
|
||||||
|
property color startColor: Qt.lighter(d.border.color,1.25)
|
||||||
|
property color endColor: shadow ? control.border.color : startColor
|
||||||
|
visible: false
|
||||||
|
border.color: FluTheme.dark ? Qt.rgba(48/255,48/255,48/255,1) : Qt.rgba(188/255,188/255,188/255,1)
|
||||||
|
}
|
||||||
|
Rectangle{
|
||||||
|
id:rect_border
|
||||||
|
anchors.fill: parent
|
||||||
|
radius: control.radius
|
||||||
|
gradient: Gradient {
|
||||||
|
GradientStop { position: 0.0; color: d.startColor }
|
||||||
|
GradientStop { position: 0.88; color: d.startColor }
|
||||||
|
GradientStop { position: 1.0; color: d.endColor}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Rectangle{
|
||||||
|
id:rect_back
|
||||||
|
anchors{
|
||||||
|
fill: parent
|
||||||
|
margins: control.border.width
|
||||||
|
topMargin: control.topMargin
|
||||||
|
bottomMargin: control.bottomMargin
|
||||||
|
leftMargin: control.leftMargin
|
||||||
|
rightMargin: control.rightMargin
|
||||||
|
}
|
||||||
|
radius: control.radius
|
||||||
|
color: control.color
|
||||||
|
}
|
||||||
|
}
|
@ -17,7 +17,7 @@ TextEdit {
|
|||||||
selectByMouse: true
|
selectByMouse: true
|
||||||
selectedTextColor: color
|
selectedTextColor: color
|
||||||
bottomPadding: 0
|
bottomPadding: 0
|
||||||
selectionColor: FluTools.colorAlpha(FluTheme.primaryColor,0.5)
|
selectionColor: FluTools.withOpacity(FluTheme.primaryColor,0.5)
|
||||||
font:FluTextStyle.Body
|
font:FluTextStyle.Body
|
||||||
onSelectedTextChanged: {
|
onSelectedTextChanged: {
|
||||||
control.forceActiveFocus()
|
control.forceActiveFocus()
|
||||||
|
@ -42,7 +42,7 @@ FluButton {
|
|||||||
id:divider_1
|
id:divider_1
|
||||||
width: 1
|
width: 1
|
||||||
x: parent.width/3
|
x: parent.width/3
|
||||||
height: parent.height
|
height: parent.height - 1
|
||||||
color: control.dividerColor
|
color: control.dividerColor
|
||||||
visible: showYear
|
visible: showYear
|
||||||
}
|
}
|
||||||
@ -50,7 +50,7 @@ FluButton {
|
|||||||
id:divider_2
|
id:divider_2
|
||||||
width: 1
|
width: 1
|
||||||
x: showYear ? parent.width*2/3 : parent.width/2
|
x: showYear ? parent.width*2/3 : parent.width/2
|
||||||
height: parent.height
|
height: parent.height - 1
|
||||||
color: control.dividerColor
|
color: control.dividerColor
|
||||||
}
|
}
|
||||||
FluText{
|
FluText{
|
||||||
|
@ -3,75 +3,21 @@ import QtQuick.Controls 2.15
|
|||||||
import QtQuick.Window 2.15
|
import QtQuick.Window 2.15
|
||||||
import FluentUI 1.0
|
import FluentUI 1.0
|
||||||
|
|
||||||
Button {
|
FluButton {
|
||||||
property bool disabled: false
|
|
||||||
property string contentDescription: ""
|
|
||||||
property color normalColor: FluTheme.dark ? Qt.rgba(62/255,62/255,62/255,1) : Qt.rgba(254/255,254/255,254/255,1)
|
|
||||||
property color hoverColor: FluTheme.dark ? Qt.rgba(68/255,68/255,68/255,1) : Qt.rgba(246/255,246/255,246/255,1)
|
|
||||||
property color disableColor: FluTheme.dark ? Qt.rgba(59/255,59/255,59/255,1) : Qt.rgba(244/255,244/255,244/255,1)
|
|
||||||
property color textColor: {
|
|
||||||
if(FluTheme.dark){
|
|
||||||
if(!enabled){
|
|
||||||
return Qt.rgba(131/255,131/255,131/255,1)
|
|
||||||
}
|
|
||||||
if(pressed){
|
|
||||||
return Qt.rgba(162/255,162/255,162/255,1)
|
|
||||||
}
|
|
||||||
return Qt.rgba(1,1,1,1)
|
|
||||||
}else{
|
|
||||||
if(!enabled){
|
|
||||||
return Qt.rgba(160/255,160/255,160/255,1)
|
|
||||||
}
|
|
||||||
if(pressed){
|
|
||||||
return Qt.rgba(96/255,96/255,96/255,1)
|
|
||||||
}
|
|
||||||
return Qt.rgba(0,0,0,1)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
property var window : Window.window
|
|
||||||
default property alias contentData: menu.contentData
|
|
||||||
Accessible.role: Accessible.Button
|
|
||||||
Accessible.name: control.text
|
|
||||||
Accessible.description: contentDescription
|
|
||||||
Accessible.onPressAction: control.clicked()
|
|
||||||
id: control
|
id: control
|
||||||
|
default property alias contentData: menu.contentData
|
||||||
rightPadding:35
|
rightPadding:35
|
||||||
enabled: !disabled
|
|
||||||
focusPolicy:Qt.TabFocus
|
|
||||||
verticalPadding: 0
|
verticalPadding: 0
|
||||||
horizontalPadding:12
|
horizontalPadding:12
|
||||||
background: Rectangle{
|
FluIcon{
|
||||||
implicitWidth: 28
|
iconSource:FluentIcons.ChevronDown
|
||||||
implicitHeight: 28
|
iconSize: 15
|
||||||
border.color: FluTheme.dark ? "#505050" : "#DFDFDF"
|
anchors{
|
||||||
border.width: 1
|
right: parent.right
|
||||||
radius: 4
|
rightMargin: 10
|
||||||
FluFocusRectangle{
|
verticalCenter: parent.verticalCenter
|
||||||
visible: control.activeFocus
|
|
||||||
radius:8
|
|
||||||
}
|
}
|
||||||
color:{
|
iconColor:control.textColor
|
||||||
if(!enabled){
|
|
||||||
return disableColor
|
|
||||||
}
|
|
||||||
return hovered ? hoverColor :normalColor
|
|
||||||
}
|
|
||||||
FluIcon{
|
|
||||||
iconSource:FluentIcons.ChevronDown
|
|
||||||
iconSize: 15
|
|
||||||
anchors{
|
|
||||||
right: parent.right
|
|
||||||
rightMargin: 10
|
|
||||||
verticalCenter: parent.verticalCenter
|
|
||||||
}
|
|
||||||
iconColor:title.color
|
|
||||||
}
|
|
||||||
}
|
|
||||||
contentItem: FluText {
|
|
||||||
id:title
|
|
||||||
text: control.text
|
|
||||||
verticalAlignment: Text.AlignVCenter
|
|
||||||
color: control.textColor
|
|
||||||
}
|
}
|
||||||
onClicked: {
|
onClicked: {
|
||||||
if(menu.count !==0){
|
if(menu.count !==0){
|
||||||
|
@ -26,8 +26,8 @@ Item {
|
|||||||
width: parent.width
|
width: parent.width
|
||||||
height: 45
|
height: 45
|
||||||
radius: 4
|
radius: 4
|
||||||
color: FluTheme.dark ? Window.active ? Qt.rgba(38/255,44/255,54/255,1) : Qt.rgba(39/255,39/255,39/255,1) : Qt.rgba(251/255,251/255,253/255,1)
|
border.color: FluTheme.dividerColor
|
||||||
border.color: FluTheme.dark ? Window.active ? Qt.rgba(55/255,55/255,55/255,1) : Qt.rgba(45/255,45/255,45/255,1) : Qt.rgba(226/255,229/255,234/255,1)
|
color: FluTheme.dark ? Window.active ? Qt.rgba(39/255,39/255,39/255,1) : Qt.rgba(39/255,39/255,39/255,1) : Qt.rgba(251/255,251/255,253/255,1)
|
||||||
MouseArea{
|
MouseArea{
|
||||||
id:control_mouse
|
id:control_mouse
|
||||||
anchors.fill: parent
|
anchors.fill: parent
|
||||||
@ -90,7 +90,7 @@ Item {
|
|||||||
radius: 4
|
radius: 4
|
||||||
clip: true
|
clip: true
|
||||||
color: FluTheme.dark ? Qt.rgba(39/255,39/255,39/255,1) : Qt.rgba(251/255,251/255,253/255,1)
|
color: FluTheme.dark ? Qt.rgba(39/255,39/255,39/255,1) : Qt.rgba(251/255,251/255,253/255,1)
|
||||||
border.color: FluTheme.dark ? Qt.rgba(45/255,45/255,45/255,1) : Qt.rgba(226/255,229/255,234/255,1)
|
border.color: FluTheme.dividerColor
|
||||||
anchors.topMargin: -contentHeight
|
anchors.topMargin: -contentHeight
|
||||||
states: [
|
states: [
|
||||||
State{
|
State{
|
||||||
|
@ -29,37 +29,26 @@ Button {
|
|||||||
font:FluTextStyle.Body
|
font:FluTextStyle.Body
|
||||||
verticalPadding: 0
|
verticalPadding: 0
|
||||||
horizontalPadding:12
|
horizontalPadding:12
|
||||||
background: Rectangle{
|
background: FluControlBackground{
|
||||||
implicitWidth: 28
|
implicitWidth: 30
|
||||||
implicitHeight: 28
|
implicitHeight: 30
|
||||||
radius: 4
|
radius: 4
|
||||||
|
bottomMargin: enabled ? 2 : 0
|
||||||
|
border.width: enabled ? 1 : 0
|
||||||
|
border.color: enabled ? Qt.darker(control.normalColor,1.2) : disableColor
|
||||||
|
color:{
|
||||||
|
if(!enabled){
|
||||||
|
return disableColor
|
||||||
|
}
|
||||||
|
if(pressed){
|
||||||
|
return pressedColor
|
||||||
|
}
|
||||||
|
return hovered ? hoverColor :normalColor
|
||||||
|
}
|
||||||
FluFocusRectangle{
|
FluFocusRectangle{
|
||||||
visible: control.visualFocus
|
visible: control.visualFocus
|
||||||
radius:4
|
radius:4
|
||||||
}
|
}
|
||||||
gradient: Gradient {
|
|
||||||
GradientStop { position: 0.33; color: control.enabled ? control.normalColor : Qt.rgba(0,0,0,0) }
|
|
||||||
GradientStop { position: 1.0; color: control.enabled ? Qt.darker(control.normalColor,1.3) : Qt.rgba(0,0,0,0) }
|
|
||||||
}
|
|
||||||
Rectangle{
|
|
||||||
radius: parent.radius
|
|
||||||
anchors{
|
|
||||||
fill: parent
|
|
||||||
topMargin: control.enabled ? 0 : 0
|
|
||||||
leftMargin: control.enabled ? 1 : 0
|
|
||||||
rightMargin: control.enabled ? 1 : 0
|
|
||||||
bottomMargin: control.enabled ? 2 : 0
|
|
||||||
}
|
|
||||||
color:{
|
|
||||||
if(!enabled){
|
|
||||||
return disableColor
|
|
||||||
}
|
|
||||||
if(pressed){
|
|
||||||
return pressedColor
|
|
||||||
}
|
|
||||||
return hovered ? hoverColor :normalColor
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
contentItem: FluText {
|
contentItem: FluText {
|
||||||
text: control.text
|
text: control.text
|
||||||
|
@ -18,7 +18,7 @@ T.Frame {
|
|||||||
background: Rectangle {
|
background: Rectangle {
|
||||||
id:d
|
id:d
|
||||||
radius: 4
|
radius: 4
|
||||||
border.color: FluTheme.dark ? Window.active ? Qt.rgba(55/255,55/255,55/255,1):Qt.rgba(45/255,45/255,45/255,1) : Qt.rgba(226/255,229/255,234/255,1)
|
border.color: FluTheme.dividerColor
|
||||||
color: FluTheme.dark ? Window.active ? Qt.rgba(38/255,44/255,54/255,1) : Qt.rgba(39/255,39/255,39/255,1) : Qt.rgba(251/255,251/255,253/255,1)
|
color: FluTheme.dark ? Window.active ? Qt.rgba(39/255,39/255,39/255,1) : Qt.rgba(45/255,45/255,45/255,1) : Qt.rgba(251/255,251/255,253/255,1)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -51,9 +51,9 @@ T.Menu {
|
|||||||
FluShadow{}
|
FluShadow{}
|
||||||
}
|
}
|
||||||
T.Overlay.modal: Rectangle {
|
T.Overlay.modal: Rectangle {
|
||||||
color: FluTools.colorAlpha(control.palette.shadow, 0.5)
|
color: FluTools.withOpacity(control.palette.shadow, 0.5)
|
||||||
}
|
}
|
||||||
T.Overlay.modeless: Rectangle {
|
T.Overlay.modeless: Rectangle {
|
||||||
color: FluTools.colorAlpha(control.palette.shadow, 0.12)
|
color: FluTools.withOpacity(control.palette.shadow, 0.12)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -25,7 +25,7 @@ TextArea{
|
|||||||
leftPadding: padding+4
|
leftPadding: padding+4
|
||||||
renderType: FluTheme.nativeText ? Text.NativeRendering : Text.QtRendering
|
renderType: FluTheme.nativeText ? Text.NativeRendering : Text.QtRendering
|
||||||
selectedTextColor: color
|
selectedTextColor: color
|
||||||
selectionColor: FluTools.colorAlpha(FluTheme.primaryColor,0.5)
|
selectionColor: FluTools.withOpacity(FluTheme.primaryColor,0.5)
|
||||||
placeholderTextColor: {
|
placeholderTextColor: {
|
||||||
if(!enabled){
|
if(!enabled){
|
||||||
return placeholderDisableColor
|
return placeholderDisableColor
|
||||||
|
@ -25,7 +25,7 @@ TextField{
|
|||||||
leftPadding: padding+4
|
leftPadding: padding+4
|
||||||
echoMode:btn_reveal.pressed ? TextField.Normal : TextField.Password
|
echoMode:btn_reveal.pressed ? TextField.Normal : TextField.Password
|
||||||
renderType: FluTheme.nativeText ? Text.NativeRendering : Text.QtRendering
|
renderType: FluTheme.nativeText ? Text.NativeRendering : Text.QtRendering
|
||||||
selectionColor: FluTools.colorAlpha(FluTheme.primaryColor,0.5)
|
selectionColor: FluTools.withOpacity(FluTheme.primaryColor,0.5)
|
||||||
selectedTextColor: color
|
selectedTextColor: color
|
||||||
placeholderTextColor: {
|
placeholderTextColor: {
|
||||||
if(!enabled){
|
if(!enabled){
|
||||||
|
@ -7,19 +7,18 @@ Page {
|
|||||||
property alias currentIndex: nav_list.currentIndex
|
property alias currentIndex: nav_list.currentIndex
|
||||||
property color textNormalColor: FluTheme.dark ? FluColors.Grey120 : FluColors.Grey120
|
property color textNormalColor: FluTheme.dark ? FluColors.Grey120 : FluColors.Grey120
|
||||||
property color textHoverColor: FluTheme.dark ? FluColors.Grey10 : FluColors.Black
|
property color textHoverColor: FluTheme.dark ? FluColors.Grey10 : FluColors.Black
|
||||||
property int textSize: 28
|
|
||||||
property bool textBold: true
|
|
||||||
property int textSpacing: 10
|
property int textSpacing: 10
|
||||||
property int headerSpacing: 20
|
property int headerSpacing: 20
|
||||||
property int headerHeight: 40
|
property int headerHeight: 40
|
||||||
id:control
|
id:control
|
||||||
width: 400
|
width: 400
|
||||||
height: 300
|
height: 300
|
||||||
|
font: FluTextStyle.Title
|
||||||
implicitHeight: height
|
implicitHeight: height
|
||||||
implicitWidth: width
|
implicitWidth: width
|
||||||
FluObject{
|
FluObject{
|
||||||
id:d
|
id:d
|
||||||
property int tabY: control.headerHeight/2+control.textSize/2 + 3
|
property int tabY: control.headerHeight/2+control.font.pixelSize/2 + 3
|
||||||
}
|
}
|
||||||
background:Item{}
|
background:Item{}
|
||||||
header:ListView{
|
header:ListView{
|
||||||
@ -65,8 +64,7 @@ Page {
|
|||||||
id:item_title
|
id:item_title
|
||||||
text: modelData.title
|
text: modelData.title
|
||||||
anchors.centerIn: parent
|
anchors.centerIn: parent
|
||||||
font.pixelSize: control.textSize
|
font: control.font
|
||||||
font.bold: control.textBold
|
|
||||||
color: {
|
color: {
|
||||||
if(item_button.hovered)
|
if(item_button.hovered)
|
||||||
return textHoverColor
|
return textHoverColor
|
||||||
|
@ -2,14 +2,13 @@ import QtQuick 2.15
|
|||||||
import QtQuick.Controls 2.15
|
import QtQuick.Controls 2.15
|
||||||
import FluentUI 1.0
|
import FluentUI 1.0
|
||||||
|
|
||||||
Button {
|
FluButton {
|
||||||
property real progress
|
property real progress
|
||||||
property bool disabled: false
|
|
||||||
property string contentDescription: ""
|
|
||||||
QtObject{
|
QtObject{
|
||||||
id:d
|
id:d
|
||||||
property bool checked: (rect_back.height === background.height) && (progress === 1)
|
property bool checked: (Number(rect_back.height) === Number(background.height)) && (progress === 1)
|
||||||
}
|
}
|
||||||
|
id: control
|
||||||
property color normalColor: {
|
property color normalColor: {
|
||||||
if(d.checked){
|
if(d.checked){
|
||||||
return FluTheme.primaryColor
|
return FluTheme.primaryColor
|
||||||
@ -32,59 +31,50 @@ Button {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
property color pressedColor: FluTheme.dark ? Qt.darker(normalColor,1.2) : Qt.lighter(normalColor,1.2)
|
property color pressedColor: FluTheme.dark ? Qt.darker(normalColor,1.2) : Qt.lighter(normalColor,1.2)
|
||||||
Accessible.role: Accessible.Button
|
background: FluControlBackground{
|
||||||
Accessible.name: control.text
|
implicitWidth: 30
|
||||||
Accessible.description: contentDescription
|
implicitHeight: 30
|
||||||
Accessible.onPressAction: control.clicked()
|
radius: 4
|
||||||
focusPolicy:Qt.TabFocus
|
border.color: FluTheme.dark ? Qt.rgba(48/255,48/255,48/255,1) : Qt.rgba(188/255,188/255,188/255,1)
|
||||||
id: control
|
border.width: d.checked ? 0 : 1
|
||||||
enabled: !disabled
|
color:{
|
||||||
verticalPadding: 0
|
if(!enabled){
|
||||||
horizontalPadding:12
|
return disableColor
|
||||||
background: FluClip{
|
|
||||||
implicitWidth: 28
|
|
||||||
implicitHeight: 28
|
|
||||||
radius: [4,4,4,4]
|
|
||||||
Rectangle{
|
|
||||||
anchors.fill: parent
|
|
||||||
border.color: FluTheme.dark ? "#505050" : "#DFDFDF"
|
|
||||||
border.width: d.checked ? 0 : 1
|
|
||||||
radius: 4
|
|
||||||
color:{
|
|
||||||
if(!enabled){
|
|
||||||
return disableColor
|
|
||||||
}
|
|
||||||
if(d.checked){
|
|
||||||
if(pressed){
|
|
||||||
return pressedColor
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return hovered ? hoverColor :normalColor
|
|
||||||
}
|
}
|
||||||
|
if(d.checked){
|
||||||
|
if(pressed){
|
||||||
|
return pressedColor
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return hovered ? hoverColor :normalColor
|
||||||
}
|
}
|
||||||
Rectangle{
|
FluClip{
|
||||||
id:rect_back
|
anchors.fill: parent
|
||||||
width: parent.width * control.progress
|
radius: [4,4,4,4]
|
||||||
height: control.progress === 1 ? background.height : 3
|
Rectangle{
|
||||||
visible: !d.checked
|
id:rect_back
|
||||||
color: FluTheme.primaryColor
|
width: parent.width * control.progress
|
||||||
anchors.bottom: parent.bottom
|
height: control.progress === 1 ? background.height : 3
|
||||||
Behavior on height{
|
visible: !d.checked
|
||||||
enabled: control.progress !== 0
|
color: FluTheme.primaryColor
|
||||||
SequentialAnimation {
|
anchors.bottom: parent.bottom
|
||||||
PauseAnimation {
|
Behavior on height{
|
||||||
duration: FluTheme.animationEnabled ? 167 : 0
|
enabled: control.progress !== 0
|
||||||
}
|
SequentialAnimation {
|
||||||
NumberAnimation{
|
PauseAnimation {
|
||||||
duration: FluTheme.animationEnabled ? 167 : 0
|
duration: FluTheme.animationEnabled ? 167 : 0
|
||||||
from: 3
|
}
|
||||||
to: background.height
|
NumberAnimation{
|
||||||
|
duration: FluTheme.animationEnabled ? 167 : 0
|
||||||
|
from: 3
|
||||||
|
to: background.height
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
Behavior on width{
|
||||||
Behavior on width{
|
NumberAnimation{
|
||||||
NumberAnimation{
|
duration: 167
|
||||||
duration: 167
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -131,10 +131,9 @@ FluIconButton {
|
|||||||
width: Math.max(item_text.implicitWidth+12,28)
|
width: Math.max(item_text.implicitWidth+12,28)
|
||||||
height: Math.max(item_text.implicitHeight,28)
|
height: Math.max(item_text.implicitHeight,28)
|
||||||
radius: 4
|
radius: 4
|
||||||
Text{
|
FluText{
|
||||||
id:item_text
|
id:item_text
|
||||||
color: FluTheme.dark ? Qt.rgba(0,0,0,1) : Qt.rgba(1,1,1,1)
|
color: FluTheme.dark ? Qt.rgba(0,0,0,1) : Qt.rgba(1,1,1,1)
|
||||||
font.pixelSize: 13
|
|
||||||
text: keyText
|
text: keyText
|
||||||
anchors.centerIn: parent
|
anchors.centerIn: parent
|
||||||
}
|
}
|
||||||
|
@ -39,7 +39,7 @@ T.SpinBox {
|
|||||||
}
|
}
|
||||||
return normalColor
|
return normalColor
|
||||||
}
|
}
|
||||||
selectionColor: FluTools.colorAlpha(FluTheme.primaryColor,0.5)
|
selectionColor: FluTools.withOpacity(FluTheme.primaryColor,0.5)
|
||||||
selectedTextColor: color
|
selectedTextColor: color
|
||||||
horizontalAlignment: Qt.AlignHCenter
|
horizontalAlignment: Qt.AlignHCenter
|
||||||
verticalAlignment: Qt.AlignVCenter
|
verticalAlignment: Qt.AlignVCenter
|
||||||
|
@ -15,7 +15,7 @@ Rectangle {
|
|||||||
property bool horizonalHeaderVisible: true
|
property bool horizonalHeaderVisible: true
|
||||||
property bool verticalHeaderVisible: true
|
property bool verticalHeaderVisible: true
|
||||||
property color selectedBorderColor: FluTheme.primaryColor
|
property color selectedBorderColor: FluTheme.primaryColor
|
||||||
property color selectedColor: FluTools.colorAlpha(FluTheme.primaryColor,0.3)
|
property color selectedColor: FluTools.withOpacity(FluTheme.primaryColor,0.3)
|
||||||
id:control
|
id:control
|
||||||
color: FluTheme.dark ? Qt.rgba(39/255,39/255,39/255,1) : Qt.rgba(251/255,251/255,253/255,1)
|
color: FluTheme.dark ? Qt.rgba(39/255,39/255,39/255,1) : Qt.rgba(251/255,251/255,253/255,1)
|
||||||
onColumnSourceChanged: {
|
onColumnSourceChanged: {
|
||||||
|
@ -25,7 +25,7 @@ TextField{
|
|||||||
}
|
}
|
||||||
font:FluTextStyle.Body
|
font:FluTextStyle.Body
|
||||||
renderType: FluTheme.nativeText ? Text.NativeRendering : Text.QtRendering
|
renderType: FluTheme.nativeText ? Text.NativeRendering : Text.QtRendering
|
||||||
selectionColor: FluTools.colorAlpha(FluTheme.primaryColor,0.5)
|
selectionColor: FluTools.withOpacity(FluTheme.primaryColor,0.5)
|
||||||
selectedTextColor: color
|
selectedTextColor: color
|
||||||
placeholderTextColor: {
|
placeholderTextColor: {
|
||||||
if(!enabled){
|
if(!enabled){
|
||||||
|
@ -2,55 +2,36 @@ import QtQuick 2.15
|
|||||||
import QtQuick.Controls 2.15
|
import QtQuick.Controls 2.15
|
||||||
import FluentUI 1.0
|
import FluentUI 1.0
|
||||||
|
|
||||||
FluClip{
|
FluControlBackground{
|
||||||
property Item inputItem
|
property Item inputItem
|
||||||
property int borderWidth: 1
|
|
||||||
id:control
|
id:control
|
||||||
radius: [4,4,4,4]
|
color: {
|
||||||
Rectangle{
|
if(inputItem && inputItem.disabled){
|
||||||
radius: 4
|
return FluTheme.dark ? Qt.rgba(59/255,59/255,59/255,1) : Qt.rgba(252/255,252/255,252/255,1)
|
||||||
anchors.fill: parent
|
|
||||||
color: {
|
|
||||||
if(inputItem && inputItem.disabled){
|
|
||||||
return FluTheme.dark ? Qt.rgba(59/255,59/255,59/255,1) : Qt.rgba(252/255,252/255,252/255,1)
|
|
||||||
}
|
|
||||||
if(inputItem && inputItem.activeFocus){
|
|
||||||
return FluTheme.dark ? Qt.rgba(36/255,36/255,36/255,1) : Qt.rgba(1,1,1,1)
|
|
||||||
}
|
|
||||||
if(inputItem && inputItem.hovered){
|
|
||||||
return FluTheme.dark ? Qt.rgba(68/255,68/255,68/255,1) : Qt.rgba(251/255,251/255,251/255,1)
|
|
||||||
}
|
|
||||||
return FluTheme.dark ? Qt.rgba(62/255,62/255,62/255,1) : Qt.rgba(1,1,1,1)
|
|
||||||
}
|
}
|
||||||
border.width: control.borderWidth
|
if(inputItem && inputItem.activeFocus){
|
||||||
border.color: {
|
return FluTheme.dark ? Qt.rgba(36/255,36/255,36/255,1) : Qt.rgba(1,1,1,1)
|
||||||
if(inputItem && inputItem.disabled){
|
|
||||||
return FluTheme.dark ? Qt.rgba(73/255,73/255,73/255,1) : Qt.rgba(237/255,237/255,237/255,1)
|
|
||||||
}
|
|
||||||
return FluTheme.dark ? Qt.rgba(76/255,76/255,76/255,1) : Qt.rgba(240/255,240/255,240/255,1)
|
|
||||||
}
|
}
|
||||||
|
if(inputItem && inputItem.hovered){
|
||||||
|
return FluTheme.dark ? Qt.rgba(68/255,68/255,68/255,1) : Qt.rgba(251/255,251/255,251/255,1)
|
||||||
|
}
|
||||||
|
return FluTheme.dark ? Qt.rgba(62/255,62/255,62/255,1) : Qt.rgba(1,1,1,1)
|
||||||
}
|
}
|
||||||
Rectangle{
|
border.width: 1
|
||||||
width: parent.width
|
gradient: Gradient {
|
||||||
height: inputItem && inputItem.activeFocus ? 2 : 1
|
GradientStop { position: 0.0; color: d.startColor }
|
||||||
anchors.bottom: parent.bottom
|
GradientStop { position: 0.92; color: d.startColor }
|
||||||
visible: !(inputItem && inputItem.disabled)
|
GradientStop { position: 1.0; color: d.endColor }
|
||||||
color: {
|
}
|
||||||
if(inputItem && inputItem.activeFocus){
|
bottomMargin: inputItem && inputItem.activeFocus ? 2 : 1
|
||||||
return FluTheme.primaryColor
|
QtObject{
|
||||||
}
|
id:d
|
||||||
if(FluTheme.dark){
|
property color startColor: FluTheme.dark ? Qt.rgba(66/255,66/255,66/255,1) : Qt.rgba(232/255,232/255,232/255,1)
|
||||||
return Qt.rgba(166/255,166/255,166/255,1)
|
property color endColor: {
|
||||||
}else{
|
if(!control.enabled){
|
||||||
return Qt.rgba(134/255,134/255,134/255,1)
|
return d.startColor
|
||||||
}
|
|
||||||
}
|
|
||||||
Behavior on height{
|
|
||||||
enabled: FluTheme.animationEnabled
|
|
||||||
NumberAnimation{
|
|
||||||
duration: 83
|
|
||||||
easing.type: Easing.OutCubic
|
|
||||||
}
|
}
|
||||||
|
return inputItem && inputItem.activeFocus ? FluTheme.primaryColor : FluTheme.dark ? Qt.rgba(123/255,123/255,123/255,1) : Qt.rgba(132/255,132/255,132/255,1)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -28,8 +28,8 @@ Button {
|
|||||||
enabled: !disabled
|
enabled: !disabled
|
||||||
font:FluTextStyle.Body
|
font:FluTextStyle.Body
|
||||||
background: Rectangle{
|
background: Rectangle{
|
||||||
implicitWidth: 28
|
implicitWidth: 30
|
||||||
implicitHeight: 28
|
implicitHeight: 30
|
||||||
radius: 4
|
radius: 4
|
||||||
color: {
|
color: {
|
||||||
if(!enabled){
|
if(!enabled){
|
||||||
|
@ -58,14 +58,14 @@ FluButton {
|
|||||||
id: divider_1
|
id: divider_1
|
||||||
width: 1
|
width: 1
|
||||||
x: isH ? parent.width/3 : parent.width/2
|
x: isH ? parent.width/3 : parent.width/2
|
||||||
height: parent.height
|
height: parent.height - 1
|
||||||
color: dividerColor
|
color: dividerColor
|
||||||
}
|
}
|
||||||
Rectangle{
|
Rectangle{
|
||||||
id: divider_2
|
id: divider_2
|
||||||
width: 1
|
width: 1
|
||||||
x: parent.width*2/3
|
x: parent.width*2/3
|
||||||
height: parent.height
|
height: parent.height - 1
|
||||||
color: dividerColor
|
color: dividerColor
|
||||||
visible: isH
|
visible: isH
|
||||||
}
|
}
|
||||||
|
@ -23,7 +23,7 @@ Button {
|
|||||||
if(checked){
|
if(checked){
|
||||||
return FluTheme.dark ? Qt.rgba(82/255,82/255,82/255,1) : Qt.rgba(199/255,199/255,199/255,1)
|
return FluTheme.dark ? Qt.rgba(82/255,82/255,82/255,1) : Qt.rgba(199/255,199/255,199/255,1)
|
||||||
}else{
|
}else{
|
||||||
return FluTheme.dark ? Qt.rgba(59/255,59/255,59/255,1) : Qt.rgba(244/255,244/255,244/255,1)
|
return FluTheme.dark ? Qt.rgba(59/255,59/255,59/255,1) : Qt.rgba(251/255,251/255,251/255,1)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
property var clickListener : function(){
|
property var clickListener : function(){
|
||||||
@ -45,45 +45,52 @@ Button {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
onClicked: clickListener()
|
onClicked: clickListener()
|
||||||
background: Rectangle{
|
background: FluControlBackground{
|
||||||
implicitWidth: 28
|
implicitWidth: 30
|
||||||
implicitHeight: 28
|
implicitHeight: 30
|
||||||
radius: 4
|
radius: 4
|
||||||
FluFocusRectangle{
|
FluFocusRectangle{
|
||||||
visible: control.activeFocus
|
visible: control.activeFocus
|
||||||
radius:4
|
radius:4
|
||||||
}
|
}
|
||||||
gradient: Gradient {
|
color:{
|
||||||
GradientStop { position: 0.33; color: control.enabled ? control.normalColor : Qt.rgba(0,0,0,0) }
|
if(!enabled){
|
||||||
GradientStop { position: 1.0; color: control.enabled ? Qt.darker(control.normalColor,1.3) : Qt.rgba(0,0,0,0) }
|
return disableColor
|
||||||
}
|
|
||||||
Rectangle{
|
|
||||||
radius: parent.radius
|
|
||||||
anchors{
|
|
||||||
fill: parent
|
|
||||||
topMargin: checked && enabled ? 0 : 0
|
|
||||||
leftMargin: checked && enabled ? 1 : 0
|
|
||||||
rightMargin: checked && enabled ? 1 : 0
|
|
||||||
bottomMargin: checked && enabled ? 2 : 0
|
|
||||||
}
|
}
|
||||||
color:{
|
if(checked){
|
||||||
if(!enabled){
|
if(pressed){
|
||||||
return disableColor
|
return pressedColor
|
||||||
}
|
}
|
||||||
if(checked){
|
}
|
||||||
if(pressed){
|
return hovered ? hoverColor :normalColor
|
||||||
return pressedColor
|
}
|
||||||
}
|
bottomMargin: {
|
||||||
}
|
if(checked){
|
||||||
return hovered ? hoverColor :normalColor
|
return enabled ? 2 : 0
|
||||||
|
}else{
|
||||||
|
return 1
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Rectangle{
|
border.width: {
|
||||||
color:"#00000000"
|
if(checked){
|
||||||
anchors.fill: parent
|
return enabled ? 1 : 0
|
||||||
border.color: FluTheme.dark ? "#505050" : "#DFDFDF"
|
}else{
|
||||||
border.width: checked ? 0 : 1
|
return 1
|
||||||
radius: parent.radius
|
}
|
||||||
|
}
|
||||||
|
shadow: {
|
||||||
|
if(checked){
|
||||||
|
return true
|
||||||
|
}else{
|
||||||
|
return !pressed && enabled
|
||||||
|
}
|
||||||
|
}
|
||||||
|
border.color: {
|
||||||
|
if(checked){
|
||||||
|
return enabled ? Qt.darker(control.normalColor,1.2) : disableColor
|
||||||
|
}else{
|
||||||
|
return FluTheme.dark ? Qt.rgba(48/255,48/255,48/255,1) : Qt.rgba(188/255,188/255,188/255,1)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
contentItem: FluText {
|
contentItem: FluText {
|
||||||
|
@ -43,9 +43,9 @@ Window {
|
|||||||
property bool useSystemAppBar
|
property bool useSystemAppBar
|
||||||
property color resizeBorderColor: {
|
property color resizeBorderColor: {
|
||||||
if(window.active){
|
if(window.active){
|
||||||
return FluTheme.dark ? "#333333" : "#6E6E6E"
|
return FluTheme.dark ? Qt.rgba(51/255,51/255,51/255,1) : Qt.rgba(110/255,110/255,110/255,1)
|
||||||
}
|
}
|
||||||
return FluTheme.dark ? "#3D3D3E" : "#A7A7A7"
|
return FluTheme.dark ? Qt.rgba(61/255,61/255,61/255,1) : Qt.rgba(167/255,167/255,167/255,1)
|
||||||
}
|
}
|
||||||
property int resizeBorderWidth: 1
|
property int resizeBorderWidth: 1
|
||||||
property var closeListener: function(event){
|
property var closeListener: function(event){
|
||||||
|
@ -19,6 +19,7 @@ FluComboBox 1.0 Controls/FluComboBox.qml
|
|||||||
FluContentDialog 1.0 Controls/FluContentDialog.qml
|
FluContentDialog 1.0 Controls/FluContentDialog.qml
|
||||||
FluContentPage 1.0 Controls/FluContentPage.qml
|
FluContentPage 1.0 Controls/FluContentPage.qml
|
||||||
FluControl 1.0 Controls/FluControl.qml
|
FluControl 1.0 Controls/FluControl.qml
|
||||||
|
FluControlBackground 1.0 Controls/FluControlBackground.qml
|
||||||
FluCopyableText 1.0 Controls/FluCopyableText.qml
|
FluCopyableText 1.0 Controls/FluCopyableText.qml
|
||||||
FluDatePicker 1.0 Controls/FluDatePicker.qml
|
FluDatePicker 1.0 Controls/FluDatePicker.qml
|
||||||
FluDivider 1.0 Controls/FluDivider.qml
|
FluDivider 1.0 Controls/FluDivider.qml
|
||||||
|
@ -109,5 +109,6 @@
|
|||||||
<file>FluentUI/Controls/FluFrame.qml</file>
|
<file>FluentUI/Controls/FluFrame.qml</file>
|
||||||
<file>FluentUI/Controls/FluSheet.qml</file>
|
<file>FluentUI/Controls/FluSheet.qml</file>
|
||||||
<file>FluentUI/Controls/FluGroupBox.qml</file>
|
<file>FluentUI/Controls/FluGroupBox.qml</file>
|
||||||
|
<file>FluentUI/Controls/FluControlBackground.qml</file>
|
||||||
</qresource>
|
</qresource>
|
||||||
</RCC>
|
</RCC>
|
||||||
|
@ -3,12 +3,13 @@ import QtQuick.Controls
|
|||||||
import QtQuick.Controls.Basic
|
import QtQuick.Controls.Basic
|
||||||
import FluentUI
|
import FluentUI
|
||||||
|
|
||||||
|
|
||||||
Button {
|
Button {
|
||||||
property bool disabled: false
|
property bool disabled: false
|
||||||
property string contentDescription: ""
|
property string contentDescription: ""
|
||||||
property color normalColor: FluTheme.dark ? Qt.rgba(62/255,62/255,62/255,1) : Qt.rgba(254/255,254/255,254/255,1)
|
property color normalColor: FluTheme.dark ? Qt.rgba(62/255,62/255,62/255,1) : Qt.rgba(254/255,254/255,254/255,1)
|
||||||
property color hoverColor: FluTheme.dark ? Qt.rgba(68/255,68/255,68/255,1) : Qt.rgba(246/255,246/255,246/255,1)
|
property color hoverColor: FluTheme.dark ? Qt.rgba(68/255,68/255,68/255,1) : Qt.rgba(246/255,246/255,246/255,1)
|
||||||
property color disableColor: FluTheme.dark ? Qt.rgba(59/255,59/255,59/255,1) : Qt.rgba(244/255,244/255,244/255,1)
|
property color disableColor: FluTheme.dark ? Qt.rgba(59/255,59/255,59/255,1) : Qt.rgba(251/255,251/255,251/255,1)
|
||||||
property color dividerColor: FluTheme.dark ? Qt.rgba(80/255,80/255,80/255,1) : Qt.rgba(233/255,233/255,233/255,1)
|
property color dividerColor: FluTheme.dark ? Qt.rgba(80/255,80/255,80/255,1) : Qt.rgba(233/255,233/255,233/255,1)
|
||||||
property color textColor: {
|
property color textColor: {
|
||||||
if(FluTheme.dark){
|
if(FluTheme.dark){
|
||||||
@ -39,18 +40,17 @@ Button {
|
|||||||
horizontalPadding:12
|
horizontalPadding:12
|
||||||
font:FluTextStyle.Body
|
font:FluTextStyle.Body
|
||||||
focusPolicy:Qt.TabFocus
|
focusPolicy:Qt.TabFocus
|
||||||
background: Rectangle{
|
background: FluControlBackground{
|
||||||
implicitWidth: 28
|
implicitWidth: 30
|
||||||
implicitHeight: 28
|
implicitHeight: 30
|
||||||
border.color: control.dividerColor
|
|
||||||
border.width: 1
|
|
||||||
radius: 4
|
radius: 4
|
||||||
color:{
|
color: {
|
||||||
if(!enabled){
|
if(!enabled){
|
||||||
return disableColor
|
return disableColor
|
||||||
}
|
}
|
||||||
return hovered ? hoverColor :normalColor
|
return hovered ? hoverColor :normalColor
|
||||||
}
|
}
|
||||||
|
shadow: !pressed && enabled
|
||||||
FluFocusRectangle{
|
FluFocusRectangle{
|
||||||
visible: control.activeFocus
|
visible: control.activeFocus
|
||||||
radius:4
|
radius:4
|
||||||
|
@ -448,7 +448,7 @@ FluButton {
|
|||||||
DayOfWeekRow {
|
DayOfWeekRow {
|
||||||
id: dayOfWeekRow
|
id: dayOfWeekRow
|
||||||
locale: FluApp.locale
|
locale: FluApp.locale
|
||||||
font.bold: false
|
font: FluTextStyle.Body
|
||||||
delegate: Label {
|
delegate: Label {
|
||||||
text: model.shortName
|
text: model.shortName
|
||||||
font: dayOfWeekRow.font
|
font: dayOfWeekRow.font
|
||||||
|
@ -45,7 +45,7 @@ T.ComboBox {
|
|||||||
topPadding: 6 - control.padding
|
topPadding: 6 - control.padding
|
||||||
bottomPadding: 6 - control.padding
|
bottomPadding: 6 - control.padding
|
||||||
renderType: FluTheme.nativeText ? Text.NativeRendering : Text.QtRendering
|
renderType: FluTheme.nativeText ? Text.NativeRendering : Text.QtRendering
|
||||||
selectionColor: FluTools.colorAlpha(FluTheme.primaryColor,0.5)
|
selectionColor: FluTools.withOpacity(FluTheme.primaryColor,0.5)
|
||||||
selectedTextColor: color
|
selectedTextColor: color
|
||||||
text: control.editable ? control.editText : control.displayText
|
text: control.editable ? control.editText : control.displayText
|
||||||
enabled: control.editable
|
enabled: control.editable
|
||||||
@ -67,7 +67,13 @@ T.ComboBox {
|
|||||||
bottomInset:1
|
bottomInset:1
|
||||||
rightInset:1
|
rightInset:1
|
||||||
background: FluTextBoxBackground{
|
background: FluTextBoxBackground{
|
||||||
borderWidth: 0
|
border.width: 0
|
||||||
|
bottomMargin: {
|
||||||
|
if(!control.editable){
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
return contentItem && contentItem.activeFocus ? 2 : 1
|
||||||
|
}
|
||||||
inputItem: contentItem
|
inputItem: contentItem
|
||||||
}
|
}
|
||||||
Component.onCompleted: {
|
Component.onCompleted: {
|
||||||
|
46
src/Qt6/imports/FluentUI/Controls/FluControlBackground.qml
Normal file
46
src/Qt6/imports/FluentUI/Controls/FluControlBackground.qml
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
import QtQuick
|
||||||
|
import QtQuick.Controls
|
||||||
|
import FluentUI
|
||||||
|
|
||||||
|
Item{
|
||||||
|
id:control
|
||||||
|
property int radius: 4
|
||||||
|
property bool shadow: true
|
||||||
|
property alias border: d.border
|
||||||
|
property var bottomMargin: undefined
|
||||||
|
property var topMargin: undefined
|
||||||
|
property var leftMargin: undefined
|
||||||
|
property var rightMargin: undefined
|
||||||
|
property color color: FluTheme.dark ? Qt.rgba(42/255,42/255,42/255,1) : Qt.rgba(254/255,254/255,254/255,1)
|
||||||
|
property alias gradient : rect_border.gradient
|
||||||
|
Rectangle{
|
||||||
|
id:d
|
||||||
|
property color startColor: Qt.lighter(d.border.color,1.25)
|
||||||
|
property color endColor: shadow ? control.border.color : startColor
|
||||||
|
visible: false
|
||||||
|
border.color: FluTheme.dark ? Qt.rgba(48/255,48/255,48/255,1) : Qt.rgba(188/255,188/255,188/255,1)
|
||||||
|
}
|
||||||
|
Rectangle{
|
||||||
|
id:rect_border
|
||||||
|
anchors.fill: parent
|
||||||
|
radius: control.radius
|
||||||
|
gradient: Gradient {
|
||||||
|
GradientStop { position: 0.0; color: d.startColor }
|
||||||
|
GradientStop { position: 0.88; color: d.startColor }
|
||||||
|
GradientStop { position: 1.0; color: d.endColor}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Rectangle{
|
||||||
|
id:rect_back
|
||||||
|
anchors{
|
||||||
|
fill: parent
|
||||||
|
margins: control.border.width
|
||||||
|
topMargin: control.topMargin
|
||||||
|
bottomMargin: control.bottomMargin
|
||||||
|
leftMargin: control.leftMargin
|
||||||
|
rightMargin: control.rightMargin
|
||||||
|
}
|
||||||
|
radius: control.radius
|
||||||
|
color: control.color
|
||||||
|
}
|
||||||
|
}
|
@ -17,7 +17,7 @@ TextEdit {
|
|||||||
selectByMouse: true
|
selectByMouse: true
|
||||||
selectedTextColor: color
|
selectedTextColor: color
|
||||||
bottomPadding: 0
|
bottomPadding: 0
|
||||||
selectionColor: FluTools.colorAlpha(FluTheme.primaryColor,0.5)
|
selectionColor: FluTools.withOpacity(FluTheme.primaryColor,0.5)
|
||||||
font:FluTextStyle.Body
|
font:FluTextStyle.Body
|
||||||
onSelectedTextChanged: {
|
onSelectedTextChanged: {
|
||||||
control.forceActiveFocus()
|
control.forceActiveFocus()
|
||||||
|
@ -41,7 +41,7 @@ FluButton {
|
|||||||
id:divider_1
|
id:divider_1
|
||||||
width: 1
|
width: 1
|
||||||
x: parent.width/3
|
x: parent.width/3
|
||||||
height: parent.height
|
height: parent.height-1
|
||||||
color: control.dividerColor
|
color: control.dividerColor
|
||||||
visible: showYear
|
visible: showYear
|
||||||
}
|
}
|
||||||
@ -49,7 +49,7 @@ FluButton {
|
|||||||
id:divider_2
|
id:divider_2
|
||||||
width: 1
|
width: 1
|
||||||
x: showYear ? parent.width*2/3 : parent.width/2
|
x: showYear ? parent.width*2/3 : parent.width/2
|
||||||
height: parent.height
|
height: parent.height-1
|
||||||
color: control.dividerColor
|
color: control.dividerColor
|
||||||
}
|
}
|
||||||
FluText{
|
FluText{
|
||||||
|
@ -4,75 +4,21 @@ import QtQuick.Controls.Basic
|
|||||||
import QtQuick.Window
|
import QtQuick.Window
|
||||||
import FluentUI
|
import FluentUI
|
||||||
|
|
||||||
Button {
|
FluButton {
|
||||||
property bool disabled: false
|
|
||||||
property string contentDescription: ""
|
|
||||||
property color normalColor: FluTheme.dark ? Qt.rgba(62/255,62/255,62/255,1) : Qt.rgba(254/255,254/255,254/255,1)
|
|
||||||
property color hoverColor: FluTheme.dark ? Qt.rgba(68/255,68/255,68/255,1) : Qt.rgba(246/255,246/255,246/255,1)
|
|
||||||
property color disableColor: FluTheme.dark ? Qt.rgba(59/255,59/255,59/255,1) : Qt.rgba(244/255,244/255,244/255,1)
|
|
||||||
property color textColor: {
|
|
||||||
if(FluTheme.dark){
|
|
||||||
if(!enabled){
|
|
||||||
return Qt.rgba(131/255,131/255,131/255,1)
|
|
||||||
}
|
|
||||||
if(pressed){
|
|
||||||
return Qt.rgba(162/255,162/255,162/255,1)
|
|
||||||
}
|
|
||||||
return Qt.rgba(1,1,1,1)
|
|
||||||
}else{
|
|
||||||
if(!enabled){
|
|
||||||
return Qt.rgba(160/255,160/255,160/255,1)
|
|
||||||
}
|
|
||||||
if(pressed){
|
|
||||||
return Qt.rgba(96/255,96/255,96/255,1)
|
|
||||||
}
|
|
||||||
return Qt.rgba(0,0,0,1)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
property var window : Window.window
|
|
||||||
default property alias contentData: menu.contentData
|
|
||||||
Accessible.role: Accessible.Button
|
|
||||||
Accessible.name: control.text
|
|
||||||
Accessible.description: contentDescription
|
|
||||||
Accessible.onPressAction: control.clicked()
|
|
||||||
id: control
|
id: control
|
||||||
|
default property alias contentData: menu.contentData
|
||||||
rightPadding:35
|
rightPadding:35
|
||||||
enabled: !disabled
|
|
||||||
focusPolicy:Qt.TabFocus
|
|
||||||
verticalPadding: 0
|
verticalPadding: 0
|
||||||
horizontalPadding:12
|
horizontalPadding:12
|
||||||
background: Rectangle{
|
FluIcon{
|
||||||
implicitWidth: 28
|
iconSource:FluentIcons.ChevronDown
|
||||||
implicitHeight: 28
|
iconSize: 15
|
||||||
border.color: FluTheme.dark ? "#505050" : "#DFDFDF"
|
anchors{
|
||||||
border.width: 1
|
right: parent.right
|
||||||
radius: 4
|
rightMargin: 10
|
||||||
FluFocusRectangle{
|
verticalCenter: parent.verticalCenter
|
||||||
visible: control.activeFocus
|
|
||||||
radius:8
|
|
||||||
}
|
}
|
||||||
color:{
|
iconColor:control.textColor
|
||||||
if(!enabled){
|
|
||||||
return disableColor
|
|
||||||
}
|
|
||||||
return hovered ? hoverColor :normalColor
|
|
||||||
}
|
|
||||||
FluIcon{
|
|
||||||
iconSource:FluentIcons.ChevronDown
|
|
||||||
iconSize: 15
|
|
||||||
anchors{
|
|
||||||
right: parent.right
|
|
||||||
rightMargin: 10
|
|
||||||
verticalCenter: parent.verticalCenter
|
|
||||||
}
|
|
||||||
iconColor:title.color
|
|
||||||
}
|
|
||||||
}
|
|
||||||
contentItem: FluText {
|
|
||||||
id:title
|
|
||||||
text: control.text
|
|
||||||
verticalAlignment: Text.AlignVCenter
|
|
||||||
color: control.textColor
|
|
||||||
}
|
}
|
||||||
onClicked: {
|
onClicked: {
|
||||||
if(menu.count !==0){
|
if(menu.count !==0){
|
||||||
|
@ -26,8 +26,8 @@ Item {
|
|||||||
width: parent.width
|
width: parent.width
|
||||||
height: 45
|
height: 45
|
||||||
radius: 4
|
radius: 4
|
||||||
color: FluTheme.dark ? Window.active ? Qt.rgba(38/255,44/255,54/255,1) : Qt.rgba(39/255,39/255,39/255,1) : Qt.rgba(251/255,251/255,253/255,1)
|
border.color: FluTheme.dividerColor
|
||||||
border.color: FluTheme.dark ? Window.active ? Qt.rgba(55/255,55/255,55/255,1) : Qt.rgba(45/255,45/255,45/255,1) : Qt.rgba(226/255,229/255,234/255,1)
|
color: FluTheme.dark ? Window.active ? Qt.rgba(39/255,39/255,39/255,1) : Qt.rgba(39/255,39/255,39/255,1) : Qt.rgba(251/255,251/255,253/255,1)
|
||||||
MouseArea{
|
MouseArea{
|
||||||
id:control_mouse
|
id:control_mouse
|
||||||
anchors.fill: parent
|
anchors.fill: parent
|
||||||
@ -90,7 +90,7 @@ Item {
|
|||||||
radius: 4
|
radius: 4
|
||||||
clip: true
|
clip: true
|
||||||
color: FluTheme.dark ? Qt.rgba(39/255,39/255,39/255,1) : Qt.rgba(251/255,251/255,253/255,1)
|
color: FluTheme.dark ? Qt.rgba(39/255,39/255,39/255,1) : Qt.rgba(251/255,251/255,253/255,1)
|
||||||
border.color: FluTheme.dark ? Qt.rgba(45/255,45/255,45/255,1) : Qt.rgba(226/255,229/255,234/255,1)
|
border.color: FluTheme.dividerColor
|
||||||
anchors.topMargin: -contentHeight
|
anchors.topMargin: -contentHeight
|
||||||
states: [
|
states: [
|
||||||
State{
|
State{
|
||||||
|
@ -30,37 +30,26 @@ Button {
|
|||||||
font:FluTextStyle.Body
|
font:FluTextStyle.Body
|
||||||
verticalPadding: 0
|
verticalPadding: 0
|
||||||
horizontalPadding:12
|
horizontalPadding:12
|
||||||
background: Rectangle{
|
background: FluControlBackground{
|
||||||
implicitWidth: 28
|
implicitWidth: 30
|
||||||
implicitHeight: 28
|
implicitHeight: 30
|
||||||
radius: 4
|
radius: 4
|
||||||
|
bottomMargin: enabled ? 2 : 0
|
||||||
|
border.width: enabled ? 1 : 0
|
||||||
|
border.color: enabled ? Qt.darker(control.normalColor,1.2) : disableColor
|
||||||
|
color:{
|
||||||
|
if(!enabled){
|
||||||
|
return disableColor
|
||||||
|
}
|
||||||
|
if(pressed){
|
||||||
|
return pressedColor
|
||||||
|
}
|
||||||
|
return hovered ? hoverColor :normalColor
|
||||||
|
}
|
||||||
FluFocusRectangle{
|
FluFocusRectangle{
|
||||||
visible: control.visualFocus
|
visible: control.visualFocus
|
||||||
radius:4
|
radius:4
|
||||||
}
|
}
|
||||||
gradient: Gradient {
|
|
||||||
GradientStop { position: 0.33; color: control.enabled ? control.normalColor : Qt.rgba(0,0,0,0) }
|
|
||||||
GradientStop { position: 1.0; color: control.enabled ? Qt.darker(control.normalColor,1.3) : Qt.rgba(0,0,0,0) }
|
|
||||||
}
|
|
||||||
Rectangle{
|
|
||||||
radius: parent.radius
|
|
||||||
anchors{
|
|
||||||
fill: parent
|
|
||||||
topMargin: control.enabled ? 0 : 0
|
|
||||||
leftMargin: control.enabled ? 1 : 0
|
|
||||||
rightMargin: control.enabled ? 1 : 0
|
|
||||||
bottomMargin: control.enabled ? 2 : 0
|
|
||||||
}
|
|
||||||
color:{
|
|
||||||
if(!enabled){
|
|
||||||
return disableColor
|
|
||||||
}
|
|
||||||
if(pressed){
|
|
||||||
return pressedColor
|
|
||||||
}
|
|
||||||
return hovered ? hoverColor :normalColor
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
contentItem: FluText {
|
contentItem: FluText {
|
||||||
text: control.text
|
text: control.text
|
||||||
|
@ -16,7 +16,7 @@ T.Frame {
|
|||||||
background: Rectangle {
|
background: Rectangle {
|
||||||
id:d
|
id:d
|
||||||
radius: 4
|
radius: 4
|
||||||
border.color: FluTheme.dark ? Window.active ? Qt.rgba(55/255,55/255,55/255,1):Qt.rgba(45/255,45/255,45/255,1) : Qt.rgba(226/255,229/255,234/255,1)
|
border.color: FluTheme.dividerColor
|
||||||
color: FluTheme.dark ? Window.active ? Qt.rgba(38/255,44/255,54/255,1) : Qt.rgba(39/255,39/255,39/255,1) : Qt.rgba(251/255,251/255,253/255,1)
|
color: FluTheme.dark ? Window.active ? Qt.rgba(39/255,39/255,39/255,1) : Qt.rgba(45/255,45/255,45/255,1) : Qt.rgba(251/255,251/255,253/255,1)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -51,9 +51,9 @@ T.Menu {
|
|||||||
FluShadow{}
|
FluShadow{}
|
||||||
}
|
}
|
||||||
T.Overlay.modal: Rectangle {
|
T.Overlay.modal: Rectangle {
|
||||||
color: Color.transparent(control.palette.shadow, 0.5)
|
color: FluTools.withOpacity(control.palette.shadow, 0.5)
|
||||||
}
|
}
|
||||||
T.Overlay.modeless: Rectangle {
|
T.Overlay.modeless: Rectangle {
|
||||||
color: Color.transparent(control.palette.shadow, 0.12)
|
color: FluTools.withOpacity(control.palette.shadow, 0.12)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -26,7 +26,7 @@ TextArea{
|
|||||||
leftPadding: padding+4
|
leftPadding: padding+4
|
||||||
renderType: FluTheme.nativeText ? Text.NativeRendering : Text.QtRendering
|
renderType: FluTheme.nativeText ? Text.NativeRendering : Text.QtRendering
|
||||||
selectedTextColor: color
|
selectedTextColor: color
|
||||||
selectionColor: FluTools.colorAlpha(FluTheme.primaryColor,0.5)
|
selectionColor: FluTools.withOpacity(FluTheme.primaryColor,0.5)
|
||||||
placeholderTextColor: {
|
placeholderTextColor: {
|
||||||
if(!enabled){
|
if(!enabled){
|
||||||
return placeholderDisableColor
|
return placeholderDisableColor
|
||||||
|
@ -26,7 +26,7 @@ TextField{
|
|||||||
leftPadding: padding+4
|
leftPadding: padding+4
|
||||||
echoMode:btn_reveal.pressed ? TextField.Normal : TextField.Password
|
echoMode:btn_reveal.pressed ? TextField.Normal : TextField.Password
|
||||||
renderType: FluTheme.nativeText ? Text.NativeRendering : Text.QtRendering
|
renderType: FluTheme.nativeText ? Text.NativeRendering : Text.QtRendering
|
||||||
selectionColor: FluTools.colorAlpha(FluTheme.primaryColor,0.5)
|
selectionColor: FluTools.withOpacity(FluTheme.primaryColor,0.5)
|
||||||
selectedTextColor: color
|
selectedTextColor: color
|
||||||
placeholderTextColor: {
|
placeholderTextColor: {
|
||||||
if(!enabled){
|
if(!enabled){
|
||||||
|
@ -8,19 +8,18 @@ Page {
|
|||||||
property alias currentIndex: nav_list.currentIndex
|
property alias currentIndex: nav_list.currentIndex
|
||||||
property color textNormalColor: FluTheme.dark ? FluColors.Grey120 : FluColors.Grey120
|
property color textNormalColor: FluTheme.dark ? FluColors.Grey120 : FluColors.Grey120
|
||||||
property color textHoverColor: FluTheme.dark ? FluColors.Grey10 : FluColors.Black
|
property color textHoverColor: FluTheme.dark ? FluColors.Grey10 : FluColors.Black
|
||||||
property int textSize: 28
|
|
||||||
property bool textBold: true
|
|
||||||
property int textSpacing: 10
|
property int textSpacing: 10
|
||||||
property int headerSpacing: 20
|
property int headerSpacing: 20
|
||||||
property int headerHeight: 40
|
property int headerHeight: 40
|
||||||
id:control
|
id:control
|
||||||
width: 400
|
width: 400
|
||||||
height: 300
|
height: 300
|
||||||
|
font: FluTextStyle.Title
|
||||||
implicitHeight: height
|
implicitHeight: height
|
||||||
implicitWidth: width
|
implicitWidth: width
|
||||||
FluObject{
|
FluObject{
|
||||||
id:d
|
id:d
|
||||||
property int tabY: control.headerHeight/2+control.textSize/2 + 3
|
property int tabY: control.headerHeight/2+control.font.pixelSize/2 + 3
|
||||||
}
|
}
|
||||||
background:Item{}
|
background:Item{}
|
||||||
header:ListView{
|
header:ListView{
|
||||||
@ -66,10 +65,9 @@ Page {
|
|||||||
id:item_title
|
id:item_title
|
||||||
text: modelData.title
|
text: modelData.title
|
||||||
anchors.centerIn: parent
|
anchors.centerIn: parent
|
||||||
font.pixelSize: control.textSize
|
font: control.font
|
||||||
font.bold: control.textBold
|
|
||||||
color: {
|
color: {
|
||||||
if(item_button.hovered || nav_list.currentIndex === index)
|
if(item_button.hovered)
|
||||||
return textHoverColor
|
return textHoverColor
|
||||||
return textNormalColor
|
return textNormalColor
|
||||||
}
|
}
|
||||||
|
@ -3,14 +3,13 @@ import QtQuick.Controls
|
|||||||
import QtQuick.Controls.Basic
|
import QtQuick.Controls.Basic
|
||||||
import FluentUI
|
import FluentUI
|
||||||
|
|
||||||
Button {
|
FluButton {
|
||||||
property real progress
|
property real progress
|
||||||
property bool disabled: false
|
|
||||||
property string contentDescription: ""
|
|
||||||
QtObject{
|
QtObject{
|
||||||
id:d
|
id:d
|
||||||
property bool checked: (rect_back.height === background.height) && (progress === 1)
|
property bool checked: (Number(rect_back.height) === Number(background.height)) && (progress === 1)
|
||||||
}
|
}
|
||||||
|
id: control
|
||||||
property color normalColor: {
|
property color normalColor: {
|
||||||
if(d.checked){
|
if(d.checked){
|
||||||
return FluTheme.primaryColor
|
return FluTheme.primaryColor
|
||||||
@ -33,59 +32,50 @@ Button {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
property color pressedColor: FluTheme.dark ? Qt.darker(normalColor,1.2) : Qt.lighter(normalColor,1.2)
|
property color pressedColor: FluTheme.dark ? Qt.darker(normalColor,1.2) : Qt.lighter(normalColor,1.2)
|
||||||
Accessible.role: Accessible.Button
|
background: FluControlBackground{
|
||||||
Accessible.name: control.text
|
implicitWidth: 30
|
||||||
Accessible.description: contentDescription
|
implicitHeight: 30
|
||||||
Accessible.onPressAction: control.clicked()
|
radius: 4
|
||||||
focusPolicy:Qt.TabFocus
|
border.color: FluTheme.dark ? Qt.rgba(48/255,48/255,48/255,1) : Qt.rgba(188/255,188/255,188/255,1)
|
||||||
id: control
|
border.width: d.checked ? 0 : 1
|
||||||
enabled: !disabled
|
color:{
|
||||||
verticalPadding: 0
|
if(!enabled){
|
||||||
horizontalPadding:12
|
return disableColor
|
||||||
background: FluClip{
|
|
||||||
implicitWidth: 28
|
|
||||||
implicitHeight: 28
|
|
||||||
radius: [4,4,4,4]
|
|
||||||
Rectangle{
|
|
||||||
anchors.fill: parent
|
|
||||||
border.color: FluTheme.dark ? "#505050" : "#DFDFDF"
|
|
||||||
border.width: d.checked ? 0 : 1
|
|
||||||
radius: 4
|
|
||||||
color:{
|
|
||||||
if(!enabled){
|
|
||||||
return disableColor
|
|
||||||
}
|
|
||||||
if(d.checked){
|
|
||||||
if(pressed){
|
|
||||||
return pressedColor
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return hovered ? hoverColor :normalColor
|
|
||||||
}
|
}
|
||||||
|
if(d.checked){
|
||||||
|
if(pressed){
|
||||||
|
return pressedColor
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return hovered ? hoverColor :normalColor
|
||||||
}
|
}
|
||||||
Rectangle{
|
FluClip{
|
||||||
id:rect_back
|
anchors.fill: parent
|
||||||
width: parent.width * control.progress
|
radius: [4,4,4,4]
|
||||||
height: control.progress === 1 ? background.height : 3
|
Rectangle{
|
||||||
visible: !d.checked
|
id:rect_back
|
||||||
color: FluTheme.primaryColor
|
width: parent.width * control.progress
|
||||||
anchors.bottom: parent.bottom
|
height: control.progress === 1 ? background.height : 3
|
||||||
Behavior on height{
|
visible: !d.checked
|
||||||
enabled: control.progress !== 0
|
color: FluTheme.primaryColor
|
||||||
SequentialAnimation {
|
anchors.bottom: parent.bottom
|
||||||
PauseAnimation {
|
Behavior on height{
|
||||||
duration: FluTheme.animationEnabled ? 167 : 0
|
enabled: control.progress !== 0
|
||||||
}
|
SequentialAnimation {
|
||||||
NumberAnimation{
|
PauseAnimation {
|
||||||
duration: FluTheme.animationEnabled ? 167 : 0
|
duration: FluTheme.animationEnabled ? 167 : 0
|
||||||
from: 3
|
}
|
||||||
to: background.height
|
NumberAnimation{
|
||||||
|
duration: FluTheme.animationEnabled ? 167 : 0
|
||||||
|
from: 3
|
||||||
|
to: background.height
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
Behavior on width{
|
||||||
Behavior on width{
|
NumberAnimation{
|
||||||
NumberAnimation{
|
duration: 167
|
||||||
duration: 167
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -131,10 +131,9 @@ FluIconButton {
|
|||||||
width: Math.max(item_text.implicitWidth+12,28)
|
width: Math.max(item_text.implicitWidth+12,28)
|
||||||
height: Math.max(item_text.implicitHeight,28)
|
height: Math.max(item_text.implicitHeight,28)
|
||||||
radius: 4
|
radius: 4
|
||||||
Text{
|
FluText{
|
||||||
id:item_text
|
id:item_text
|
||||||
color: FluTheme.dark ? Qt.rgba(0,0,0,1) : Qt.rgba(1,1,1,1)
|
color: FluTheme.dark ? Qt.rgba(0,0,0,1) : Qt.rgba(1,1,1,1)
|
||||||
font.pixelSize: 13
|
|
||||||
text: keyText
|
text: keyText
|
||||||
anchors.centerIn: parent
|
anchors.centerIn: parent
|
||||||
}
|
}
|
||||||
|
@ -40,7 +40,7 @@ T.SpinBox {
|
|||||||
}
|
}
|
||||||
return normalColor
|
return normalColor
|
||||||
}
|
}
|
||||||
selectionColor: FluTools.colorAlpha(FluTheme.primaryColor,0.5)
|
selectionColor: FluTools.withOpacity(FluTheme.primaryColor,0.5)
|
||||||
selectedTextColor: color
|
selectedTextColor: color
|
||||||
horizontalAlignment: Qt.AlignHCenter
|
horizontalAlignment: Qt.AlignHCenter
|
||||||
verticalAlignment: Qt.AlignVCenter
|
verticalAlignment: Qt.AlignVCenter
|
||||||
|
@ -16,7 +16,7 @@ Rectangle {
|
|||||||
property bool horizonalHeaderVisible: true
|
property bool horizonalHeaderVisible: true
|
||||||
property bool verticalHeaderVisible: true
|
property bool verticalHeaderVisible: true
|
||||||
property color selectedBorderColor: FluTheme.primaryColor
|
property color selectedBorderColor: FluTheme.primaryColor
|
||||||
property color selectedColor: FluTools.colorAlpha(FluTheme.primaryColor,0.3)
|
property color selectedColor: FluTools.withOpacity(FluTheme.primaryColor,0.3)
|
||||||
id:control
|
id:control
|
||||||
color: FluTheme.dark ? Qt.rgba(39/255,39/255,39/255,1) : Qt.rgba(251/255,251/255,253/255,1)
|
color: FluTheme.dark ? Qt.rgba(39/255,39/255,39/255,1) : Qt.rgba(251/255,251/255,253/255,1)
|
||||||
onColumnSourceChanged: {
|
onColumnSourceChanged: {
|
||||||
|
@ -26,7 +26,7 @@ TextField{
|
|||||||
}
|
}
|
||||||
font:FluTextStyle.Body
|
font:FluTextStyle.Body
|
||||||
renderType: FluTheme.nativeText ? Text.NativeRendering : Text.QtRendering
|
renderType: FluTheme.nativeText ? Text.NativeRendering : Text.QtRendering
|
||||||
selectionColor: FluTools.colorAlpha(FluTheme.primaryColor,0.5)
|
selectionColor: FluTools.withOpacity(FluTheme.primaryColor,0.5)
|
||||||
selectedTextColor: color
|
selectedTextColor: color
|
||||||
placeholderTextColor: {
|
placeholderTextColor: {
|
||||||
if(!enabled){
|
if(!enabled){
|
||||||
|
@ -2,55 +2,37 @@ import QtQuick
|
|||||||
import QtQuick.Controls
|
import QtQuick.Controls
|
||||||
import FluentUI
|
import FluentUI
|
||||||
|
|
||||||
FluClip{
|
FluControlBackground{
|
||||||
property Item inputItem
|
property Item inputItem
|
||||||
property int borderWidth: 1
|
|
||||||
id:control
|
id:control
|
||||||
radius: [4,4,4,4]
|
color: {
|
||||||
Rectangle{
|
if(inputItem && inputItem.disabled){
|
||||||
radius: 4
|
return FluTheme.dark ? Qt.rgba(59/255,59/255,59/255,1) : Qt.rgba(252/255,252/255,252/255,1)
|
||||||
anchors.fill: parent
|
|
||||||
color: {
|
|
||||||
if(inputItem && inputItem.disabled){
|
|
||||||
return FluTheme.dark ? Qt.rgba(59/255,59/255,59/255,1) : Qt.rgba(252/255,252/255,252/255,1)
|
|
||||||
}
|
|
||||||
if(inputItem && inputItem.activeFocus){
|
|
||||||
return FluTheme.dark ? Qt.rgba(36/255,36/255,36/255,1) : Qt.rgba(1,1,1,1)
|
|
||||||
}
|
|
||||||
if(inputItem && inputItem.hovered){
|
|
||||||
return FluTheme.dark ? Qt.rgba(68/255,68/255,68/255,1) : Qt.rgba(251/255,251/255,251/255,1)
|
|
||||||
}
|
|
||||||
return FluTheme.dark ? Qt.rgba(62/255,62/255,62/255,1) : Qt.rgba(1,1,1,1)
|
|
||||||
}
|
}
|
||||||
border.width: control.borderWidth
|
if(inputItem && inputItem.activeFocus){
|
||||||
border.color: {
|
return FluTheme.dark ? Qt.rgba(36/255,36/255,36/255,1) : Qt.rgba(1,1,1,1)
|
||||||
if(inputItem && inputItem.disabled){
|
|
||||||
return FluTheme.dark ? Qt.rgba(73/255,73/255,73/255,1) : Qt.rgba(237/255,237/255,237/255,1)
|
|
||||||
}
|
|
||||||
return FluTheme.dark ? Qt.rgba(76/255,76/255,76/255,1) : Qt.rgba(240/255,240/255,240/255,1)
|
|
||||||
}
|
}
|
||||||
|
if(inputItem && inputItem.hovered){
|
||||||
|
return FluTheme.dark ? Qt.rgba(68/255,68/255,68/255,1) : Qt.rgba(251/255,251/255,251/255,1)
|
||||||
|
}
|
||||||
|
return FluTheme.dark ? Qt.rgba(62/255,62/255,62/255,1) : Qt.rgba(1,1,1,1)
|
||||||
}
|
}
|
||||||
Rectangle{
|
border.width: 1
|
||||||
width: parent.width
|
gradient: Gradient {
|
||||||
height: inputItem && inputItem.activeFocus ? 2 : 1
|
GradientStop { position: 0.0; color: d.startColor }
|
||||||
anchors.bottom: parent.bottom
|
GradientStop { position: d.position; color: d.startColor }
|
||||||
visible: !(inputItem && inputItem.disabled)
|
GradientStop { position: 1.0; color: d.endColor }
|
||||||
color: {
|
}
|
||||||
if(inputItem && inputItem.activeFocus){
|
bottomMargin: inputItem && inputItem.activeFocus ? 2 : 1
|
||||||
return FluTheme.primaryColor
|
QtObject{
|
||||||
}
|
id:d
|
||||||
if(FluTheme.dark){
|
property real position: 1 - 3/control.height
|
||||||
return Qt.rgba(166/255,166/255,166/255,1)
|
property color startColor: FluTheme.dark ? Qt.rgba(66/255,66/255,66/255,1) : Qt.rgba(232/255,232/255,232/255,1)
|
||||||
}else{
|
property color endColor: {
|
||||||
return Qt.rgba(134/255,134/255,134/255,1)
|
if(!control.enabled){
|
||||||
}
|
return d.startColor
|
||||||
}
|
|
||||||
Behavior on height{
|
|
||||||
enabled: FluTheme.animationEnabled
|
|
||||||
NumberAnimation{
|
|
||||||
duration: 83
|
|
||||||
easing.type: Easing.OutCubic
|
|
||||||
}
|
}
|
||||||
|
return inputItem && inputItem.activeFocus ? FluTheme.primaryColor : FluTheme.dark ? Qt.rgba(123/255,123/255,123/255,1) : Qt.rgba(132/255,132/255,132/255,1)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -29,8 +29,8 @@ Button {
|
|||||||
enabled: !disabled
|
enabled: !disabled
|
||||||
font:FluTextStyle.Body
|
font:FluTextStyle.Body
|
||||||
background: Rectangle{
|
background: Rectangle{
|
||||||
implicitWidth: 28
|
implicitWidth: 30
|
||||||
implicitHeight: 28
|
implicitHeight: 30
|
||||||
radius: 4
|
radius: 4
|
||||||
color: {
|
color: {
|
||||||
if(!enabled){
|
if(!enabled){
|
||||||
|
@ -58,14 +58,14 @@ FluButton {
|
|||||||
id: divider_1
|
id: divider_1
|
||||||
width: 1
|
width: 1
|
||||||
x: isH ? parent.width/3 : parent.width/2
|
x: isH ? parent.width/3 : parent.width/2
|
||||||
height: parent.height
|
height: parent.height-1
|
||||||
color: dividerColor
|
color: dividerColor
|
||||||
}
|
}
|
||||||
Rectangle{
|
Rectangle{
|
||||||
id: divider_2
|
id: divider_2
|
||||||
width: 1
|
width: 1
|
||||||
x: parent.width*2/3
|
x: parent.width*2/3
|
||||||
height: parent.height
|
height: parent.height-1
|
||||||
color: dividerColor
|
color: dividerColor
|
||||||
visible: isH
|
visible: isH
|
||||||
}
|
}
|
||||||
|
@ -24,7 +24,7 @@ Button {
|
|||||||
if(checked){
|
if(checked){
|
||||||
return FluTheme.dark ? Qt.rgba(82/255,82/255,82/255,1) : Qt.rgba(199/255,199/255,199/255,1)
|
return FluTheme.dark ? Qt.rgba(82/255,82/255,82/255,1) : Qt.rgba(199/255,199/255,199/255,1)
|
||||||
}else{
|
}else{
|
||||||
return FluTheme.dark ? Qt.rgba(59/255,59/255,59/255,1) : Qt.rgba(244/255,244/255,244/255,1)
|
return FluTheme.dark ? Qt.rgba(59/255,59/255,59/255,1) : Qt.rgba(251/255,251/255,251/255,1)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
property var clickListener : function(){
|
property var clickListener : function(){
|
||||||
@ -41,45 +41,52 @@ Button {
|
|||||||
verticalPadding: 0
|
verticalPadding: 0
|
||||||
horizontalPadding:12
|
horizontalPadding:12
|
||||||
onClicked: clickListener()
|
onClicked: clickListener()
|
||||||
background: Rectangle{
|
background: FluControlBackground{
|
||||||
implicitWidth: 28
|
implicitWidth: 30
|
||||||
implicitHeight: 28
|
implicitHeight: 30
|
||||||
radius: 4
|
radius: 4
|
||||||
FluFocusRectangle{
|
FluFocusRectangle{
|
||||||
visible: control.activeFocus
|
visible: control.activeFocus
|
||||||
radius:4
|
radius:4
|
||||||
}
|
}
|
||||||
gradient: Gradient {
|
color:{
|
||||||
GradientStop { position: 0.33; color: control.enabled ? control.normalColor : Qt.rgba(0,0,0,0) }
|
if(!enabled){
|
||||||
GradientStop { position: 1.0; color: control.enabled ? Qt.darker(control.normalColor,1.3) : Qt.rgba(0,0,0,0) }
|
return disableColor
|
||||||
}
|
|
||||||
Rectangle{
|
|
||||||
radius: parent.radius
|
|
||||||
anchors{
|
|
||||||
fill: parent
|
|
||||||
topMargin: checked && enabled ? 0 : 0
|
|
||||||
leftMargin: checked && enabled ? 1 : 0
|
|
||||||
rightMargin: checked && enabled ? 1 : 0
|
|
||||||
bottomMargin: checked && enabled ? 2 : 0
|
|
||||||
}
|
}
|
||||||
color:{
|
if(checked){
|
||||||
if(!enabled){
|
if(pressed){
|
||||||
return disableColor
|
return pressedColor
|
||||||
}
|
}
|
||||||
if(checked){
|
}
|
||||||
if(pressed){
|
return hovered ? hoverColor :normalColor
|
||||||
return pressedColor
|
}
|
||||||
}
|
bottomMargin: {
|
||||||
}
|
if(checked){
|
||||||
return hovered ? hoverColor :normalColor
|
return enabled ? 2 : 0
|
||||||
|
}else{
|
||||||
|
return 1
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Rectangle{
|
border.width: {
|
||||||
color:"#00000000"
|
if(checked){
|
||||||
anchors.fill: parent
|
return enabled ? 1 : 0
|
||||||
border.color: FluTheme.dark ? "#505050" : "#DFDFDF"
|
}else{
|
||||||
border.width: checked ? 0 : 1
|
return 1
|
||||||
radius: parent.radius
|
}
|
||||||
|
}
|
||||||
|
shadow: {
|
||||||
|
if(checked){
|
||||||
|
return true
|
||||||
|
}else{
|
||||||
|
return !pressed && enabled
|
||||||
|
}
|
||||||
|
}
|
||||||
|
border.color: {
|
||||||
|
if(checked){
|
||||||
|
return enabled ? Qt.darker(control.normalColor,1.2) : disableColor
|
||||||
|
}else{
|
||||||
|
return FluTheme.dark ? Qt.rgba(48/255,48/255,48/255,1) : Qt.rgba(188/255,188/255,188/255,1)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
contentItem: FluText {
|
contentItem: FluText {
|
||||||
|
@ -42,9 +42,9 @@ Window {
|
|||||||
property bool useSystemAppBar
|
property bool useSystemAppBar
|
||||||
property color resizeBorderColor: {
|
property color resizeBorderColor: {
|
||||||
if(window.active){
|
if(window.active){
|
||||||
return FluTheme.dark ? "#333333" : "#6E6E6E"
|
return FluTheme.dark ? Qt.rgba(51/255,51/255,51/255,1) : Qt.rgba(110/255,110/255,110/255,1)
|
||||||
}
|
}
|
||||||
return FluTheme.dark ? "#3D3D3E" : "#A7A7A7"
|
return FluTheme.dark ? Qt.rgba(61/255,61/255,61/255,1) : Qt.rgba(167/255,167/255,167/255,1)
|
||||||
}
|
}
|
||||||
property int resizeBorderWidth: 1
|
property int resizeBorderWidth: 1
|
||||||
property var closeListener: function(event){
|
property var closeListener: function(event){
|
||||||
|
Loading…
Reference in New Issue
Block a user