1
/****************************************************************************
3
** Copyright (C) 2011 Nokia Corporation and/or its subsidiary(-ies).
4
** All rights reserved.
5
** Contact: Nokia Corporation (qt-info@nokia.com)
7
** This file is part of the Qt Components project.
9
** $QT_BEGIN_LICENSE:BSD$
10
** You may use this file under the terms of the BSD license as follows:
12
** "Redistribution and use in source and binary forms, with or without
13
** modification, are permitted provided that the following conditions are
15
** * Redistributions of source code must retain the above copyright
16
** notice, this list of conditions and the following disclaimer.
17
** * Redistributions in binary form must reproduce the above copyright
18
** notice, this list of conditions and the following disclaimer in
19
** the documentation and/or other materials provided with the
21
** * Neither the name of Nokia Corporation and its Subsidiary(-ies) nor
22
** the names of its contributors may be used to endorse or promote
23
** products derived from this software without specific prior written
26
** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
27
** "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
28
** LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
29
** A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
30
** OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
31
** SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
32
** LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
33
** DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
34
** THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
35
** (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
36
** OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE."
39
****************************************************************************/
41
// Page stack. Items are page containers.
44
// Page component cache map. Key is page url, value is page component.
45
var componentCache = {};
47
// Returns the page stack depth.
49
return pageStack.length;
52
// Pushes a page on the stack.
53
function push(page, properties, replace, immediate) {
54
// page order sanity check
55
if ((!replace && page == currentPage)
56
|| (replace && pageStack.length > 1
57
&& page == pageStack[pageStack.length - 2].page)) {
58
throw new Error("Cannot navigate so that the resulting page stack has two consecutive entries of the same page instance.");
61
// figure out if more than one page is being pushed
63
if (page instanceof Array) {
66
if (page.createObject === undefined && page.parent === undefined && typeof page != "string") {
67
properties = properties || page.properties;
72
// get the current container
73
var oldContainer = pageStack[pageStack.length - 1];
75
// pop the old container off the stack if this is a replace
76
if (oldContainer && replace) {
80
// push any extra defined pages onto the stack
83
for (i = 0; i < pages.length; i++) {
86
if (tPage.createObject === undefined && tPage.parent === undefined && typeof tPage != "string") {
87
tProps = tPage.properties;
90
pageStack.push(initPage(tPage, tProps));
94
// initialize the page
95
var container = initPage(page, properties);
97
// push the page container onto the stack
98
pageStack.push(container);
100
depth = pageStack.length;
101
currentPage = container.page;
103
// perform page transition
104
immediate = immediate || !oldContainer;
105
var orientationChange = false;
107
orientationChange = orientationChanges(oldContainer.page, container.page);
108
oldContainer.pushExit(replace, immediate, orientationChange);
112
var tools = container.page.tools || null;
114
toolBar.setTools(tools, immediate ? "set" : replace ? "replace" : "push");
117
container.pushEnter(immediate, orientationChange);
118
return container.page;
121
// Initializes a page and its container.
122
function initPage(page, properties) {
123
var container = containerComponent.createObject(root);
126
if (page.createObject) {
127
// page defined as component
129
} else if (typeof page == "string") {
130
// page defined as string (a url)
131
pageComp = componentCache[page];
133
pageComp = componentCache[page] = Qt.createComponent(page);
137
if (pageComp.status == Component.Error) {
138
throw new Error("Error while loading page: " + pageComp.errorString());
140
// instantiate page from component
141
page = pageComp.createObject(container, properties || {});
144
// copy properties to the page
145
for (var prop in properties) {
146
if (properties.hasOwnProperty(prop)) {
147
page[prop] = properties[prop];
152
container.page = page;
153
if (page.parent == null) {
154
container.owner = container;
156
container.owner = page.parent;
159
// the page has to be reparented if
160
if (page.parent != container) {
161
page.parent = container;
164
if (page.pageStack !== undefined) {
165
page.pageStack = root;
168
page.anchors.fill = container
173
// Pops a page off the stack.
174
function pop(page, immediate) {
175
// make sure there are enough pages in the stack to pop
176
if (pageStack.length > 1) {
177
//unwind to itself means no pop
178
if (page !== undefined && page == pageStack[pageStack.length - 1].page) {
181
// pop the current container off the stack and get the next container
182
var oldContainer = pageStack.pop();
183
var container = pageStack[pageStack.length - 1];
184
if (page !== undefined) {
185
// an unwind target has been specified - pop until we find it
186
while (page != container.page && pageStack.length > 1) {
189
container = pageStack[pageStack.length - 1];
193
depth = pageStack.length;
194
currentPage = container.page;
196
// perform page transition
197
var orientationChange = orientationChanges(oldContainer.page, container.page);
198
oldContainer.popExit(immediate, orientationChange);
199
container.popEnter(immediate, orientationChange);
202
var tools = container.page.tools || null;
204
toolBar.setTools(tools, immediate ? "set" : "pop");
206
return oldContainer.page;
212
// Checks if the orientation changes between oldPage and newPage
213
function orientationChanges(oldPage, newPage) {
214
return newPage.orientationLock != PageOrientation.Automatic
215
&& newPage.orientationLock != PageOrientation.LockPrevious
216
&& newPage.orientationLock != oldPage.orientationLock
219
// Clears the page stack.
222
while (container = pageStack.pop()) {
229
// Iterates through all pages in the stack (top to bottom) to find a page.
230
function find(func) {
231
for (var i = pageStack.length - 1; i >= 0; i--) {
232
var page = pageStack[i].page;