123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170 |
- import QtQuick 2.10
- import QtQuick.Controls 2.3
- import UM 1.3 as UM
- import Cura 1.0 as Cura
- ScrollView
- {
- id: base
- property var currentItem: null
- property string currentSection: preferredCategory
- property string preferredCategory: "Ultimaker"
- background: Rectangle
- {
- anchors.fill: parent
- color: "white"
- }
- ListView
- {
- id: machineList
- model: UM.DefinitionContainersModel
- {
- id: machineDefinitionsModel
- filter: { "visible": true }
- sectionProperty: "category"
- preferredSectionValue: preferredCategory
- }
- section.property: "section"
- section.delegate: sectionHeader
- delegate: machineButton
- }
- Component
- {
- id: sectionHeader
- Button
- {
- id: button
- width: ListView.view.width
- height: UM.Theme.getSize("action_button").height
- text: section
- property bool isActive: base.currentSection == section
- background: Rectangle
- {
- anchors.fill: parent
- color: isActive ? UM.Theme.getColor("setting_control_highlight") : "transparent"
- }
- contentItem: Item
- {
- width: childrenRect.width
- height: UM.Theme.getSize("action_button").height
- UM.RecolorImage
- {
- id: arrow
- anchors.left: parent.left
-
- width: UM.Theme.getSize("standard_arrow").width
- height: UM.Theme.getSize("standard_arrow").height
- sourceSize.width: width
- sourceSize.height: height
- color: UM.Theme.getColor("text")
- source: base.currentSection == section ? UM.Theme.getIcon("arrow_bottom") : UM.Theme.getIcon("arrow_right")
- }
- Label
- {
- id: label
- anchors.left: arrow.right
- anchors.leftMargin: UM.Theme.getSize("default_margin").width
- verticalAlignment: Text.AlignVCenter
- text: button.text
- font.bold: true
- renderType: Text.NativeRendering
- }
- }
- onClicked:
- {
- if (base.currentSection != section)
- {
-
- for (var i = 0; i < ListView.view.count; i++)
- {
- var item = ListView.view.model.getItem(i)
- if (item.section == section)
- {
- base.currentItem = item
- base.currentSection = item.section
- ListView.view.currentIndex = i
- break
- }
- }
- }
- }
- }
- }
- Component
- {
- id: machineButton
- RadioButton
- {
- id: radioButton
- anchors.left: parent.left
- anchors.leftMargin: UM.Theme.getSize("standard_list_lineheight").width
- anchors.right: parent.right
- anchors.rightMargin: UM.Theme.getSize("default_margin").width
- height: visible ? UM.Theme.getSize("standard_list_lineheight").height : 0
- checked: ListView.view.currentIndex == index
- text: name
- font: UM.Theme.getFont("default")
- visible: base.currentSection == section
- background: Rectangle
- {
- anchors.fill: parent
- color: "transparent"
- }
- indicator: Rectangle
- {
- implicitWidth: 16
- implicitHeight: 16
- anchors.verticalCenter: parent.verticalCenter
- radius: width / 2
- border.width: UM.Theme.getSize("default_lining").width
- border.color: radioButton.hovered ? UM.Theme.getColor("small_button_text") : UM.Theme.getColor("small_button_text_hover")
- Rectangle {
- width: parent.width / 2
- height: width
- anchors.centerIn: parent
- radius: width / 2
- color: radioButton.hovered ? UM.Theme.getColor("primary_button_hover") : UM.Theme.getColor("primary_button")
- visible: radioButton.checked
- }
- }
- contentItem: Label
- {
- verticalAlignment: Text.AlignVCenter
- leftPadding: radioButton.indicator.width + radioButton.spacing
- text: radioButton.text
- font: radioButton.font
- renderType: Text.NativeRendering
- }
- onClicked:
- {
- ListView.view.currentIndex = index
- }
- }
- }
- }
|