PoC: Qt Compositor-ized homescreen
[apps/homescreen.git] / homescreen / qml / Home.qml
1 /*
2  * Copyright (C) 2016 The Qt Company Ltd.
3  * Copyright (C) 2016, 2017 Mentor Graphics Development (Deutschland) GmbH
4  *
5  * Licensed under the Apache License, Version 2.0 (the "License");
6  * you may not use this file except in compliance with the License.
7  * You may obtain a copy of the License at
8  *
9  *      http://www.apache.org/licenses/LICENSE-2.0
10  *
11  * Unless required by applicable law or agreed to in writing, software
12  * distributed under the License is distributed on an "AS IS" BASIS,
13  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14  * See the License for the specific language governing permissions and
15  * limitations under the License.
16  */
17
18 import QtQuick 2.2
19 import Home 1.0
20
21 Item {
22     id: root
23
24     Image {
25         anchors.fill: parent
26         anchors.topMargin: -218
27         anchors.bottomMargin: -215
28         source: './images/AGL_HMI_Background_Car-01.png'
29     }
30
31     property int pid: -1
32
33     GridView {
34         id: grid
35         anchors.centerIn: parent
36         width: cellHeight * 3
37         height: cellHeight * 3
38         cellWidth: 320
39         cellHeight: 320
40         interactive: false
41
42         model: ApplicationModel { id: applicationModel }
43         delegate: IconItem {
44             width: grid.cellWidth
45             height: grid.cellHeight
46         }
47
48         MouseArea {
49             id: loc
50             anchors.fill: parent
51             property string currentId: ''
52             property int newIndex: -1
53             property int index: grid.indexAt(loc.mouseX, loc.mouseY)
54             onPressAndHold: currentId = applicationModel.id(newIndex = index)
55             onReleased: {
56                 if (currentId === '') {
57                     launcher.show(applicationModel.id(loc.index))
58                 } else {
59                     currentId = ''
60                 }
61             }
62             onPositionChanged: {
63                 if (loc.currentId === '') return
64                 if (index < 0) return
65                 if (index === newIndex) return
66                     applicationModel.move(newIndex, newIndex = index)
67             }
68         }
69     }
70 }