/**************************************************************************** ** ** Copyright (C) 2015 The Qt Company Ltd. ** Contact: http://www.qt.io/licensing/ ** ** This file is part of the Qt Quick Controls module of the Qt Toolkit. ** ** $QT_BEGIN_LICENSE:LGPL3$ ** Commercial License Usage ** Licensees holding valid commercial Qt licenses may use this file in ** accordance with the commercial license agreement provided with the ** Software or, alternatively, in accordance with the terms contained in ** a written agreement between you and The Qt Company. For licensing terms ** and conditions see http://www.qt.io/terms-conditions. For further ** information use the contact form at http://www.qt.io/contact-us. ** ** GNU Lesser General Public License Usage ** Alternatively, this file may be used under the terms of the GNU Lesser ** General Public License version 3 as published by the Free Software ** Foundation and appearing in the file LICENSE.LGPLv3 included in the ** packaging of this file. Please review the following information to ** ensure the GNU Lesser General Public License version 3 requirements ** will be met: https://www.gnu.org/licenses/lgpl.html. ** ** GNU General Public License Usage ** Alternatively, this file may be used under the terms of the GNU ** General Public License version 2.0 or later 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 2.0 requirements will be ** met: http://www.gnu.org/licenses/gpl-2.0.html. ** ** $QT_END_LICENSE$ ** ****************************************************************************/ import QtQuick 2.2 import QtQuick.Controls 1.2 import QtQuick.Controls.Private 1.0 Loader { id: loader property var styleDef property bool focused property bool pressed property bool checked property bool selected property bool accelerated property bool window_focused property int index: 0 property real level: 0 property string levelId: "" property int orientations: Qt.Horizontal property int duration: 0 property var excludes: [] property var clippables: [] property Padding padding: Padding { top: loader.item ? loader.item.padding.top : 0 left: loader.item ? loader.item.padding.left : 0 right: loader.item ? loader.item.padding.right : 0 bottom: loader.item ? loader.item.padding.bottom : 0 } readonly property string type: styleDef ? styleDef.type : "" readonly property bool isExcluded: !!styleDef && excludes.indexOf(styleDef.id) !== -1 readonly property bool isClippable: !!styleDef && clippables.indexOf(styleDef.id) !== -1 active: !!styleDef && !isExcluded sourceComponent: type === "animation" ? Qt.createComponent("AnimationDrawable.qml") : isClippable || type === "clipDrawable" ? Qt.createComponent("ClipDrawable.qml") : type === "color" ? Qt.createComponent("ColorDrawable.qml") : type === "gradient" ? Qt.createComponent("GradientDrawable.qml") : type === "image" ? Qt.createComponent("ImageDrawable.qml") : type === "layer" ? Qt.createComponent("LayerDrawable.qml") : type === "9patch" ? Qt.createComponent("NinePatchDrawable.qml") : type === "rotate" ? Qt.createComponent("RotateDrawable.qml") : type === "stateslist" ? Qt.createComponent("StateDrawable.qml") : null Binding { target: loader.item; property: "styleDef"; value: loader.styleDef } Binding { target: loader.item; property: "focused"; value: loader.focused } Binding { target: loader.item; property: "pressed"; value: loader.pressed } Binding { target: loader.item; property: "checked"; value: loader.checked } Binding { target: loader.item; property: "selected"; value: loader.selected } Binding { target: loader.item; property: "accelerated"; value: loader.accelerated } Binding { target: loader.item; property: "window_focused"; value: loader.window_focused } Binding { target: loader.item; property: "level"; value: loader.level } Binding { target: loader.item; property: "levelId"; value: loader.levelId } Binding { target: loader.item; property: "orientations"; value: loader.orientations } Binding { target: loader.item; property: "duration"; value: loader.duration } Binding { target: loader.item; property: "excludes"; value: loader.excludes } Binding { target: loader.item; property: "clippables"; value: loader.clippables } }