blob: d1c285bceeb81494acf8dba30af2e70304fec194 [file] [log] [blame]
import QtQuick 2.5
import QtQuick.Controls 2.15
import QtQuick.Controls.Material 2.0
import QtQuick.Layouts 1.0
import sh.swisschili.REFAL 1.0
Item {
id: root
required property string code
required property string result
property int status: Cell.IDLE
property int resultType: Cell.EXPRESSION
property bool cellActive: false
signal insertBelowClicked()
signal codeEditingFinished(string code)
signal cellFocused()
signal cellUnfocused()
signal runClicked()
signal quitClicked()
signal deleteClicked()
height: column.height
Keys.onEscapePressed: {
root.cellUnfocused()
code.focus = false
}
ColumnLayout {
id: column
width: parent.width - 20
anchors.centerIn: parent
Item {
implicitWidth: row.implicitWidth
implicitHeight: row.implicitHeight
Layout.fillWidth: true
Pane {
anchors.fill: parent
anchors.topMargin: -5
anchors.bottomMargin: -5
Material.elevation: root.cellActive ? 4 : 0
}
MouseArea {
id: selectCell
anchors.fill: row
onClicked: root.cellFocused()
}
RowLayout {
anchors.fill: parent
id: row
RoundButton {
Layout.alignment: Qt.AlignTop
icon.source: iconForState(root.status)
icon.color: Material.color(Material.Grey, Material.Shade600)
flat: true
onClicked: {
if (root.status == Cell.IDLE)
root.runClicked()
else if (root.status == Cell.RUNNING)
root.quitClicked()
}
function iconForState(state) {
console.log("iconForState", state);
if (state === Cell.RUNNING)
return "qrc:///icons/square.svg"
return "qrc:///icons/play-circle.svg"
}
}
ColumnLayout {
Layout.fillWidth: true
Layout.fillHeight: true
TextArea {
id: code
Layout.fillWidth: true
Layout.fillHeight: true
font.family: "monospace"
text: root.code
selectByMouse: true
wrapMode: TextEdit.WrapAtWordBoundaryOrAnywhere
placeholderText: qsTr("Write some code...")
Keys.onTabPressed: {
var pos = cursorPosition + 4
text = text.slice(0, cursorPosition) + " " + text.slice(cursorPosition);
cursorPosition = pos
}
onTextChanged: {
root.codeEditingFinished(text)
}
onPressed: root.cellFocused()
onFocusChanged: if (focus) root.cellFocused()
onActiveFocusChanged: if (activeFocus) root.cellFocused()
}
Label {
visible: root.result.length > 0
Layout.fillWidth: true
font.family: "monospace"
text: root.result
textFormat: root.resultType === Cell.EXPRESSION ? Text.PlainText : Text.RichText
Layout.bottomMargin: 5
}
}
RoundButton {
Layout.alignment: Qt.AlignTop
icon.source: "qrc:///icons/menu.svg"
icon.color: Constants.buttonGrey
flat: true
onClicked: cellContextMenu.popup()
Menu {
id: cellContextMenu
MenuItem {
icon.source: "qrc:///icons/trash.svg"
icon.color: Material.color(Material.Red)
text: qsTr("Delete")
onClicked: root.deleteClicked()
}
}
}
}
}
InsertRow {
onInsertClicked: root.insertBelowClicked()
}
}
}