import QtQuick 2.2 import QtQuick.Controls.Styles 1.1 import QtQuick.Controls 1.1 import QtQuick.Dialogs 1.1 import QtQuick.Layouts 1.1 import QtQuick.Window 2.0 Window { id: stateListContainer modality: Qt.WindowModal width: 640 height: 480 visible: false ColumnLayout { anchors.fill: parent TableView { id: list Layout.fillHeight: true Layout.fillWidth: true model: projectModel.stateListModel itemDelegate: renderDelegate headerDelegate: null TableViewColumn { role: "title" title: qsTr("State") width: list.width } } Button { anchors.bottom: parent.bottom action: addStateAction } } Component { id: renderDelegate Item { RowLayout { anchors.fill: parent Text { Layout.fillWidth: true Layout.fillHeight: true text: styleData.value font.pointSize: 12 verticalAlignment: Text.AlignBottom } ToolButton { text: qsTr("Edit"); Layout.fillHeight: true onClicked: list.model.editState(styleData.row); } ToolButton { visible: list.model.defaultStateIndex !== styleData.row text: qsTr("Delete"); Layout.fillHeight: true onClicked: list.model.deleteState(styleData.row); } ToolButton { text: qsTr("Run"); Layout.fillHeight: true onClicked: list.model.runState(styleData.row); } } } } Action { id: addStateAction text: "&Add State" shortcut: "Ctrl+T" enabled: codeModel.hasContract && !clientModel.running; onTriggered: list.model.addState(); } }