GroupBox.qml 3.7 KB
/* Webcamoid, webcam capture application.
 * Copyright (C) 2019  Gonzalo Exequiel Pedone
 *
 * Webcamoid is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * Webcamoid is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with Webcamoid. If not, see <http://www.gnu.org/licenses/>.
 *
 * Web-Site: http://webcamoid.github.io/
 */

import QtQuick
import QtQuick.Controls
import QtQuick.Templates as T
import Ak

T.GroupBox {
    id: control
    implicitWidth: Math.max(implicitBackgroundWidth + leftInset + rightInset,
                            contentWidth + leftPadding + rightPadding,
                            implicitLabelWidth + leftPadding + rightPadding)
    implicitHeight: Math.max(implicitBackgroundHeight + topInset + bottomInset,
                             contentHeight + topPadding + bottomPadding)
    spacing: AkUnit.create(6 * AkTheme.controlScale, "dp").pixels
    padding: AkUnit.create(8 * AkTheme.controlScale, "dp").pixels
    topPadding: groupTitle.text?
                    groupTitle.height
                    + titleTopPadding
                    + titleBottomPadding:
                    AkUnit.create(8 * AkTheme.controlScale, "dp").pixels
    clip: true

    property int titleTopPadding:
        AkUnit.create(8 * AkTheme.controlScale, "dp").pixels
    property int titleBottomPadding:
        AkUnit.create(16 * AkTheme.controlScale, "dp").pixels
    readonly property color activeDark: AkTheme.palette.active.dark
    readonly property color activeLink: AkTheme.palette.active.link
    readonly property color activeWindowText: AkTheme.palette.active.windowText
    readonly property color disabledDark: AkTheme.palette.disabled.dark
    readonly property color disabledLink: AkTheme.palette.disabled.link
    readonly property color disabledWindowText: AkTheme.palette.disabled.windowText

    label: Text {
        id: groupTitle
        x: control.leftPadding
        y: titleTopPadding
        width: control.availableWidth
        text: control.title
        font.bold: true
        font.capitalization: control.font.capitalization
        font.family: control.font.family
        font.hintingPreference: control.font.hintingPreference
        font.italic: control.font.italic
        font.kerning: control.font.kerning
        font.letterSpacing: control.font.letterSpacing
        font.pointSize: control.font.pointSize
        font.preferShaping: control.font.preferShaping
        font.strikeout: control.font.strikeout
        font.styleName: control.font.styleName
        font.underline: control.font.underline
        font.wordSpacing: control.font.wordSpacing
        color: control.enabled?
                   control.activeWindowText:
                   control.disabledWindowText
        linkColor: control.enabled?
                       control.activeLink:
                       control.disabledLink
        elide: Text.ElideRight
        verticalAlignment: Text.AlignVCenter
        enabled: control.enabled
    }

    background: Rectangle {
        width: parent.width
        height: parent.height
        radius: AkUnit.create(4 * AkTheme.controlScale, "dp").pixels
        color: "transparent"
        border.color: enabled?
                          control.activeDark:
                          control.disabledDark
        border.width: AkUnit.create(1 * AkTheme.controlScale, "dp").pixels
    }
}