From 3d618159831b6379f2aefc27d8f744fd46a9f3d2 Mon Sep 17 00:00:00 2001
From: Adrian Kummerlaender
Date: Fri, 7 Aug 2015 16:29:35 +0200
Subject: Extracted terminal list into separate component
---
 qml/TerminalList.qml | 115 +++++++++++++++++++++++++++++++++++++++++++++++++++
 qml/main.qml         | 106 ++---------------------------------------------
 qml/ui.qrc           |   3 +-
 3 files changed, 121 insertions(+), 103 deletions(-)
 create mode 100644 qml/TerminalList.qml
diff --git a/qml/TerminalList.qml b/qml/TerminalList.qml
new file mode 100644
index 0000000..249193d
--- /dev/null
+++ b/qml/TerminalList.qml
@@ -0,0 +1,115 @@
+import QtQuick 2.0
+import QtQuick.Layouts 1.1
+
+Item {
+	id: item
+
+	property StateHandler state      : null
+	property int          activeItem : 0
+	property int          itemIndex  : 0
+
+	property alias children : column.children
+
+	function onItemExecuted(index) {
+		if ( index === (children.length - 1) ) {
+			createItem();
+		}
+	}
+
+	function createItem() {
+		var terminalItem = Qt.createComponent("qrc:/TerminalItem.qml");
+		var instantiateTerminal = function() {
+			var instance = terminalItem.createObject(column, {
+				"index": itemIndex,
+				"width": flickable.width
+			});
+			instance.onExecuted.connect(onItemExecuted);
+
+			++itemIndex;
+		}
+
+		if ( terminalItem.status === Component.Ready ) {
+			instantiateTerminal();
+		} else {
+			terminalItem.statusChanged.connect(instantiateTerminal);
+		}
+	}
+
+	function scrollTo(index) {
+		if ( column.height >= flickable.height ) {
+			var offset = children[index].y
+					   + (children[index].height / 2)
+					   - (flickable.height / 2);
+
+			var bound  = column.height
+					   - flickable.height;
+
+			if ( offset < 0 ) {
+				flickable.contentY = 0;
+			} else if ( offset >= bound ) {
+				flickable.contentY = bound;
+			} else {
+				flickable.contentY = offset;
+			}
+		}
+	}
+
+	function selectItem(index) {
+		children[activeItem].deselect();
+		children[index     ].select();
+
+		activeItem = index;
+
+		scrollTo(index);
+	}
+
+	function selectNext() {
+		if ( activeItem < (children.length - 1) ) {
+			selectItem(activeItem + 1);
+		} else {
+			state.enterInsertMode();
+		}
+	}
+
+	function selectPrev() {
+		if ( activeItem > 0 ) {
+			selectItem(activeItem - 1);
+		}
+	}
+
+	function focusCurrent() {
+		children[activeItem].forceActiveFocus();
+	}
+
+	function unfocusCurrent() {
+		children[activeItem].unfocus();
+	}
+
+	function getCurrent() {
+		return children[activeItem];
+	}
+
+	Flickable {
+		id: flickable
+
+		anchors.fill: parent
+
+		boundsBehavior: Flickable.StopAtBounds
+		contentHeight:  column.height
+		contentWidth:   parent.width
+		pixelAligned:   true
+
+		Column {
+			id: column
+
+			anchors {
+				left:  parent.left
+				right: parent.right
+			}
+
+			spacing: 10
+
+			onHeightChanged: scrollTo(activeItem)
+		}
+	}
+}
diff --git a/qml/main.qml b/qml/main.qml
index 2b81fe2..3f3b5a9 100644
--- a/qml/main.qml
+++ b/qml/main.qml
@@ -26,111 +26,13 @@ ApplicationWindow {
 	ColumnLayout {
 		anchors.fill: parent
 
-		Flickable {
-			id: terminalListFlickable
+		TerminalList {
+			id: terminalList
+
+			state: state
 
 			Layout.fillHeight: true
 			Layout.fillWidth:  true
-
-			boundsBehavior: Flickable.StopAtBounds
-			contentHeight:  terminalList.height
-			contentWidth:   parent.width
-			pixelAligned:   true
-
-			Column {
-				id: terminalList
-
-				property int activeItem : 0
-				property int itemIndex  : 0
-
-				anchors {
-					left:  parent.left
-					right: parent.right
-				}
-
-				spacing: 10
-
-				onHeightChanged: scrollTo(activeItem)
-
-				function onItemExecuted(index) {
-					if ( index === (children.length - 1) ) {
-						createItem();
-					}
-				}
-
-				function createItem() {
-					var terminalItem = Qt.createComponent("qrc:/TerminalItem.qml");
-					var instantiateTerminal = function() {
-						var instance = terminalItem.createObject(terminalList, {
-							"index": itemIndex,
-							"width": terminalListFlickable.width
-						});
-						instance.onExecuted.connect(onItemExecuted);
-
-						++itemIndex;
-					}
-
-					if ( terminalItem.status === Component.Ready ) {
-						instantiateTerminal();
-					} else {
-						terminalItem.statusChanged.connect(instantiateTerminal);
-					}
-				}
-
-				function scrollTo(index) {
-					if ( terminalList.height >= terminalListFlickable.height ) {
-						var offset = children[index].y
-								   + (children[index].height       / 2)
-								   - (terminalListFlickable.height / 2);
-
-						var bound  = terminalList.height
-								   - terminalListFlickable.height;
-
-						if ( offset < 0 ) {
-							terminalListFlickable.contentY = 0;
-						} else if ( offset >= bound ) {
-							terminalListFlickable.contentY = bound;
-						} else {
-							terminalListFlickable.contentY = offset;
-						}
-					}
-				}
-
-				function selectItem(index) {
-					children[activeItem].deselect();
-					children[index     ].select();
-
-					activeItem = index;
-
-					scrollTo(index);
-				}
-
-				function selectNext() {
-					if ( activeItem < (children.length - 1) ) {
-						selectItem(activeItem + 1);
-					} else {
-						state.enterInsertMode();
-					}
-				}
-
-				function selectPrev() {
-					if ( activeItem > 0 ) {
-						selectItem(activeItem - 1);
-					}
-				}
-
-				function focusCurrent() {
-					children[activeItem].forceActiveFocus();
-				}
-
-				function unfocusCurrent() {
-					children[activeItem].unfocus();
-				}
-
-				function getCurrent() {
-					return children[activeItem];
-				}
-			}
 		}
 
 		CommandInput {
diff --git a/qml/ui.qrc b/qml/ui.qrc
index ae9e8e7..df6d4e3 100644
--- a/qml/ui.qrc
+++ b/qml/ui.qrc
@@ -4,7 +4,8 @@
 		StateHandler.qml
 		TerminalItem.qml
 		EmbeddedTerminal.qml
-		Highlighter.qml
 		CommandInput.qml
+		TerminalList.qml
+		Highlighter.qml
 	
 
-- 
cgit v1.2.3