import QtQuick 2.4
import "."

Item {
    property bool checked: false
    property alias label: label.text
    property bool enabled: true

    implicitWidth: track.width + label.width + 16
    implicitHeight: Math.max(label.height, thumb.height)

    Rectangle {
        id: track
        width: height * 2
        height: radius * 2
        radius: Style.roundRadius

        color: (checked && enabled) ? Style.frameColor : Style.minorFrameColor
        anchors.left: parent.left
        anchors.leftMargin: Style.margin
        anchors.verticalCenter: parent.verticalCenter

        Rectangle {
            id: thumb
            width: radius * 2
            height: radius * 2
            radius: Style.roundRadius * 1.5

            anchors.verticalCenter: parent.verticalCenter
            color: (checked && enabled) ? Style.themeColor : "white"
            border.width: 1
            border.color: Style.inactiveThemeColor

            x: checked ? parent.width - (track.radius + radius) : (track.radius - radius)

            Behavior on x {
                NumberAnimation {
                    duration: 250
                }
            }
        }
    }

    Text {
        id: label
        anchors.left: track.right
        anchors.leftMargin: Style.margin
        anchors.verticalCenter: parent.verticalCenter
        font.pixelSize: Style.baseFontPixelSize
    }

    MouseArea {
        anchors.fill: parent
        id: mouseArea
        enabled: root.enabled

        hoverEnabled: true
        onClicked: {
            checked = !checked
        }
    }
}