SwitchDelegate.qml 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. // Copyright (C) 2017 The Qt Company Ltd.
  2. // SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only
  3. // Qt-Security score:significant reason:default
  4. import QtQuick
  5. import QtQuick.Templates as T
  6. import QtQuick.Controls.impl
  7. import QtQuick.Controls.Material
  8. import QtQuick.Controls.Material.impl
  9. T.SwitchDelegate {
  10. id: control
  11. implicitWidth: Math.max(implicitBackgroundWidth + leftInset + rightInset,
  12. implicitContentWidth + leftPadding + rightPadding)
  13. implicitHeight: Math.max(implicitBackgroundHeight + topInset + bottomInset,
  14. implicitContentHeight + topPadding + bottomPadding,
  15. implicitIndicatorHeight + topPadding + bottomPadding)
  16. padding: 16
  17. verticalPadding: Material.switchDelegateVerticalPadding
  18. spacing: 16
  19. icon.width: 24
  20. icon.height: 24
  21. icon.color: enabled ? Material.foreground : Material.hintTextColor
  22. indicator: SwitchIndicator {
  23. x: control.text ? (control.mirrored ? control.leftPadding : control.width - width - control.rightPadding) : control.leftPadding + (control.availableWidth - width) / 2
  24. y: control.topPadding + (control.availableHeight - height) / 2
  25. control: control
  26. }
  27. contentItem: IconLabel {
  28. leftPadding: !control.mirrored ? 0 : control.indicator.width + control.spacing
  29. rightPadding: control.mirrored ? 0 : control.indicator.width + control.spacing
  30. spacing: control.spacing
  31. mirrored: control.mirrored
  32. display: control.display
  33. alignment: control.display === IconLabel.IconOnly || control.display === IconLabel.TextUnderIcon ? Qt.AlignCenter : Qt.AlignLeft
  34. icon: control.icon
  35. text: control.text
  36. font: control.font
  37. color: control.enabled ? control.Material.foreground : control.Material.hintTextColor
  38. }
  39. background: Rectangle {
  40. implicitHeight: control.Material.delegateHeight
  41. color: control.highlighted ? control.Material.listHighlightColor : "transparent"
  42. Ripple {
  43. width: parent.width
  44. height: parent.height
  45. clip: visible
  46. pressed: control.pressed
  47. anchor: control
  48. active: enabled && (control.down || control.visualFocus || control.hovered)
  49. color: control.Material.rippleColor
  50. }
  51. }
  52. }