/**************************************************************************** ** ** Copyright (C) 2012 Nokia Corporation and/or its subsidiary(-ies). ** Contact: http://www.qt-project.org/ ** ** This file is part of the test suite of the Qt Toolkit. ** ** $QT_BEGIN_LICENSE:LGPL$ ** 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. ** ** GNU General Public License Usage ** Alternatively, this file may be used under the terms of the GNU General ** Public License version 3.0 as published by the Free Software Foundation ** and appearing in the file LICENSE.GPL included in the packaging of this ** file. Please review the following information to ensure the GNU General ** Public License version 3.0 requirements will be met: ** http://www.gnu.org/copyleft/gpl.html. ** ** 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. ** ** ** ** ** ** ** $QT_END_LICENSE$ ** ****************************************************************************/ import QtQuick 2.0 Item { id: listviewelementtest anchors.fill: parent property string testtext: "" property bool hivis: false Rectangle { id: listviewelementbackground color: "lightgray"; border.color: "gray"; radius: 5; clip: true; opacity: .1 height: listviewelement.height + 10; width: listviewelement.width + 10 anchors.centerIn: listviewelement } ListView { id: listviewelement height: 250; width: parent.width *.8; clip: true anchors.centerIn: parent model: devices highlightFollowsCurrentItem: true highlight: highlightrect delegate: delegaterect section.property: "os" section.delegate: sectiondelegaterect header: headerrect footer: footerrect spacing: 0 Behavior on spacing { NumberAnimation { duration: 200 } } } Component { id: delegaterect Item { width: listviewelement.width - 4; height: 30 Rectangle { color: "blue"; anchors.fill: parent; radius: 5; border.color: "black"; opacity: .1 } Text { text: model.name; anchors.centerIn: parent } } } Component { id: sectiondelegaterect Item { width: listviewelement.width - 4; height: 30 Rectangle { color: "green"; anchors.fill: parent; radius: 5; border.color: "black"; opacity: .5 } Text { text: section; anchors.verticalCenter: parent.verticalCenter; anchors.left: parent.left; anchors.leftMargin: 5 } } } Component { id: highlightrect Rectangle { id: coloredbox; color: "yellow"; width: listviewelement.width - 4; height: 30; radius: 5; opacity: .5; visible: hivis SequentialAnimation on color { loops: Animation.Infinite; running: coloredbox.visible ColorAnimation { to: "green"; duration: 2000 } ColorAnimation { to: "yellow"; duration: 2000 } } } } Component { id: headerrect Rectangle { id: hdr; color: "brown"; width: listviewelement.width - 4; height: 30; radius: 5; opacity: .5 Text { anchors.centerIn: parent; text: "Nokia Devices" } } } Component { id: footerrect Rectangle { id: ftr; color: "brown"; width: listviewelement.width - 4; height: 30; radius: 5; opacity: .5 Text { anchors.centerIn: parent; text: "Nokia pty ltd." } } } SystemTestHelp { id: helpbubble; visible: statenum != 0 anchors { top: parent.top; horizontalCenter: parent.horizontalCenter; topMargin: 50 } } BugPanel { id: bugpanel } states: [ State { name: "start"; when: statenum == 1 PropertyChanges { target: listviewelementtest testtext: "This is a ListView element. At present it should be displaying the names of a few Nokia devices, ordered by Operating System.\n"+ "Next, let's view the end of the list" } }, State { name: "end"; when: statenum == 2 StateChangeScript { script: listviewelement.positionViewAtEnd(); } PropertyChanges { target: listviewelementtest testtext: "The end of the list should now be visible.\nNext, let's add a highlight." } }, State { name: "highlight"; when: statenum == 3 PropertyChanges { target: listviewelement; currentIndex: 0 } StateChangeScript { script: listviewelement.positionViewAtBeginning(); } PropertyChanges { target: listviewelementtest; hivis: true } PropertyChanges { target: listviewelementtest testtext: "The ListView should now be showing a highlight on the first item.\n"+ "Next, let's move to an item down the list." } }, State { name: "highlight7"; when: statenum == 4 PropertyChanges { target: listviewelement; currentIndex: 6 } PropertyChanges { target: listviewelementtest; hivis: true } PropertyChanges { target: listviewelementtest testtext: "The ListView should now be showing the highlight over item 7 - the N95\n"+ "Next let's add some space between them." } }, State { name: "sections"; when: statenum == 5 PropertyChanges { target: listviewelement; currentIndex: 6 } PropertyChanges { target: listviewelement; spacing: 5 } PropertyChanges { target: listviewelementtest; hivis: true } PropertyChanges { target: listviewelementtest testtext: "The ListView should now be showing a space between each list item,\n"+ "but not after the header and sections, or before the footer.\n"+ "Advance to restart the test." } } ] ListModel { id: devices ListElement { name: "N900"; os: "Maemo" } ListElement { name: "N810"; os: "Maemo" } ListElement { name: "N9"; os: "Meego" } ListElement { name: "N-Gage QD"; os: "S60 1.2" } ListElement { name: "E90"; os: "S60 2nd" } ListElement { name: "E72"; os: "S60 3.2" } ListElement { name: "N95"; os: "S60 5.0" } ListElement { name: "X6"; os: "S60 5.0" } ListElement { name: "N97"; os: "Symbian^1" } ListElement { name: "5800"; os: "Symbian^1" } ListElement { name: "E7"; os: "Symbian^3" } ListElement { name: "N8"; os: "Symbian^3" } ListElement { name: "C7"; os: "Symbian^3" } ListElement { name: "X7"; os: "Symbian Anna" } } }