mirror of
https://github.com/zhuzichu520/FluentUI.git
synced 2024-11-26 21:37:04 +08:00
update
This commit is contained in:
parent
90943674b3
commit
192c65a510
@ -19,7 +19,7 @@ endif()
|
||||
file(TO_CMAKE_PATH "/" PATH_SEPARATOR)
|
||||
|
||||
#设置版本号
|
||||
add_definitions(-DVERSION=1,3,6,2)
|
||||
add_definitions(-DVERSION=1,3,7,0)
|
||||
|
||||
find_package(Qt6 REQUIRED COMPONENTS Quick)
|
||||
|
||||
|
@ -5,76 +5,80 @@ import QtQuick.Window
|
||||
import FluentUI
|
||||
import "qrc:///example/qml/component"
|
||||
|
||||
FluScrollablePage{
|
||||
FluPage{
|
||||
|
||||
title:"Pivot"
|
||||
Component.onDestruction: {
|
||||
console.debug("------------------------->")
|
||||
}
|
||||
|
||||
FluArea{
|
||||
Layout.fillWidth: true
|
||||
Layout.topMargin: 20
|
||||
height: 400
|
||||
paddings: 10
|
||||
// title:"Pivot"
|
||||
|
||||
FluPivot{
|
||||
anchors.fill: parent
|
||||
currentIndex: 2
|
||||
FluPivotItem{
|
||||
title:"All"
|
||||
contentItem:FluText{
|
||||
text:"All emails go here."
|
||||
}
|
||||
}
|
||||
FluPivotItem{
|
||||
title:"Unread"
|
||||
contentItem:FluText{
|
||||
text:"Unread emails go here."
|
||||
}
|
||||
}
|
||||
FluPivotItem{
|
||||
title:"Flagged"
|
||||
contentItem:FluText{
|
||||
text:"Flagged emails go here."
|
||||
}
|
||||
}
|
||||
FluPivotItem{
|
||||
title:"Urgent"
|
||||
contentItem:FluText{
|
||||
text:"Urgent emails go here."
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
CodeExpander{
|
||||
Layout.fillWidth: true
|
||||
Layout.topMargin: -1
|
||||
code:'FluPivot{
|
||||
anchors.fill: parent
|
||||
FluPivotItem:{
|
||||
text:"All"
|
||||
contentItem: FluText{
|
||||
text:"All emails go here."
|
||||
}
|
||||
}
|
||||
FluPivotItem:{
|
||||
text:"Unread"
|
||||
contentItem: FluText{
|
||||
text:"Unread emails go here."
|
||||
}
|
||||
}
|
||||
FluPivotItem:{
|
||||
text:"Flagged"
|
||||
contentItem: FluText{
|
||||
text:"Flagged emails go here."
|
||||
}
|
||||
}
|
||||
FluPivotItem:{
|
||||
text:"Urgent"
|
||||
contentItem: FluText{
|
||||
text:"Urgent emails go here."
|
||||
}
|
||||
}
|
||||
}
|
||||
'
|
||||
}
|
||||
// FluArea{
|
||||
// Layout.fillWidth: true
|
||||
// Layout.topMargin: 20
|
||||
// height: 400
|
||||
// paddings: 10
|
||||
|
||||
// FluPivot{
|
||||
// anchors.fill: parent
|
||||
// currentIndex: 2
|
||||
// FluPivotItem{
|
||||
// title:"All"
|
||||
// contentItem:FluText{
|
||||
// text:"All emails go here."
|
||||
// }
|
||||
// }
|
||||
// FluPivotItem{
|
||||
// title:"Unread"
|
||||
// contentItem:FluText{
|
||||
// text:"Unread emails go here."
|
||||
// }
|
||||
// }
|
||||
// FluPivotItem{
|
||||
// title:"Flagged"
|
||||
// contentItem:FluText{
|
||||
// text:"Flagged emails go here."
|
||||
// }
|
||||
// }
|
||||
// FluPivotItem{
|
||||
// title:"Urgent"
|
||||
// contentItem:FluText{
|
||||
// text:"Urgent emails go here."
|
||||
// }
|
||||
// }
|
||||
// }
|
||||
// }
|
||||
// CodeExpander{
|
||||
// Layout.fillWidth: true
|
||||
// Layout.topMargin: -1
|
||||
// code:'FluPivot{
|
||||
// anchors.fill: parent
|
||||
// FluPivotItem:{
|
||||
// text:"All"
|
||||
// contentItem: FluText{
|
||||
// text:"All emails go here."
|
||||
// }
|
||||
// }
|
||||
// FluPivotItem:{
|
||||
// text:"Unread"
|
||||
// contentItem: FluText{
|
||||
// text:"Unread emails go here."
|
||||
// }
|
||||
// }
|
||||
// FluPivotItem:{
|
||||
// text:"Flagged"
|
||||
// contentItem: FluText{
|
||||
// text:"Flagged emails go here."
|
||||
// }
|
||||
// }
|
||||
// FluPivotItem:{
|
||||
// text:"Urgent"
|
||||
// contentItem: FluText{
|
||||
// text:"Urgent emails go here."
|
||||
// }
|
||||
// }
|
||||
//}
|
||||
//'
|
||||
// }
|
||||
|
||||
}
|
||||
|
@ -13,8 +13,26 @@ FluContentPage{
|
||||
loadData(1,1000)
|
||||
}
|
||||
|
||||
Component.onDestruction: {
|
||||
console.debug("T_TableView已经销毁")
|
||||
Component{
|
||||
id:com_action
|
||||
Item{
|
||||
RowLayout{
|
||||
anchors.centerIn: parent
|
||||
FluButton{
|
||||
text:"删除"
|
||||
onClicked: {
|
||||
table_view.closeEditor()
|
||||
tableModel.removeRow(row)
|
||||
}
|
||||
}
|
||||
FluFilledButton{
|
||||
text:"编辑"
|
||||
onClicked: {
|
||||
showSuccess(JSON.stringify(tableModel.getRow(row)))
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
function loadData(page,count){
|
||||
@ -47,7 +65,8 @@ FluContentPage{
|
||||
nickname: getRandomNickname(),
|
||||
height:40,
|
||||
minimumHeight:40,
|
||||
maximumHeight:200
|
||||
maximumHeight:200,
|
||||
action:com_action
|
||||
})
|
||||
}
|
||||
table_view.dataSource = dataSource
|
||||
@ -116,6 +135,13 @@ FluContentPage{
|
||||
width:100,
|
||||
minimumWidth:80,
|
||||
maximumWidth:200
|
||||
},
|
||||
{
|
||||
title: '操作',
|
||||
dataIndex: 'action',
|
||||
width:160,
|
||||
minimumWidth:160,
|
||||
maximumWidth:160
|
||||
}
|
||||
]
|
||||
}
|
||||
|
@ -12,7 +12,7 @@ endif()
|
||||
set(QML_PLUGIN_DIRECTORY ${CMAKE_PREFIX_PATH}/qml/FluentUI)
|
||||
|
||||
#设置版本号
|
||||
add_definitions(-DVERSION=1,3,6,2)
|
||||
add_definitions(-DVERSION=1,3,7,0)
|
||||
|
||||
find_package(Qt6 REQUIRED COMPONENTS Core Quick Qml)
|
||||
|
||||
|
@ -111,6 +111,9 @@ void FluApp::closeApp(){
|
||||
}
|
||||
|
||||
void FluApp::deleteWindow(QQuickWindow* window){
|
||||
wnds.remove(window->winId());
|
||||
window->deleteLater();
|
||||
if(window){
|
||||
wnds.remove(window->winId());
|
||||
window->deleteLater();
|
||||
window = nullptr;
|
||||
}
|
||||
}
|
||||
|
@ -89,5 +89,8 @@ void FluTools::restoreOverrideCursor(){
|
||||
}
|
||||
|
||||
void FluTools::deleteItem(QObject *p){
|
||||
p->deleteLater();
|
||||
if(p){
|
||||
delete p;
|
||||
p = nullptr;
|
||||
}
|
||||
}
|
||||
|
@ -59,6 +59,16 @@ Rectangle {
|
||||
}
|
||||
}
|
||||
}
|
||||
Component{
|
||||
id:com_text
|
||||
FluText {
|
||||
text: itemData
|
||||
anchors.fill: parent
|
||||
anchors.margins: 10
|
||||
elide: Text.ElideRight
|
||||
verticalAlignment: Text.AlignVCenter
|
||||
}
|
||||
}
|
||||
ScrollView{
|
||||
id:scroll_table
|
||||
anchors.left: header_vertical.right
|
||||
@ -110,6 +120,8 @@ Rectangle {
|
||||
model: table_model
|
||||
clip: true
|
||||
delegate: Rectangle {
|
||||
id:item_table
|
||||
property var position: Qt.point(column,row)
|
||||
required property bool selected
|
||||
property bool current: selection_model.currentIndex === table_model.index(row,column)
|
||||
color: selected ? FluTheme.primaryColor.lightest: (row%2!==0) ? control.color : (FluTheme.dark ? Qt.rgba(1,1,1,0.06) : Qt.rgba(0,0,0,0.06))
|
||||
@ -118,6 +130,9 @@ Rectangle {
|
||||
TapHandler{
|
||||
acceptedButtons: Qt.LeftButton
|
||||
onDoubleTapped: {
|
||||
if(display instanceof Component){
|
||||
return
|
||||
}
|
||||
selection_model.setCurrentIndex(table_model.index(row,column), ItemSelectionModel.Current)
|
||||
item_loader.sourceComponent = obtEditDelegate(column,row)
|
||||
var index = table_model.index(row,column)
|
||||
@ -128,12 +143,20 @@ Rectangle {
|
||||
}
|
||||
}
|
||||
}
|
||||
FluText {
|
||||
text: display
|
||||
Loader{
|
||||
property var itemData: display
|
||||
property var tableView: table_view
|
||||
property var tableModel: table_model
|
||||
property var position: item_table.position
|
||||
property int row: position.y
|
||||
property int column: position.x
|
||||
anchors.fill: parent
|
||||
anchors.margins: 10
|
||||
elide: Text.ElideRight
|
||||
verticalAlignment: Text.AlignVCenter
|
||||
sourceComponent: {
|
||||
if(itemData instanceof Component){
|
||||
return itemData
|
||||
}
|
||||
return com_text
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -353,13 +376,10 @@ Rectangle {
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
function closeEditor(){
|
||||
item_loader.sourceComponent = null
|
||||
}
|
||||
|
||||
function resetPosition(){
|
||||
table_view.positionViewAtCell(Qt.point(0, 0),Qt.AlignTop|Qt.AlignLeft)
|
||||
}
|
||||
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user