SpinBox.qml 3.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. // Copyright (C) 2020 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.NativeStyle as NativeStyle
  7. T.SpinBox {
  8. id: control
  9. property bool nativeIndicators: up.indicator.hasOwnProperty("_qt_default")
  10. && down.indicator.hasOwnProperty("_qt_default")
  11. readonly property bool __notCustomizable: true
  12. // Note: the indicators are inside the contentItem
  13. implicitWidth: Math.max(implicitBackgroundWidth + leftInset + rightInset,
  14. contentItem.implicitWidth + leftPadding + rightPadding)
  15. implicitHeight: Math.max(implicitBackgroundHeight + topInset + bottomInset,
  16. implicitContentHeight + topPadding + bottomPadding,
  17. up.implicitIndicatorHeight + down.implicitIndicatorHeight)
  18. spacing: 2
  19. validator: IntValidator {
  20. locale: control.locale.name
  21. bottom: Math.min(control.from, control.to)
  22. top: Math.max(control.from, control.to)
  23. }
  24. contentItem: TextField {
  25. text: control.displayText
  26. font: control.font
  27. color: control.palette.text
  28. selectionColor: control.palette.highlight
  29. selectedTextColor: control.palette.highlightedText
  30. horizontalAlignment: Qt.AlignLeft
  31. verticalAlignment: Qt.AlignVCenter
  32. implicitWidth: Math.max(90 /* minimum */, contentWidth + leftPadding + rightPadding)
  33. topPadding: 0
  34. bottomPadding: 0
  35. leftPadding: 10
  36. rightPadding: up.indicator.width + 10
  37. readOnly: !control.editable
  38. validator: control.validator
  39. inputMethodHints: control.inputMethodHints
  40. clip: width < implicitWidth
  41. readonly property bool __ignoreNotCustomizable: true
  42. // Since the indicators are embedded inside the TextField we need to avoid that
  43. // the TextField consumes mouse events for that area.
  44. // We achieve that by setting a containmentMask
  45. containmentMask: Item { height: contentItem.height; width: contentItem.width - upAndDown.width }
  46. }
  47. NativeStyle.SpinBox {
  48. id: upAndDown
  49. control: control
  50. subControl: NativeStyle.SpinBox.Up
  51. visible: nativeIndicators
  52. x: up.indicator.x
  53. y: up.indicator.y
  54. //implicitHeight: contentItem.implicitHeight-2
  55. height: parent.height-2
  56. useNinePatchImage: false
  57. z:99
  58. }
  59. up.indicator: Item {
  60. x: control.width - width - 2
  61. y: 1
  62. height: upAndDown.height >> 1
  63. implicitWidth: upAndDown.implicitWidth
  64. implicitHeight: (upAndDown.implicitHeight >> 1)
  65. property bool _qt_default
  66. readonly property bool __ignoreNotCustomizable: true
  67. }
  68. down.indicator: Item {
  69. x: control.width - width - 2
  70. y: up.indicator.y + (upAndDown.height >> 1)
  71. height: upAndDown.height - up.indicator.height
  72. implicitWidth: upAndDown.implicitWidth
  73. implicitHeight: upAndDown.implicitHeight >> 1
  74. property bool _qt_default
  75. readonly property bool __ignoreNotCustomizable: true
  76. }
  77. // No background, the TextField will cover the whole control
  78. background: Item {
  79. readonly property bool __ignoreNotCustomizable: true
  80. }
  81. }