/**************************************************************************** ** ** Copyright (c) 2011 Nokia Corporation and/or its subsidiary(-ies). ** All rights reserved. ** Contact: Yoann Lopes (yoann.lopes@nokia.com) ** ** This file is part of the MeeSpot project. ** ** Redistribution and use in source and binary forms, with or without ** modification, are permitted provided that the following conditions ** are met: ** ** Redistributions of source code must retain the above copyright notice, ** this list of conditions and the following disclaimer. ** ** Redistributions in binary form must reproduce the above copyright ** notice, this list of conditions and the following disclaimer in the ** documentation and/or other materials provided with the distribution. ** ** Neither the name of Nokia Corporation and its Subsidiary(-ies) nor the names of its ** contributors may be used to endorse or promote products derived from ** this software without specific prior written permission. ** ** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS ** "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT ** LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS ** FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT ** HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, ** SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED ** TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR ** PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF ** LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING ** NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS ** SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. ** ** If you have questions regarding the use of this file, please contact ** Nokia at qt-info@nokia.com. ** ****************************************************************************/ import QtQuick 1.1 import com.nokia.meego 1.0 import "UIConstants.js" as UI Item { id: listItem signal clicked signal pressAndHold property alias pressed: mouseArea.pressed property alias name: mainText.text property alias duration: timing.text property bool highlighted: false property bool starred: false property bool available: true property color highlightColor: UI.SPOTIFY_COLOR property int titleSize: UI.LIST_TILE_SIZE property string titleFont: UI.FONT_FAMILY_BOLD property color titleColor: theme.inverted ? UI.LIST_TITLE_COLOR_INVERTED : UI.LIST_TITLE_COLOR property int subtitleSize: UI.LIST_SUBTILE_SIZE property string subtitleFont: UI.FONT_FAMILY_LIGHT property color subtitleColor: theme.inverted ? UI.LIST_SUBTITLE_COLOR_INVERTED : UI.LIST_SUBTITLE_COLOR height: UI.LIST_ITEM_HEIGHT_SMALL width: parent.width SequentialAnimation { id: backAnimation property bool animEnded: false running: mouseArea.pressed ScriptAction { script: backAnimation.animEnded = false } PauseAnimation { duration: 200 } ParallelAnimation { NumberAnimation { target: background; property: "opacity"; to: 0.4; duration: 300 } ColorAnimation { target: mainText; property: "color"; to: theme.inverted ? "black" : "#DDDDDD"; duration: 300 } ColorAnimation { target: timing; property: "color"; to: theme.inverted ? "black" : "#DDDDDD"; duration: 300 } NumberAnimation { target: iconItem; property: "opacity"; to: 0.2; duration: 300 } } PauseAnimation { duration: 100 } ScriptAction { script: { backAnimation.animEnded = true; listItem.pressAndHold(); } } onRunningChanged: { if (!running) { iconItem.opacity = 1.0 mainText.color = highlighted ? listItem.highlightColor : listItem.titleColor timing.color = highlighted ? listItem.highlightColor : listItem.subtitleColor } } } Connections { target: theme onInvertedChanged: { mainText.color = highlighted ? listItem.highlightColor : listItem.titleColor timing.color = highlighted ? listItem.highlightColor : listItem.subtitleColor } } onHighlightedChanged: { mainText.color = highlighted ? listItem.highlightColor : listItem.titleColor timing.color = highlighted ? listItem.highlightColor : listItem.subtitleColor } Rectangle { id: background anchors.fill: parent // Fill page porders anchors.leftMargin: -UI.MARGIN_XLARGE anchors.rightMargin: -UI.MARGIN_XLARGE opacity: mouseArea.pressed ? 1.0 : 0.0 color: theme.inverted ? "#22FFFFFF" : "#15000000" } Item { anchors.left: parent.left anchors.right: parent.right anchors.verticalCenter: parent.verticalCenter opacity: listItem.available ? 1.0 : 0.3 Label { id: mainText anchors.left: parent.left anchors.right: iconItem.left anchors.rightMargin: UI.MARGIN_XLARGE anchors.verticalCenter: parent.verticalCenter font.family: listItem.titleFont font.weight: Font.Bold font.pixelSize: listItem.titleSize color: highlighted ? listItem.highlightColor : listItem.titleColor elide: Text.ElideRight Behavior on color { ColorAnimation { duration: 200 } } } Image { id: iconItem anchors.right: timing.left anchors.rightMargin: UI.MARGIN_XLARGE anchors.verticalCenter: parent.verticalCenter anchors.verticalCenterOffset: -2 width: 34; height: width smooth: true visible: listItem.starred source: "image://theme/icon-m-toolbar-favorite-mark" + (theme.inverted ? "-white" : "") } Label { id: timing anchors.verticalCenter: parent.verticalCenter font.family: listItem.subtitleFont font.weight: Font.Light font.pixelSize: listItem.subtitleSize color: highlighted ? listItem.highlightColor : listItem.subtitleColor anchors.right: parent.right visible: text != "" Behavior on color { ColorAnimation { duration: 200 } } } } MouseArea { id: mouseArea; anchors.fill: parent onClicked: { if (!backAnimation.animEnded) listItem.clicked(); } } }