forked from qt-creator/qt-creator
		
	Task-Number: QTCREATORBUG-5672 Done-with: Oswald Buddenhagen Change-Id: I61f8a83205bc338ba12e43b7471eaa957da2b004 Reviewed-on: http://codereview.qt.nokia.com/2451 Reviewed-by: Qt Sanity Bot <qt_sanity_bot@ovi.com> Reviewed-by: Oswald Buddenhagen <oswald.buddenhagen@nokia.com> Reviewed-by: Eike Ziller <eike.ziller@nokia.com>
		
			
				
	
	
		
			143 lines
		
	
	
		
			5.0 KiB
		
	
	
	
		
			QML
		
	
	
	
	
	
			
		
		
	
	
			143 lines
		
	
	
		
			5.0 KiB
		
	
	
	
		
			QML
		
	
	
	
	
	
| /**************************************************************************
 | |
| **
 | |
| ** This file is part of Qt Creator
 | |
| **
 | |
| ** Copyright (c) 2011 Nokia Corporation and/or its subsidiary(-ies).
 | |
| **
 | |
| ** Contact: Nokia Corporation (info@qt.nokia.com)
 | |
| **
 | |
| **
 | |
| ** GNU Lesser General Public License Usage
 | |
| **
 | |
| ** This file may be used under the terms of the GNU Lesser General Public
 | |
| ** License version 2.1 as published by the Free Software Foundation and
 | |
| ** appearing in the file LICENSE.LGPL included in the packaging of this file.
 | |
| ** Please review the following information to ensure the GNU Lesser General
 | |
| ** Public License version 2.1 requirements will be met:
 | |
| ** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
 | |
| **
 | |
| ** In addition, as a special exception, Nokia gives you certain additional
 | |
| ** rights. These rights are described in the Nokia Qt LGPL Exception
 | |
| ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
 | |
| **
 | |
| ** Other Usage
 | |
| **
 | |
| ** Alternatively, this file may be used in accordance with the terms and
 | |
| ** conditions contained in a signed written agreement between you and Nokia.
 | |
| **
 | |
| ** If you have questions regarding the use of this file, please contact
 | |
| ** Nokia at info@qt.nokia.com.
 | |
| **
 | |
| **************************************************************************/
 | |
| 
 | |
| import QtQuick 1.0
 | |
| import "custom" as Components
 | |
| 
 | |
| 
 | |
| Item {
 | |
|     id: tabbar
 | |
|     property int tabHeight: tabrow.height
 | |
|     property int tabWidth: tabrow.width
 | |
| 
 | |
|     Keys.onRightPressed: {
 | |
|         if (tabFrame && tabFrame.current < tabFrame.count - 1)
 | |
|             tabFrame.current = tabFrame.current + 1
 | |
|     }
 | |
|     Keys.onLeftPressed: {
 | |
|         if (tabFrame && tabFrame.current > 0)
 | |
|             tabFrame.current = tabFrame.current - 1
 | |
|     }
 | |
| 
 | |
|     height: tabHeight
 | |
| 
 | |
|     property Item tabFrame
 | |
|     onTabFrameChanged:parent = tabFrame
 | |
|     visible: tabFrame ? tabFrame.tabsVisible : true
 | |
|     property int __overlap : styleitem.pixelMetric("tabvshift");
 | |
|     property string position: tabFrame ? tabFrame.position : "North"
 | |
|     property string tabBarAlignment: styleitem.styleHint("tabbaralignment");
 | |
|     property int tabOverlap: styleitem.pixelMetric("taboverlap");
 | |
|     property int tabBaseOverlap: styleitem.pixelMetric("tabbaseoverlap");
 | |
|     property int tabHSpace: styleitem.pixelMetric("tabhspace");
 | |
|     property int tabVSpace: styleitem.pixelMetric("tabvspace");
 | |
| 
 | |
|     function tab(index) {
 | |
|         for (var i = 0; i < tabrow.children.length; ++i) {
 | |
|             if (tabrow.children[i].tabindex == index) {
 | |
|                 return tabrow.children[i]
 | |
|             }
 | |
|         }
 | |
|         return null;
 | |
|     }
 | |
| 
 | |
|     QStyleItem {
 | |
|         visible:false
 | |
|         id:styleitem
 | |
|         elementType: "tab"
 | |
|         text: "generic"
 | |
|     }
 | |
| 
 | |
|     Row {
 | |
|         id: tabrow
 | |
|         focus: true
 | |
|         property int paintMargins: 1
 | |
|         states:
 | |
|                 State {
 | |
|             when: tabBarAlignment == "center"
 | |
|             name: "centered"
 | |
|             AnchorChanges {
 | |
|                 target:tabrow
 | |
|                 anchors.horizontalCenter: tabbar.horizontalCenter
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         Repeater {
 | |
|             id:repeater
 | |
|             focus:true
 | |
|             model: tabFrame ? tabFrame.tabs.length : null
 | |
|             delegate: Item {
 | |
|                 id:tab
 | |
|                 focus:true
 | |
|                 property int tabindex: index
 | |
|                 property bool selected : tabFrame.current == index
 | |
|                 z: selected ? 1 : -1
 | |
|                 function updateRect() {
 | |
|                     var rect = style.sizeFromContents(textitem.width + tabHSpace + 2, Math.max(style.fontHeight + tabVSpace + 6, 0))
 | |
|                     width = rect.width
 | |
|                     height = rect.height
 | |
|                 }
 | |
|                 // Component.onCompleted: print("taboverlap" + tabOverlap + " tabbaseoverlap " + tabBaseOverlap + " overlap " +__overlap + " hspace " + tabHSpace)
 | |
|                 QStyleItem {
 | |
|                     id: style
 | |
|                     elementType: "tab"
 | |
|                     selected: tab.selected
 | |
|                     info: tabbar.position
 | |
|                     text: tabFrame.tabs[index].title
 | |
|                     hover: mousearea.containsMouse
 | |
|                     focus: tabbar.focus && selected
 | |
|                     property bool first: index === 0
 | |
|                     paintMargins: tabrow.paintMargins
 | |
|                     activeControl: tabFrame.count == 1 ? "only" : index === 0 ? "beginning" :
 | |
|                             index == tabFrame.count-1 ? "end" : "middle"
 | |
|                     anchors.fill: parent
 | |
|                     anchors.margins: -paintMargins
 | |
|                     Text {
 | |
|                         id: textitem
 | |
|                         // Used for size hint
 | |
|                         visible: false
 | |
|                         onWidthChanged: updateRect()
 | |
|                         onHeightChanged: updateRect()
 | |
|                         text: tabFrame.tabs[index].title
 | |
|                     }
 | |
|                 }
 | |
|                 MouseArea {
 | |
|                     id: mousearea
 | |
|                     anchors.fill: parent
 | |
|                     hoverEnabled: true
 | |
|                     onPressed: tabFrame.current = index
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| }
 |