import QtQuick 2.15 import QtQuick.Window 2.15 import QtQuick.Layouts 1.15 import FluentUI 1.0 import QtGraphicalEffects 1.15 Item { id:root property var window : { if(Window.window == null) return null return Window.window } property color color: FluApp.isDark ? "#202020" : "#F3F3F3" property string title: "FluentUI" property int minimumWidth property int maximumWidth property int minimumHeight property int maximumHeight property int borderless:{ if(Window.window == null) return 4 if(Window.window.visibility === Window.Maximized){ return 0 } return 4 } default property alias content: container.children FluWindowResize{} Behavior on opacity{ NumberAnimation{ duration: 100 } } Rectangle{ color:FluTheme.primaryColor.dark border.width: 1 anchors.fill: parent radius: 4 border.color:Qt.lighter(FluTheme.primaryColor.dark,1.3) } Rectangle{ id:container color:root.color anchors.fill: parent anchors.margins: borderless } Component.onCompleted: { } Connections{ target: FluApp function onWindowReady(view){ if(FluApp.equalsWindow(view,window)){ helper.initWindow(view); helper.setTitle(title); if(minimumWidth){ helper.setMinimumWidth(minimumWidth) } if(maximumWidth){ helper.setMaximumWidth(maximumWidth) } if(minimumHeight){ helper.setMinimumHeight(minimumHeight) } if(maximumHeight){ helper.setMaximumHeight(maximumHeight) } } } } WindowHelper{ id:helper } FluInfoBar{ id:infoBar root: root } function showSuccess(text,duration,moremsg){ infoBar.showSuccess(text,duration,moremsg); } function showInfo(text,duration,moremsg){ infoBar.showInfo(text,duration,moremsg); } function showWarning(text,duration,moremsg){ infoBar.showWarning(text,duration,moremsg); } function showError(text,duration,moremsg){ infoBar.showError(text,duration,moremsg); } function close(){ window.close() } }