2 * Copyright 2014 Canonical Ltd.
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU Lesser General Public License as published by
6 * the Free Software Foundation; version 3.
8 * This program is distributed in the hope that it will be useful,
9 * but WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 * GNU Lesser General Public License for more details.
13 * You should have received a copy of the GNU Lesser General Public License
14 * along with this program. If not, see <http://www.gnu.org/licenses/>.
18 import Ubuntu.Components 1.3
19 import Ubuntu.Components.Themes 1.3
20 import "../Components"
22 import Ubuntu.Components.Themes.Ambiance 1.3 as Ambiance
27 property color backgroundColor: d.undefinedColor
28 property color headerColor: d.undefinedColor
29 property color footerColor: d.undefinedColor
30 property alias imageSource: overlaidImage.source
32 property alias title: headerConfig.title
33 property alias showHeader: header.visible
42 // As specified in qtmir, it will set the color value to this for fields left undefined
43 // This is also the default value of a color property in QML.
44 readonly property color undefinedColor: "#00000000"
46 readonly property color defaultBackgroundColor: header.visible ? ambiancePalette.normal.background : "black"
48 // Splash screen that shows the application icon and splashTitle
49 readonly property bool showIcon: overlaidImage.status == Image.Null && !root.showHeader
56 // mimic API of toolkit's MainView component required by MainViewStyle
57 property color backgroundColor: Qt.colorEqual(root.backgroundColor, d.undefinedColor) ? d.defaultBackgroundColor
58 : root.backgroundColor
59 property color headerColor: Qt.colorEqual(root.headerColor, d.undefinedColor) ? styledItem.backgroundColor
61 property color footerColor: Qt.colorEqual(root.footerColor, d.undefinedColor) ? styledItem.backgroundColor
64 // FIXME: fake a Theme object as to expose the Palette corresponding to the backgroundColor (see MainViewStyle.qml)
65 readonly property var fakeTheme: QtObject {
67 property Palette palette: Qt.createQmlObject("import QtQuick 2.4;\
68 import Ubuntu.Components.Themes.%1 1.3;\
69 Palette {}".arg(styledItem.fakeTheme.name),
70 styledItem, "dynamicPalette");
73 // FIXME: should instead use future toolkit API:
74 // style: theme.createStyleComponent("MainViewStyle.qml", styledItem)
75 style: Component { MainViewStyle {theme: styledItem.fakeTheme} }
78 Ambiance.PageHeadStyle {
84 property var styledItem: header
85 // FIXME Keep in sync with SDK's MainView.qml values of these two colors
86 property color dividerColor: Qt.darker(styledItem.backgroundColor, 1.1)
87 property color panelColor: Qt.lighter(styledItem.backgroundColor, 1.1)
88 panelForegroundColor: config.foregroundColor
89 config: PageHeadConfiguration {
91 foregroundColor: styledItem.fakeTheme.palette.selected.backgroundText
94 property var contents: null
99 anchors.centerIn: parent
100 anchors.verticalCenterOffset: header.visible ? header.height / 2 : 0
111 anchors.horizontalCenter: parent.horizontalCenter
112 anchors.verticalCenter: parent.verticalCenter
113 anchors.verticalCenterOffset: -units.gu(4)
115 height: units.gu(7.5)
120 aspect: UbuntuShape.Flat
121 sourceFillMode: Image.PreserveAspectCrop
124 sourceSize.width: iconShape.width
125 sourceSize.height: iconShape.height
126 source: d.showIcon ? root.icon : ""
132 anchors.horizontalCenter: parent.horizontalCenter
133 anchors.top: iconShape.bottom
134 anchors.topMargin: units.gu(2)
137 color: styledItem.fakeTheme.palette.selected.backgroundText
142 anchors.centerIn: header.visible ? parent : undefined
143 anchors.verticalCenterOffset: header.visible ? header.height / 2 : 0
145 anchors.horizontalCenter: header.visible ? undefined : parent.horizontalCenter
146 anchors.bottom: header.visible ? undefined : parent.bottom
147 anchors.bottomMargin: header.visible ? 0 : units.gu(12)
154 enabled: parent.visible
155 // absorb all mouse events