mirror of
https://github.com/Ultimaker/Cura.git
synced 2025-07-06 22:47:29 -06:00
Fix Settings lines positioning for Per Object Settings
CURA-6683
This commit is contained in:
parent
667e5f8e18
commit
44fbcaeb3a
1 changed files with 306 additions and 304 deletions
|
@ -41,10 +41,12 @@ Item
|
||||||
}
|
}
|
||||||
|
|
||||||
function setMeshType(type){
|
function setMeshType(type){
|
||||||
|
print("setting mesh type to " + type)
|
||||||
UM.ActiveTool.setProperty("MeshType", type)
|
UM.ActiveTool.setProperty("MeshType", type)
|
||||||
}
|
}
|
||||||
|
|
||||||
function updateView(type) {
|
function updateView(type) {
|
||||||
|
print("updating view for type " + type)
|
||||||
|
|
||||||
// set checked state of mesh type buttons
|
// set checked state of mesh type buttons
|
||||||
normalButton.checked = type === normal_mesh_type
|
normalButton.checked = type === normal_mesh_type
|
||||||
|
@ -149,6 +151,206 @@ Item
|
||||||
onClicked: setOverhangsMeshType()
|
onClicked: setOverhangsMeshType()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Column // Settings Dialog
|
||||||
|
{
|
||||||
|
// This is to ensure that the panel is first increasing in size up to 200 and then shows a scrollbar.
|
||||||
|
// It kinda looks ugly otherwise (big panel, no content on it)
|
||||||
|
id: currentSettings
|
||||||
|
property int maximumHeight: 200 * screenScaleFactor
|
||||||
|
height: Math.min(contents.count * (UM.Theme.getSize("section").height + UM.Theme.getSize("default_lining").height), maximumHeight)
|
||||||
|
visible: current_mesh_type != "anti_overhang_mesh"
|
||||||
|
|
||||||
|
ScrollView
|
||||||
|
{
|
||||||
|
height: parent.height
|
||||||
|
width: UM.Theme.getSize("setting").width + UM.Theme.getSize("default_margin").width
|
||||||
|
style: UM.Theme.styles.scrollview
|
||||||
|
|
||||||
|
ListView
|
||||||
|
{
|
||||||
|
id: contents
|
||||||
|
spacing: UM.Theme.getSize("default_lining").height
|
||||||
|
|
||||||
|
model: UM.SettingDefinitionsModel
|
||||||
|
{
|
||||||
|
id: addedSettingsModel
|
||||||
|
containerId: Cura.MachineManager.activeMachine != null ? Cura.MachineManager.activeMachine.definition.id: ""
|
||||||
|
expanded: [ "*" ]
|
||||||
|
filter:
|
||||||
|
{
|
||||||
|
if (printSequencePropertyProvider.properties.value == "one_at_a_time")
|
||||||
|
{
|
||||||
|
return {"settable_per_meshgroup": true}
|
||||||
|
}
|
||||||
|
return {"settable_per_mesh": true}
|
||||||
|
}
|
||||||
|
exclude:
|
||||||
|
{
|
||||||
|
var excluded_settings = [ "support_mesh", "anti_overhang_mesh", "cutting_mesh", "infill_mesh" ]
|
||||||
|
|
||||||
|
if(current_mesh_type == "support_mesh")
|
||||||
|
{
|
||||||
|
excluded_settings = excluded_settings.concat(base.all_categories_except_support)
|
||||||
|
}
|
||||||
|
return excluded_settings
|
||||||
|
}
|
||||||
|
|
||||||
|
visibilityHandler: Cura.PerObjectSettingVisibilityHandler
|
||||||
|
{
|
||||||
|
selectedObjectId: UM.ActiveTool.properties.getValue("SelectedObjectId")
|
||||||
|
}
|
||||||
|
|
||||||
|
// For some reason the model object is updated after removing him from the memory and
|
||||||
|
// it happens only on Windows. For this reason, set the destroyed value manually.
|
||||||
|
Component.onDestruction: {
|
||||||
|
setDestroyed(true)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
delegate: Row
|
||||||
|
{
|
||||||
|
spacing: - UM.Theme.getSize("default_margin").width
|
||||||
|
Loader
|
||||||
|
{
|
||||||
|
id: settingLoader
|
||||||
|
width: UM.Theme.getSize("setting").width
|
||||||
|
height: UM.Theme.getSize("section").height
|
||||||
|
|
||||||
|
property var definition: model
|
||||||
|
property var settingDefinitionsModel: addedSettingsModel
|
||||||
|
property var propertyProvider: provider
|
||||||
|
property var globalPropertyProvider: inheritStackProvider
|
||||||
|
property var externalResetHandler: false
|
||||||
|
|
||||||
|
//Qt5.4.2 and earlier has a bug where this causes a crash: https://bugreports.qt.io/browse/QTBUG-35989
|
||||||
|
//In addition, while it works for 5.5 and higher, the ordering of the actual combo box drop down changes,
|
||||||
|
//causing nasty issues when selecting different options. So disable asynchronous loading of enum type completely.
|
||||||
|
asynchronous: model.type != "enum" && model.type != "extruder"
|
||||||
|
|
||||||
|
onLoaded: {
|
||||||
|
settingLoader.item.showRevertButton = false
|
||||||
|
settingLoader.item.showInheritButton = false
|
||||||
|
settingLoader.item.showLinkedSettingIcon = false
|
||||||
|
settingLoader.item.doDepthIndentation = false
|
||||||
|
settingLoader.item.doQualityUserSettingEmphasis = false
|
||||||
|
}
|
||||||
|
|
||||||
|
sourceComponent:
|
||||||
|
{
|
||||||
|
switch(model.type)
|
||||||
|
{
|
||||||
|
case "int":
|
||||||
|
return settingTextField
|
||||||
|
case "[int]":
|
||||||
|
return settingTextField
|
||||||
|
case "float":
|
||||||
|
return settingTextField
|
||||||
|
case "enum":
|
||||||
|
return settingComboBox
|
||||||
|
case "extruder":
|
||||||
|
return settingExtruder
|
||||||
|
case "optional_extruder":
|
||||||
|
return settingOptionalExtruder
|
||||||
|
case "bool":
|
||||||
|
return settingCheckBox
|
||||||
|
case "str":
|
||||||
|
return settingTextField
|
||||||
|
case "category":
|
||||||
|
return settingCategory
|
||||||
|
default:
|
||||||
|
return settingUnknown
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Button
|
||||||
|
{
|
||||||
|
width: Math.round(UM.Theme.getSize("setting").height / 2)
|
||||||
|
height: UM.Theme.getSize("setting").height
|
||||||
|
|
||||||
|
onClicked: addedSettingsModel.setVisible(model.key, false)
|
||||||
|
|
||||||
|
style: ButtonStyle
|
||||||
|
{
|
||||||
|
background: Item
|
||||||
|
{
|
||||||
|
UM.RecolorImage
|
||||||
|
{
|
||||||
|
anchors.verticalCenter: parent.verticalCenter
|
||||||
|
width: parent.width
|
||||||
|
height: width
|
||||||
|
sourceSize.height: width
|
||||||
|
color: control.hovered ? UM.Theme.getColor("setting_control_button_hover") : UM.Theme.getColor("setting_control_button")
|
||||||
|
source: UM.Theme.getIcon("minus")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Specialty provider that only watches global_inherits (we cant filter on what property changed we get events
|
||||||
|
// so we bypass that to make a dedicated provider).
|
||||||
|
UM.SettingPropertyProvider
|
||||||
|
{
|
||||||
|
id: provider
|
||||||
|
|
||||||
|
containerStackId: UM.ActiveTool.properties.getValue("ContainerID")
|
||||||
|
key: model.key
|
||||||
|
watchedProperties: [ "value", "enabled", "validationState" ]
|
||||||
|
storeIndex: 0
|
||||||
|
removeUnusedValue: false
|
||||||
|
}
|
||||||
|
|
||||||
|
UM.SettingPropertyProvider
|
||||||
|
{
|
||||||
|
id: inheritStackProvider
|
||||||
|
containerStackId: UM.ActiveTool.properties.getValue("ContainerID")
|
||||||
|
key: model.key
|
||||||
|
watchedProperties: [ "limit_to_extruder" ]
|
||||||
|
}
|
||||||
|
|
||||||
|
Connections
|
||||||
|
{
|
||||||
|
target: inheritStackProvider
|
||||||
|
onPropertiesChanged:
|
||||||
|
{
|
||||||
|
provider.forcePropertiesChanged()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Connections
|
||||||
|
{
|
||||||
|
target: UM.ActiveTool
|
||||||
|
onPropertiesChanged:
|
||||||
|
{
|
||||||
|
// the values cannot be bound with UM.ActiveTool.properties.getValue() calls,
|
||||||
|
// so here we connect to the signal and update the those values.
|
||||||
|
if (typeof UM.ActiveTool.properties.getValue("SelectedObjectId") !== "undefined")
|
||||||
|
{
|
||||||
|
const selectedObjectId = UM.ActiveTool.properties.getValue("SelectedObjectId")
|
||||||
|
if (addedSettingsModel.visibilityHandler.selectedObjectId != selectedObjectId)
|
||||||
|
{
|
||||||
|
addedSettingsModel.visibilityHandler.selectedObjectId = selectedObjectId
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (typeof UM.ActiveTool.properties.getValue("ContainerID") !== "undefined")
|
||||||
|
{
|
||||||
|
const containerId = UM.ActiveTool.properties.getValue("ContainerID")
|
||||||
|
if (provider.containerStackId != containerId)
|
||||||
|
{
|
||||||
|
provider.containerStackId = containerId
|
||||||
|
}
|
||||||
|
if (inheritStackProvider.containerStackId != containerId)
|
||||||
|
{
|
||||||
|
inheritStackProvider.containerStackId = containerId
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
Button
|
Button
|
||||||
{
|
{
|
||||||
id: customiseSettingsButton;
|
id: customiseSettingsButton;
|
||||||
|
@ -194,337 +396,137 @@ Item
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Column // Settings Dialog
|
UM.Dialog
|
||||||
{
|
{
|
||||||
// This is to ensure that the panel is first increasing in size up to 200 and then shows a scrollbar.
|
id: settingPickDialog
|
||||||
// It kinda looks ugly otherwise (big panel, no content on it)
|
|
||||||
id: currentSettings
|
title: catalog.i18nc("@title:window", "Select Settings to Customize for this model")
|
||||||
property int maximumHeight: 200 * screenScaleFactor
|
width: screenScaleFactor * 360
|
||||||
height: Math.min(contents.count * (UM.Theme.getSize("section").height + UM.Theme.getSize("default_lining").height), maximumHeight)
|
|
||||||
visible: current_mesh_type != "anti_overhang_mesh"
|
property var additional_excluded_settings
|
||||||
|
|
||||||
|
onVisibilityChanged:
|
||||||
|
{
|
||||||
|
// force updating the model to sync it with addedSettingsModel
|
||||||
|
if(visible)
|
||||||
|
{
|
||||||
|
// Set skip setting, it will prevent from resetting selected mesh_type
|
||||||
|
contents.model.visibilityHandler.addSkipResetSetting(current_mesh_type)
|
||||||
|
listview.model.forceUpdate()
|
||||||
|
|
||||||
|
updateFilter()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function updateFilter()
|
||||||
|
{
|
||||||
|
var new_filter = {}
|
||||||
|
new_filter["settable_per_mesh"] = true
|
||||||
|
// Don't filter on "settable_per_meshgroup" any more when `printSequencePropertyProvider.properties.value`
|
||||||
|
// is set to "one_at_a_time", because the current backend architecture isn't ready for that.
|
||||||
|
|
||||||
|
if(filterInput.text != "")
|
||||||
|
{
|
||||||
|
new_filter["i18n_label"] = "*" + filterInput.text
|
||||||
|
}
|
||||||
|
|
||||||
|
listview.model.filter = new_filter
|
||||||
|
}
|
||||||
|
|
||||||
|
TextField {
|
||||||
|
id: filterInput
|
||||||
|
|
||||||
|
anchors {
|
||||||
|
top: parent.top
|
||||||
|
left: parent.left
|
||||||
|
right: toggleShowAll.left
|
||||||
|
rightMargin: UM.Theme.getSize("default_margin").width
|
||||||
|
}
|
||||||
|
|
||||||
|
placeholderText: catalog.i18nc("@label:textbox", "Filter...")
|
||||||
|
|
||||||
|
onTextChanged: settingPickDialog.updateFilter()
|
||||||
|
}
|
||||||
|
|
||||||
|
CheckBox
|
||||||
|
{
|
||||||
|
id: toggleShowAll
|
||||||
|
|
||||||
|
anchors {
|
||||||
|
top: parent.top
|
||||||
|
right: parent.right
|
||||||
|
}
|
||||||
|
|
||||||
|
text: catalog.i18nc("@label:checkbox", "Show all")
|
||||||
|
checked: listview.model.showAll
|
||||||
|
onClicked:
|
||||||
|
{
|
||||||
|
listview.model.showAll = checked
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
ScrollView
|
ScrollView
|
||||||
{
|
{
|
||||||
height: parent.height
|
id: scrollView
|
||||||
width: UM.Theme.getSize("setting").width + UM.Theme.getSize("default_margin").width
|
|
||||||
style: UM.Theme.styles.scrollview
|
|
||||||
|
|
||||||
|
anchors
|
||||||
|
{
|
||||||
|
top: filterInput.bottom
|
||||||
|
left: parent.left
|
||||||
|
right: parent.right
|
||||||
|
bottom: parent.bottom
|
||||||
|
}
|
||||||
ListView
|
ListView
|
||||||
{
|
{
|
||||||
id: contents
|
id:listview
|
||||||
spacing: UM.Theme.getSize("default_lining").height
|
|
||||||
|
|
||||||
model: UM.SettingDefinitionsModel
|
model: UM.SettingDefinitionsModel
|
||||||
{
|
{
|
||||||
id: addedSettingsModel
|
id: definitionsModel
|
||||||
containerId: Cura.MachineManager.activeMachine != null ? Cura.MachineManager.activeMachine.definition.id: ""
|
containerId: Cura.MachineManager.activeMachine != null ? Cura.MachineManager.activeMachine.definition.id: ""
|
||||||
|
visibilityHandler: UM.SettingPreferenceVisibilityHandler {}
|
||||||
expanded: [ "*" ]
|
expanded: [ "*" ]
|
||||||
filter:
|
|
||||||
{
|
|
||||||
if (printSequencePropertyProvider.properties.value == "one_at_a_time")
|
|
||||||
{
|
|
||||||
return {"settable_per_meshgroup": true}
|
|
||||||
}
|
|
||||||
return {"settable_per_mesh": true}
|
|
||||||
}
|
|
||||||
exclude:
|
exclude:
|
||||||
{
|
{
|
||||||
var excluded_settings = [ "support_mesh", "anti_overhang_mesh", "cutting_mesh", "infill_mesh" ]
|
var excluded_settings = [ "machine_settings", "command_line_settings", "support_mesh", "anti_overhang_mesh", "cutting_mesh", "infill_mesh" ]
|
||||||
|
excluded_settings = excluded_settings.concat(settingPickDialog.additional_excluded_settings)
|
||||||
if(current_mesh_type == "support_mesh")
|
|
||||||
{
|
|
||||||
excluded_settings = excluded_settings.concat(base.all_categories_except_support)
|
|
||||||
}
|
|
||||||
return excluded_settings
|
return excluded_settings
|
||||||
}
|
}
|
||||||
|
|
||||||
visibilityHandler: Cura.PerObjectSettingVisibilityHandler
|
|
||||||
{
|
|
||||||
selectedObjectId: UM.ActiveTool.properties.getValue("SelectedObjectId")
|
|
||||||
}
|
|
||||||
|
|
||||||
// For some reason the model object is updated after removing him from the memory and
|
|
||||||
// it happens only on Windows. For this reason, set the destroyed value manually.
|
|
||||||
Component.onDestruction: {
|
|
||||||
setDestroyed(true)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
delegate:Loader
|
||||||
delegate: Row
|
|
||||||
{
|
{
|
||||||
spacing: - UM.Theme.getSize("default_margin").width
|
id: loader
|
||||||
Loader
|
|
||||||
|
width: parent.width
|
||||||
|
height: model.type != undefined ? UM.Theme.getSize("section").height : 0
|
||||||
|
|
||||||
|
property var definition: model
|
||||||
|
property var settingDefinitionsModel: definitionsModel
|
||||||
|
|
||||||
|
asynchronous: true
|
||||||
|
source:
|
||||||
{
|
{
|
||||||
id: settingLoader
|
switch(model.type)
|
||||||
width: UM.Theme.getSize("setting").width
|
|
||||||
height: UM.Theme.getSize("section").height
|
|
||||||
|
|
||||||
property var definition: model
|
|
||||||
property var settingDefinitionsModel: addedSettingsModel
|
|
||||||
property var propertyProvider: provider
|
|
||||||
property var globalPropertyProvider: inheritStackProvider
|
|
||||||
property var externalResetHandler: false
|
|
||||||
|
|
||||||
//Qt5.4.2 and earlier has a bug where this causes a crash: https://bugreports.qt.io/browse/QTBUG-35989
|
|
||||||
//In addition, while it works for 5.5 and higher, the ordering of the actual combo box drop down changes,
|
|
||||||
//causing nasty issues when selecting different options. So disable asynchronous loading of enum type completely.
|
|
||||||
asynchronous: model.type != "enum" && model.type != "extruder"
|
|
||||||
|
|
||||||
onLoaded: {
|
|
||||||
settingLoader.item.showRevertButton = false
|
|
||||||
settingLoader.item.showInheritButton = false
|
|
||||||
settingLoader.item.showLinkedSettingIcon = false
|
|
||||||
settingLoader.item.doDepthIndentation = false
|
|
||||||
settingLoader.item.doQualityUserSettingEmphasis = false
|
|
||||||
}
|
|
||||||
|
|
||||||
sourceComponent:
|
|
||||||
{
|
{
|
||||||
switch(model.type)
|
case "category":
|
||||||
{
|
return "PerObjectCategory.qml"
|
||||||
case "int":
|
default:
|
||||||
return settingTextField
|
return "PerObjectItem.qml"
|
||||||
case "[int]":
|
|
||||||
return settingTextField
|
|
||||||
case "float":
|
|
||||||
return settingTextField
|
|
||||||
case "enum":
|
|
||||||
return settingComboBox
|
|
||||||
case "extruder":
|
|
||||||
return settingExtruder
|
|
||||||
case "optional_extruder":
|
|
||||||
return settingOptionalExtruder
|
|
||||||
case "bool":
|
|
||||||
return settingCheckBox
|
|
||||||
case "str":
|
|
||||||
return settingTextField
|
|
||||||
case "category":
|
|
||||||
return settingCategory
|
|
||||||
default:
|
|
||||||
return settingUnknown
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Button
|
|
||||||
{
|
|
||||||
width: Math.round(UM.Theme.getSize("setting").height / 2)
|
|
||||||
height: UM.Theme.getSize("setting").height
|
|
||||||
|
|
||||||
onClicked: addedSettingsModel.setVisible(model.key, false)
|
|
||||||
|
|
||||||
style: ButtonStyle
|
|
||||||
{
|
|
||||||
background: Item
|
|
||||||
{
|
|
||||||
UM.RecolorImage
|
|
||||||
{
|
|
||||||
anchors.verticalCenter: parent.verticalCenter
|
|
||||||
width: parent.width
|
|
||||||
height: width
|
|
||||||
sourceSize.height: width
|
|
||||||
color: control.hovered ? UM.Theme.getColor("setting_control_button_hover") : UM.Theme.getColor("setting_control_button")
|
|
||||||
source: UM.Theme.getIcon("minus")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Specialty provider that only watches global_inherits (we cant filter on what property changed we get events
|
|
||||||
// so we bypass that to make a dedicated provider).
|
|
||||||
UM.SettingPropertyProvider
|
|
||||||
{
|
|
||||||
id: provider
|
|
||||||
|
|
||||||
containerStackId: UM.ActiveTool.properties.getValue("ContainerID")
|
|
||||||
key: model.key
|
|
||||||
watchedProperties: [ "value", "enabled", "validationState" ]
|
|
||||||
storeIndex: 0
|
|
||||||
removeUnusedValue: false
|
|
||||||
}
|
|
||||||
|
|
||||||
UM.SettingPropertyProvider
|
|
||||||
{
|
|
||||||
id: inheritStackProvider
|
|
||||||
containerStackId: UM.ActiveTool.properties.getValue("ContainerID")
|
|
||||||
key: model.key
|
|
||||||
watchedProperties: [ "limit_to_extruder" ]
|
|
||||||
}
|
|
||||||
|
|
||||||
Connections
|
|
||||||
{
|
|
||||||
target: inheritStackProvider
|
|
||||||
onPropertiesChanged:
|
|
||||||
{
|
|
||||||
provider.forcePropertiesChanged()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Connections
|
|
||||||
{
|
|
||||||
target: UM.ActiveTool
|
|
||||||
onPropertiesChanged:
|
|
||||||
{
|
|
||||||
// the values cannot be bound with UM.ActiveTool.properties.getValue() calls,
|
|
||||||
// so here we connect to the signal and update the those values.
|
|
||||||
if (typeof UM.ActiveTool.properties.getValue("SelectedObjectId") !== "undefined")
|
|
||||||
{
|
|
||||||
const selectedObjectId = UM.ActiveTool.properties.getValue("SelectedObjectId")
|
|
||||||
if (addedSettingsModel.visibilityHandler.selectedObjectId != selectedObjectId)
|
|
||||||
{
|
|
||||||
addedSettingsModel.visibilityHandler.selectedObjectId = selectedObjectId
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (typeof UM.ActiveTool.properties.getValue("ContainerID") !== "undefined")
|
|
||||||
{
|
|
||||||
const containerId = UM.ActiveTool.properties.getValue("ContainerID")
|
|
||||||
if (provider.containerStackId != containerId)
|
|
||||||
{
|
|
||||||
provider.containerStackId = containerId
|
|
||||||
}
|
|
||||||
if (inheritStackProvider.containerStackId != containerId)
|
|
||||||
{
|
|
||||||
inheritStackProvider.containerStackId = containerId
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
Component.onCompleted: settingPickDialog.updateFilter()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
UM.Dialog
|
rightButtons: [
|
||||||
{
|
Button {
|
||||||
id: settingPickDialog
|
text: catalog.i18nc("@action:button", "Close")
|
||||||
|
onClicked: {
|
||||||
title: catalog.i18nc("@title:window", "Select Settings to Customize for this model")
|
settingPickDialog.visible = false
|
||||||
width: screenScaleFactor * 360
|
|
||||||
|
|
||||||
property var additional_excluded_settings
|
|
||||||
|
|
||||||
onVisibilityChanged:
|
|
||||||
{
|
|
||||||
// force updating the model to sync it with addedSettingsModel
|
|
||||||
if(visible)
|
|
||||||
{
|
|
||||||
// Set skip setting, it will prevent from resetting selected mesh_type
|
|
||||||
contents.model.visibilityHandler.addSkipResetSetting(current_mesh_type)
|
|
||||||
listview.model.forceUpdate()
|
|
||||||
|
|
||||||
updateFilter()
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
]
|
||||||
function updateFilter()
|
}
|
||||||
{
|
|
||||||
var new_filter = {}
|
|
||||||
new_filter["settable_per_mesh"] = true
|
|
||||||
// Don't filter on "settable_per_meshgroup" any more when `printSequencePropertyProvider.properties.value`
|
|
||||||
// is set to "one_at_a_time", because the current backend architecture isn't ready for that.
|
|
||||||
|
|
||||||
if(filterInput.text != "")
|
|
||||||
{
|
|
||||||
new_filter["i18n_label"] = "*" + filterInput.text
|
|
||||||
}
|
|
||||||
|
|
||||||
listview.model.filter = new_filter
|
|
||||||
}
|
|
||||||
|
|
||||||
TextField {
|
|
||||||
id: filterInput
|
|
||||||
|
|
||||||
anchors {
|
|
||||||
top: parent.top
|
|
||||||
left: parent.left
|
|
||||||
right: toggleShowAll.left
|
|
||||||
rightMargin: UM.Theme.getSize("default_margin").width
|
|
||||||
}
|
|
||||||
|
|
||||||
placeholderText: catalog.i18nc("@label:textbox", "Filter...")
|
|
||||||
|
|
||||||
onTextChanged: settingPickDialog.updateFilter()
|
|
||||||
}
|
|
||||||
|
|
||||||
CheckBox
|
|
||||||
{
|
|
||||||
id: toggleShowAll
|
|
||||||
|
|
||||||
anchors {
|
|
||||||
top: parent.top
|
|
||||||
right: parent.right
|
|
||||||
}
|
|
||||||
|
|
||||||
text: catalog.i18nc("@label:checkbox", "Show all")
|
|
||||||
checked: listview.model.showAll
|
|
||||||
onClicked:
|
|
||||||
{
|
|
||||||
listview.model.showAll = checked
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
ScrollView
|
|
||||||
{
|
|
||||||
id: scrollView
|
|
||||||
|
|
||||||
anchors
|
|
||||||
{
|
|
||||||
top: filterInput.bottom
|
|
||||||
left: parent.left
|
|
||||||
right: parent.right
|
|
||||||
bottom: parent.bottom
|
|
||||||
}
|
|
||||||
ListView
|
|
||||||
{
|
|
||||||
id:listview
|
|
||||||
model: UM.SettingDefinitionsModel
|
|
||||||
{
|
|
||||||
id: definitionsModel
|
|
||||||
containerId: Cura.MachineManager.activeMachine != null ? Cura.MachineManager.activeMachine.definition.id: ""
|
|
||||||
visibilityHandler: UM.SettingPreferenceVisibilityHandler {}
|
|
||||||
expanded: [ "*" ]
|
|
||||||
exclude:
|
|
||||||
{
|
|
||||||
var excluded_settings = [ "machine_settings", "command_line_settings", "support_mesh", "anti_overhang_mesh", "cutting_mesh", "infill_mesh" ]
|
|
||||||
excluded_settings = excluded_settings.concat(settingPickDialog.additional_excluded_settings)
|
|
||||||
return excluded_settings
|
|
||||||
}
|
|
||||||
}
|
|
||||||
delegate:Loader
|
|
||||||
{
|
|
||||||
id: loader
|
|
||||||
|
|
||||||
width: parent.width
|
|
||||||
height: model.type != undefined ? UM.Theme.getSize("section").height : 0
|
|
||||||
|
|
||||||
property var definition: model
|
|
||||||
property var settingDefinitionsModel: definitionsModel
|
|
||||||
|
|
||||||
asynchronous: true
|
|
||||||
source:
|
|
||||||
{
|
|
||||||
switch(model.type)
|
|
||||||
{
|
|
||||||
case "category":
|
|
||||||
return "PerObjectCategory.qml"
|
|
||||||
default:
|
|
||||||
return "PerObjectItem.qml"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Component.onCompleted: settingPickDialog.updateFilter()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
rightButtons: [
|
|
||||||
Button {
|
|
||||||
text: catalog.i18nc("@action:button", "Close")
|
|
||||||
onClicked: {
|
|
||||||
settingPickDialog.visible = false
|
|
||||||
}
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
|
|
||||||
UM.SettingPropertyProvider
|
UM.SettingPropertyProvider
|
||||||
{
|
{
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue