|
|
|
import QtQuick 2.0
|
|
|
|
import QtQuick.Window 2.0
|
|
|
|
import QtQuick.Layouts 1.0
|
|
|
|
import QtQuick.Controls 1.0
|
|
|
|
import QtQuick.Controls.Styles 1.1
|
|
|
|
|
|
|
|
Item {
|
|
|
|
signal editorTextChanged
|
|
|
|
|
|
|
|
function setText(text) {
|
|
|
|
codeEditor.text = text;
|
|
|
|
}
|
|
|
|
|
|
|
|
function getText() {
|
|
|
|
return codeEditor.text;
|
|
|
|
}
|
|
|
|
|
|
|
|
function setFocus() {
|
|
|
|
codeEditor.forceActiveFocus();
|
|
|
|
}
|
|
|
|
|
|
|
|
anchors.fill: parent
|
|
|
|
id: contentView
|
|
|
|
width: parent.width
|
|
|
|
height: parent.height * 0.7
|
|
|
|
Rectangle {
|
|
|
|
id: lineColumn
|
|
|
|
property int rowHeight: codeEditor.font.pixelSize + 3
|
|
|
|
color: "#202020"
|
|
|
|
width: 50
|
|
|
|
height: parent.height
|
|
|
|
Column {
|
|
|
|
y: -codeEditor.flickableItem.contentY + 4
|
|
|
|
width: parent.width
|
|
|
|
Repeater {
|
|
|
|
model: Math.max(codeEditor.lineCount + 2, (lineColumn.height/lineColumn.rowHeight))
|
|
|
|
delegate: Text {
|
|
|
|
id: text
|
|
|
|
color: codeEditor.textColor
|
|
|
|
font: codeEditor.font
|
|
|
|
width: lineColumn.width - 4
|
|
|
|
horizontalAlignment: Text.AlignRight
|
|
|
|
verticalAlignment: Text.AlignVCenter
|
|
|
|
height: lineColumn.rowHeight
|
|
|
|
renderType: Text.NativeRendering
|
|
|
|
text: index + 1
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
TextArea {
|
|
|
|
id: codeEditor
|
|
|
|
textColor: "#EEE8D5"
|
|
|
|
style: TextAreaStyle {
|
|
|
|
backgroundColor: "#002B36"
|
|
|
|
}
|
|
|
|
|
|
|
|
anchors.left: lineColumn.right
|
|
|
|
anchors.right: parent.right
|
|
|
|
anchors.top: parent.top
|
|
|
|
anchors.bottom: parent.bottom
|
|
|
|
wrapMode: TextEdit.NoWrap
|
|
|
|
frameVisible: false
|
|
|
|
|
|
|
|
height: parent.height
|
|
|
|
font.family: "Monospace"
|
|
|
|
font.pointSize: 12
|
|
|
|
width: parent.width
|
|
|
|
|
|
|
|
tabChangesFocus: false
|
|
|
|
Keys.onPressed: {
|
|
|
|
if (event.key === Qt.Key_Tab) {
|
|
|
|
codeEditor.insert(codeEditor.cursorPosition, "\t");
|
|
|
|
event.accepted = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
onTextChanged: {
|
|
|
|
editorTextChanged();
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|