mirror of
https://github.com/zhuzichu520/FluentUI.git
synced 2025-03-17 09:29:41 +08:00
869 lines
29 KiB
QML
869 lines
29 KiB
QML
import QtQuick
|
|
import QtQuick.Controls
|
|
import QtQuick.Controls.Basic
|
|
import QtQuick.Layouts
|
|
import Qt.labs.qmlmodels
|
|
import FluentUI
|
|
|
|
Rectangle {
|
|
readonly property alias rows: table_view.rows
|
|
readonly property alias columns: table_view.columns
|
|
readonly property alias current: d.current
|
|
readonly property alias sourceModel: table_model
|
|
property var columnSource
|
|
property var dataSource
|
|
property color borderColor: FluTheme.dark ? Qt.rgba(37/255,37/255,37/255,1) : Qt.rgba(228/255,228/255,228/255,1)
|
|
property bool horizonalHeaderVisible: true
|
|
property bool verticalHeaderVisible: true
|
|
property color selectedBorderColor: FluTheme.primaryColor
|
|
property color selectedColor: FluTools.colorAlpha(FluTheme.primaryColor,0.3)
|
|
id:control
|
|
color: FluTheme.dark ? Qt.rgba(39/255,39/255,39/255,1) : Qt.rgba(251/255,251/255,253/255,1)
|
|
onColumnSourceChanged: {
|
|
if(columnSource.length!==0){
|
|
var columns= []
|
|
var columnsData = []
|
|
var headerRow = {}
|
|
columnSource.forEach(function(item){
|
|
var column = Qt.createQmlObject('import Qt.labs.qmlmodels 1.0;TableModelColumn{}',table_model);
|
|
column.display = item.dataIndex
|
|
columnsData.push(item)
|
|
columns.push(column)
|
|
headerRow[item.dataIndex] = item.title
|
|
})
|
|
d.columns_data = columnsData
|
|
table_model.columns = columns
|
|
header_column_model.columns = columns
|
|
header_column_model.rows = [headerRow]
|
|
}
|
|
}
|
|
QtObject{
|
|
id:d
|
|
property var current
|
|
property int rowHoverIndex: -1
|
|
property int defaultItemWidth: 100
|
|
property int defaultItemHeight: 42
|
|
property var columns_data: []
|
|
property var editDelegate
|
|
property var editPosition
|
|
function getEditDelegate(column){
|
|
var obj =d.columns_data[column].editDelegate
|
|
if(obj){
|
|
return obj
|
|
}
|
|
if(d.columns_data[column].editMultiline === true){
|
|
return com_edit_multiline
|
|
}
|
|
return com_edit
|
|
}
|
|
}
|
|
onDataSourceChanged: {
|
|
table_model.clear()
|
|
table_model.rows = dataSource
|
|
}
|
|
TableModel {
|
|
id:table_model
|
|
TableModelColumn {}
|
|
}
|
|
TableModel{
|
|
id:header_column_model
|
|
TableModelColumn {}
|
|
}
|
|
TableModel{
|
|
id:header_row_model
|
|
TableModelColumn { display: "rowIndex" }
|
|
}
|
|
FluTableSortProxyModel{
|
|
id:table_sort_model
|
|
model: table_model
|
|
}
|
|
Component{
|
|
id:com_edit
|
|
FluTextBox{
|
|
id:text_box
|
|
text: String(display)
|
|
readOnly: true === d.columns_data[column].readOnly
|
|
Component.onCompleted: {
|
|
forceActiveFocus()
|
|
selectAll()
|
|
}
|
|
onCommit: {
|
|
if(!readOnly){
|
|
editTextChaged(text_box.text)
|
|
}
|
|
tableView.closeEditor()
|
|
}
|
|
}
|
|
}
|
|
Component{
|
|
id:com_edit_multiline
|
|
Item{
|
|
anchors.fill: parent
|
|
Flickable{
|
|
id:item_scroll
|
|
clip: true
|
|
anchors.fill: parent
|
|
ScrollBar.vertical: multiline_text_srcoll_bar
|
|
boundsBehavior: Flickable.StopAtBounds
|
|
TextArea.flickable: FluMultilineTextBox {
|
|
id:text_box
|
|
text: String(display)
|
|
readOnly: true === d.columns_data[column].readOnly
|
|
verticalAlignment: TextInput.AlignVCenter
|
|
isCtrlEnterForNewline: true
|
|
Component.onCompleted: {
|
|
forceActiveFocus()
|
|
selectAll()
|
|
}
|
|
rightPadding: 34
|
|
onCommit: {
|
|
if(!readOnly){
|
|
editTextChaged(text_box.text)
|
|
}
|
|
tableView.closeEditor()
|
|
}
|
|
}
|
|
}
|
|
FluIconButton{
|
|
iconSource:FluentIcons.ChromeClose
|
|
iconSize: 10
|
|
width: 20
|
|
height: 20
|
|
padding: 0
|
|
verticalPadding: 0
|
|
horizontalPadding: 0
|
|
visible: {
|
|
if(text_box.readOnly)
|
|
return false
|
|
return text_box.text !== ""
|
|
}
|
|
anchors{
|
|
verticalCenter: parent.verticalCenter
|
|
right: parent.right
|
|
rightMargin: 15
|
|
}
|
|
onClicked:{
|
|
text_box.text = ""
|
|
}
|
|
}
|
|
FluScrollBar{
|
|
id:multiline_text_srcoll_bar
|
|
anchors{
|
|
right: parent.right
|
|
rightMargin: 5
|
|
top: parent.top
|
|
bottom: parent.bottom
|
|
topMargin: 3
|
|
bottomMargin: 3
|
|
}
|
|
}
|
|
}
|
|
}
|
|
Component{
|
|
id:com_text
|
|
FluText {
|
|
id:item_text
|
|
text: String(display)
|
|
elide: Text.ElideRight
|
|
wrapMode: Text.WrapAnywhere
|
|
anchors{
|
|
fill: parent
|
|
leftMargin: 11
|
|
rightMargin: 11
|
|
topMargin: 6
|
|
bottomMargin: 6
|
|
}
|
|
verticalAlignment: Text.AlignVCenter
|
|
MouseArea{
|
|
acceptedButtons: Qt.NoButton
|
|
id: hover_handler
|
|
hoverEnabled: true
|
|
anchors.fill: parent
|
|
}
|
|
FluTooltip{
|
|
text: item_text.text
|
|
delay: 500
|
|
visible: item_text.contentWidth < item_text.implicitWidth && item_text.contentHeight < item_text.implicitHeight && hover_handler.containsMouse
|
|
}
|
|
}
|
|
}
|
|
Component{
|
|
id:com_table_delegate
|
|
MouseArea{
|
|
id:item_table_mouse
|
|
property var rowObject : control.getRow(row)
|
|
property var itemModel: model
|
|
property bool editVisible: {
|
|
if(rowObject && d.editPosition && d.editPosition._key === rowObject._key && d.editPosition.column === column){
|
|
return true
|
|
}
|
|
return false
|
|
}
|
|
hoverEnabled: true
|
|
onEntered: {
|
|
d.rowHoverIndex = row
|
|
}
|
|
onWidthChanged: {
|
|
if(editVisible){
|
|
updateEditPosition()
|
|
}
|
|
}
|
|
onHeightChanged: {
|
|
if(editVisible){
|
|
updateEditPosition()
|
|
}
|
|
}
|
|
onXChanged: {
|
|
if(editVisible){
|
|
updateEditPosition()
|
|
}
|
|
}
|
|
onYChanged: {
|
|
if(editVisible){
|
|
updateEditPosition()
|
|
}
|
|
}
|
|
function updateEditPosition(){
|
|
var obj = {}
|
|
obj._key = rowObject._key
|
|
obj.column = column
|
|
obj.row = row
|
|
obj.x = item_table_mouse.x
|
|
obj.y = item_table_mouse.y + 1
|
|
obj.width = item_table_mouse.width
|
|
obj.height = item_table_mouse.height - 2
|
|
d.editPosition = obj
|
|
}
|
|
Rectangle{
|
|
id:item_table
|
|
anchors.fill: parent
|
|
property point position: Qt.point(column,row)
|
|
property bool isRowSelected: {
|
|
if(rowObject === null)
|
|
return false
|
|
if(d.current){
|
|
return rowObject._key === d.current._key
|
|
}
|
|
return false
|
|
}
|
|
color:{
|
|
if(item_table.isRowSelected){
|
|
return control.selectedColor
|
|
}
|
|
if(d.rowHoverIndex === row || item_table.isRowSelected){
|
|
return FluTheme.dark ? Qt.rgba(1,1,1,0.06) : Qt.rgba(0,0,0,0.06)
|
|
}
|
|
return (row%2!==0) ? control.color : (FluTheme.dark ? Qt.rgba(1,1,1,0.015) : Qt.rgba(0,0,0,0.015))
|
|
}
|
|
MouseArea{
|
|
anchors.fill: parent
|
|
acceptedButtons: Qt.LeftButton
|
|
onPressed:{
|
|
closeEditor()
|
|
}
|
|
onCanceled: {
|
|
}
|
|
onReleased: {
|
|
}
|
|
onDoubleClicked:{
|
|
if(typeof(display) == "object"){
|
|
return
|
|
}
|
|
d.editDelegate = d.getEditDelegate(column)
|
|
updateEditPosition()
|
|
loader_edit.display = display
|
|
}
|
|
onClicked:
|
|
(event)=>{
|
|
d.current = rowObject
|
|
closeEditor()
|
|
event.accepted = true
|
|
}
|
|
}
|
|
FluLoader{
|
|
property var model: itemModel
|
|
property var display: itemModel.display
|
|
property int row: item_table.position.y
|
|
property int column: item_table.position.x
|
|
property bool isObject: typeof(display) == "object"
|
|
property var options: {
|
|
if(isObject){
|
|
return display.options
|
|
}
|
|
return {}
|
|
}
|
|
anchors.fill: parent
|
|
sourceComponent: {
|
|
if(isObject){
|
|
return display.comId
|
|
}
|
|
return com_text
|
|
}
|
|
}
|
|
Item{
|
|
anchors.fill: parent
|
|
visible: item_table.isRowSelected
|
|
Rectangle{
|
|
width: 1
|
|
height: parent.height
|
|
anchors.left: parent.left
|
|
color: control.selectedBorderColor
|
|
visible: column === 0
|
|
}
|
|
Rectangle{
|
|
width: 1
|
|
height: parent.height
|
|
anchors.right: parent.right
|
|
color: control.selectedBorderColor
|
|
visible: column === control.columns-1
|
|
}
|
|
Rectangle{
|
|
width: parent.width
|
|
height: 1
|
|
anchors.top: parent.top
|
|
color: control.selectedBorderColor
|
|
}
|
|
Rectangle{
|
|
width: parent.width
|
|
height: 1
|
|
anchors.bottom: parent.bottom
|
|
color: control.selectedBorderColor
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
MouseArea{
|
|
id:layout_mouse_table
|
|
hoverEnabled: true
|
|
anchors{
|
|
left: header_vertical.right
|
|
top: header_horizontal.bottom
|
|
right: parent.right
|
|
bottom: parent.bottom
|
|
}
|
|
onExited: {
|
|
d.rowHoverIndex = -1
|
|
}
|
|
onCanceled: {
|
|
d.rowHoverIndex = -1
|
|
}
|
|
TableView {
|
|
id:table_view
|
|
boundsBehavior: Flickable.StopAtBounds
|
|
anchors.fill: parent
|
|
ScrollBar.horizontal:scroll_bar_h
|
|
ScrollBar.vertical:scroll_bar_v
|
|
columnWidthProvider: function(column) {
|
|
var columnObject = d.columns_data[column]
|
|
var width = columnObject.width
|
|
if(width){
|
|
return width
|
|
}
|
|
var minimumWidth = columnObject.minimumWidth
|
|
if(minimumWidth){
|
|
return minimumWidth
|
|
}
|
|
return d.defaultItemWidth
|
|
}
|
|
rowHeightProvider: function(row) {
|
|
var rowObject = control.getRow(row)
|
|
var height = rowObject.height
|
|
if(height){
|
|
return height
|
|
}
|
|
var minimumHeight = rowObject._minimumHeight
|
|
if(minimumHeight){
|
|
return minimumHeight
|
|
}
|
|
return d.defaultItemHeight
|
|
}
|
|
model: table_sort_model
|
|
clip: true
|
|
onRowsChanged: {
|
|
control.closeEditor()
|
|
}
|
|
delegate: com_table_delegate
|
|
FluLoader{
|
|
id:loader_edit
|
|
property var tableView: control
|
|
property var display
|
|
property int column: {
|
|
if(d.editPosition){
|
|
return d.editPosition.column
|
|
}
|
|
return 0
|
|
}
|
|
property int row: {
|
|
if(d.editPosition){
|
|
return d.editPosition.row
|
|
}
|
|
return 0
|
|
}
|
|
signal editTextChaged(string text)
|
|
sourceComponent: d.editPosition ? d.editDelegate : undefined
|
|
onEditTextChaged:
|
|
(text)=>{
|
|
var obj = control.getRow(row)
|
|
obj[d.columns_data[column].dataIndex] = text
|
|
control.setRow(row,obj)
|
|
}
|
|
width: {
|
|
if(d.editPosition){
|
|
return d.editPosition.width
|
|
}
|
|
return 0
|
|
}
|
|
height: {
|
|
if(d.editPosition){
|
|
return d.editPosition.height
|
|
}
|
|
return 0
|
|
}
|
|
x:{
|
|
if(d.editPosition){
|
|
return d.editPosition.x
|
|
}
|
|
return 0
|
|
}
|
|
y:{
|
|
if(d.editPosition){
|
|
return d.editPosition.y
|
|
}
|
|
return 0
|
|
}
|
|
z:999
|
|
}
|
|
}
|
|
}
|
|
Component{
|
|
id:com_column_header_delegate
|
|
Rectangle{
|
|
id:column_item_control
|
|
readonly property real cellPadding: 8
|
|
property bool canceled: false
|
|
property int columnIndex: column
|
|
readonly property var columnObject : d.columns_data[column]
|
|
implicitWidth: {
|
|
return (item_column_loader.item && item_column_loader.item.implicitWidth) + (cellPadding * 2)
|
|
}
|
|
implicitHeight: Math.max(36, (item_column_loader.item&&item_column_loader.item.implicitHeight) + (cellPadding * 2))
|
|
color: FluTheme.dark ? Qt.rgba(50/255,50/255,50/255,1) : Qt.rgba(247/255,247/255,247/255,1)
|
|
Rectangle{
|
|
border.color: control.borderColor
|
|
width: parent.width
|
|
height: 1
|
|
anchors.top: parent.top
|
|
color:"#00000000"
|
|
}
|
|
Rectangle{
|
|
border.color: control.borderColor
|
|
width: parent.width
|
|
height: 1
|
|
anchors.bottom: parent.bottom
|
|
color:"#00000000"
|
|
}
|
|
Rectangle{
|
|
border.color: control.borderColor
|
|
width: 1
|
|
height: parent.height
|
|
anchors.left: parent.left
|
|
visible: column !== 0
|
|
color:"#00000000"
|
|
}
|
|
Rectangle{
|
|
border.color: control.borderColor
|
|
width: 1
|
|
height: parent.height
|
|
anchors.right: parent.right
|
|
color:"#00000000"
|
|
visible: column === table_view.columns - 1
|
|
}
|
|
MouseArea{
|
|
id:column_item_control_mouse
|
|
anchors.fill: parent
|
|
anchors.rightMargin: 6
|
|
hoverEnabled: true
|
|
onCanceled: {
|
|
column_item_control.canceled = true
|
|
}
|
|
onContainsMouseChanged: {
|
|
if(!containsMouse){
|
|
column_item_control.canceled = false
|
|
}
|
|
}
|
|
onClicked:
|
|
(event)=>{
|
|
control.closeEditor()
|
|
}
|
|
}
|
|
FluLoader{
|
|
id:item_column_loader
|
|
property var itemModel: model
|
|
property var modelData: model.display
|
|
property var tableView: table_view
|
|
property var tableModel: table_model
|
|
property var options:{
|
|
if(typeof(modelData) == "object"){
|
|
return modelData.options
|
|
}
|
|
return {}
|
|
}
|
|
property int column: column_item_control.columnIndex
|
|
width: parent.width
|
|
height: parent.height
|
|
sourceComponent: {
|
|
if(typeof(modelData) == "object"){
|
|
return modelData.comId
|
|
}
|
|
return com_column_text
|
|
}
|
|
}
|
|
MouseArea{
|
|
property point clickPos: "0,0"
|
|
height: parent.height
|
|
width: 6
|
|
anchors.right: parent.right
|
|
acceptedButtons: Qt.LeftButton
|
|
hoverEnabled: true
|
|
visible: !(columnObject.width === columnObject.minimumWidth && columnObject.width === columnObject.maximumWidth && columnObject.width)
|
|
cursorShape: Qt.SplitHCursor
|
|
preventStealing: true
|
|
onPressed :
|
|
(mouse)=>{
|
|
FluTools.setOverrideCursor(Qt.SplitHCursor)
|
|
clickPos = Qt.point(mouse.x, mouse.y)
|
|
}
|
|
onReleased:{
|
|
FluTools.restoreOverrideCursor()
|
|
}
|
|
onCanceled: {
|
|
FluTools.restoreOverrideCursor()
|
|
}
|
|
onPositionChanged:
|
|
(mouse)=>{
|
|
if(!pressed){
|
|
return
|
|
}
|
|
var delta = Qt.point(mouse.x - clickPos.x, mouse.y - clickPos.y)
|
|
var minimumWidth = columnObject.minimumWidth
|
|
var maximumWidth = columnObject.maximumWidth
|
|
var w = columnObject.width
|
|
if(!w){
|
|
w = d.defaultItemWidth
|
|
}
|
|
if(!minimumWidth){
|
|
minimumWidth = d.defaultItemWidth
|
|
}
|
|
if(!maximumWidth){
|
|
maximumWidth = 65535
|
|
}
|
|
columnObject.width = Math.min(Math.max(minimumWidth, w + delta.x),maximumWidth)
|
|
table_view.forceLayout()
|
|
header_horizontal.forceLayout()
|
|
}
|
|
}
|
|
}
|
|
}
|
|
Component{
|
|
id:com_row_header_delegate
|
|
Rectangle{
|
|
id:item_control
|
|
readonly property real cellPadding: 8
|
|
property bool canceled: false
|
|
property var rowObject: control.getRow(row)
|
|
implicitWidth: Math.max(30, row_text.implicitWidth + (cellPadding * 2))
|
|
implicitHeight: row_text.implicitHeight + (cellPadding * 2)
|
|
color: FluTheme.dark ? Qt.rgba(50/255,50/255,50/255,1) : Qt.rgba(247/255,247/255,247/255,1)
|
|
Rectangle{
|
|
border.color: control.borderColor
|
|
width: parent.width
|
|
height: 1
|
|
anchors.top: parent.top
|
|
visible: row !== 0
|
|
color:"#00000000"
|
|
}
|
|
Rectangle{
|
|
border.color: control.borderColor
|
|
width: parent.width
|
|
height: 1
|
|
anchors.bottom: parent.bottom
|
|
visible: row === table_view.rows - 1
|
|
color:"#00000000"
|
|
}
|
|
Rectangle{
|
|
border.color: control.borderColor
|
|
width: 1
|
|
height: parent.height
|
|
anchors.left: parent.left
|
|
color:"#00000000"
|
|
}
|
|
Rectangle{
|
|
border.color: control.borderColor
|
|
width: 1
|
|
height: parent.height
|
|
anchors.right: parent.right
|
|
color:"#00000000"
|
|
}
|
|
FluText{
|
|
id:row_text
|
|
anchors.centerIn: parent
|
|
text: model.display
|
|
}
|
|
MouseArea{
|
|
id:item_control_mouse
|
|
anchors.fill: parent
|
|
anchors.bottomMargin: 6
|
|
hoverEnabled: true
|
|
onCanceled: {
|
|
item_control.canceled = true
|
|
}
|
|
onContainsMouseChanged: {
|
|
if(!containsMouse){
|
|
item_control.canceled = false
|
|
}
|
|
}
|
|
onClicked:
|
|
(event)=>{
|
|
control.closeEditor()
|
|
}
|
|
}
|
|
MouseArea{
|
|
property point clickPos: "0,0"
|
|
height: 6
|
|
width: parent.width
|
|
anchors.bottom: parent.bottom
|
|
acceptedButtons: Qt.LeftButton
|
|
cursorShape: Qt.SplitVCursor
|
|
preventStealing: true
|
|
visible: {
|
|
if(rowObject === null)
|
|
return false
|
|
return !(rowObject.height === rowObject._minimumHeight && rowObject.height === rowObject._maximumHeight && rowObject.height)
|
|
}
|
|
onPressed :
|
|
(mouse)=>{
|
|
FluTools.setOverrideCursor(Qt.SplitVCursor)
|
|
clickPos = Qt.point(mouse.x, mouse.y)
|
|
}
|
|
onReleased:{
|
|
FluTools.restoreOverrideCursor()
|
|
}
|
|
onCanceled: {
|
|
FluTools.restoreOverrideCursor()
|
|
}
|
|
onPositionChanged:
|
|
(mouse)=>{
|
|
if(!pressed){
|
|
return
|
|
}
|
|
var rowObject = control.getRow(row)
|
|
var delta = Qt.point(mouse.x - clickPos.x, mouse.y - clickPos.y)
|
|
var minimumHeight = rowObject._minimumHeight
|
|
var maximumHeight = rowObject._maximumHeight
|
|
var h = rowObject.height
|
|
if(!h){
|
|
h = d.defaultItemHeight
|
|
}
|
|
if(!minimumHeight){
|
|
minimumHeight = d.defaultItemHeight
|
|
}
|
|
if(!maximumHeight){
|
|
maximumHeight = 65535
|
|
}
|
|
rowObject.height = Math.min(Math.max(minimumHeight, h + delta.y),maximumHeight)
|
|
control.setRow(row,rowObject)
|
|
table_view.forceLayout()
|
|
}
|
|
}
|
|
}
|
|
}
|
|
Component{
|
|
id:com_column_text
|
|
FluText {
|
|
id: column_text
|
|
text: modelData
|
|
anchors.fill: parent
|
|
horizontalAlignment: Text.AlignHCenter
|
|
verticalAlignment: Text.AlignVCenter
|
|
}
|
|
}
|
|
Item{
|
|
id: header_vertical_column
|
|
anchors{
|
|
top: header_horizontal.top
|
|
bottom: header_horizontal.bottom
|
|
left: parent.left
|
|
right: header_vertical.right
|
|
}
|
|
Rectangle{
|
|
border.color: control.borderColor
|
|
width: parent.width
|
|
height: 1
|
|
anchors.top: parent.top
|
|
color:"#00000000"
|
|
}
|
|
Rectangle{
|
|
border.color: control.borderColor
|
|
width: parent.width
|
|
height: 1
|
|
anchors.bottom: parent.bottom
|
|
color:"#00000000"
|
|
}
|
|
Rectangle{
|
|
border.color: control.borderColor
|
|
width: 1
|
|
height: parent.height
|
|
anchors.left: parent.left
|
|
color:"#00000000"
|
|
}
|
|
Rectangle{
|
|
border.color: control.borderColor
|
|
width: 1
|
|
height: parent.height
|
|
anchors.right: parent.right
|
|
color:"#00000000"
|
|
}
|
|
}
|
|
TableView {
|
|
id: header_horizontal
|
|
model: header_column_model
|
|
anchors{
|
|
left: header_vertical.right
|
|
right: layout_mouse_table.right
|
|
top: parent.top
|
|
}
|
|
visible: control.horizonalHeaderVisible
|
|
height: visible ? Math.max(1, contentHeight) : 0
|
|
boundsBehavior: Flickable.StopAtBounds
|
|
clip: true
|
|
syncDirection: Qt.Horizontal
|
|
ScrollBar.horizontal:scroll_bar_h_2
|
|
columnWidthProvider: table_view.columnWidthProvider
|
|
syncView: table_view.rows === 0 ? null : table_view
|
|
onContentXChanged:{
|
|
timer_horizontal_force_layout.restart()
|
|
}
|
|
Timer{
|
|
id:timer_horizontal_force_layout
|
|
interval: 50
|
|
onTriggered: {
|
|
header_horizontal.forceLayout()
|
|
}
|
|
}
|
|
delegate: com_column_header_delegate
|
|
}
|
|
TableView {
|
|
id: header_vertical
|
|
boundsBehavior: Flickable.StopAtBounds
|
|
anchors{
|
|
top: layout_mouse_table.top
|
|
left: parent.left
|
|
}
|
|
visible: control.verticalHeaderVisible
|
|
implicitWidth: visible ? Math.max(1, contentWidth) : 0
|
|
implicitHeight: syncView ? syncView.height : 0
|
|
syncDirection: Qt.Vertical
|
|
syncView: table_view
|
|
clip: true
|
|
model: header_row_model
|
|
delegate: com_row_header_delegate
|
|
onContentYChanged:{
|
|
timer_vertical_force_layout.restart()
|
|
}
|
|
Connections{
|
|
target: table_model
|
|
function onRowCountChanged(){
|
|
header_row_model.rows = Array.from({length: table_model.rows.length}, (_, i) => ({rowIndex:i+1}))
|
|
}
|
|
}
|
|
Timer{
|
|
id:timer_vertical_force_layout
|
|
interval: 50
|
|
onTriggered: {
|
|
header_vertical.forceLayout()
|
|
}
|
|
}
|
|
}
|
|
FluScrollBar {
|
|
id: scroll_bar_h
|
|
anchors{
|
|
left: layout_mouse_table.left
|
|
right: parent.right
|
|
bottom: layout_mouse_table.bottom
|
|
}
|
|
visible: table_view.rows !== 0
|
|
z:999
|
|
}
|
|
FluScrollBar {
|
|
id: scroll_bar_h_2
|
|
anchors{
|
|
left: layout_mouse_table.left
|
|
right: parent.right
|
|
bottom: layout_mouse_table.bottom
|
|
}
|
|
visible: table_view.rows === 0
|
|
z:999
|
|
}
|
|
FluScrollBar {
|
|
id: scroll_bar_v
|
|
anchors{
|
|
top: layout_mouse_table.top
|
|
bottom: layout_mouse_table.bottom
|
|
right: parent.right
|
|
}
|
|
z:999
|
|
}
|
|
function closeEditor(){
|
|
d.editPosition = undefined
|
|
d.editDelegate = undefined
|
|
}
|
|
function resetPosition(){
|
|
scroll_bar_h.position = 0
|
|
scroll_bar_v.position = 0
|
|
}
|
|
function customItem(comId,options={}){
|
|
var o = {}
|
|
o.comId = comId
|
|
o.options = options
|
|
return o
|
|
}
|
|
function sort(callback=undefined){
|
|
if(callback){
|
|
table_sort_model.setComparator(function(left,right){
|
|
return callback(table_model.getRow(left),table_model.getRow(right))
|
|
})
|
|
}else{
|
|
table_sort_model.setComparator(undefined)
|
|
}
|
|
}
|
|
function filter(callback=undefined){
|
|
if(callback){
|
|
table_sort_model.setFilter(function(index){
|
|
return callback(table_model.getRow(index))
|
|
})
|
|
}else{
|
|
table_sort_model.setFilter(undefined)
|
|
}
|
|
}
|
|
function setRow(rowIndex,obj){
|
|
if(rowIndex>=0 && rowIndex<table_view.rows){
|
|
table_view.model.setRow(rowIndex,obj)
|
|
}
|
|
}
|
|
function getRow(rowIndex){
|
|
if(rowIndex>=0 && rowIndex<table_view.rows){
|
|
return table_view.model.getRow(rowIndex)
|
|
}
|
|
return null
|
|
}
|
|
function removeRow(rowIndex,rows=1){
|
|
if(rowIndex>=0 && rowIndex<table_view.rows){
|
|
table_view.model.removeRow(rowIndex,rows)
|
|
}
|
|
}
|
|
function appendRow(obj){
|
|
table_model.appendRow(obj)
|
|
}
|
|
}
|