mirror of
https://github.com/Ultimaker/Cura.git
synced 2025-07-13 09:47:50 -06:00
Fix models using new MaterialNode class
The new one doesn't have getMetadata. Maybe we should allow it to have that actually. Contributes to issue CURA-6600.
This commit is contained in:
parent
54b46abd0f
commit
7d1f8e981b
3 changed files with 10 additions and 14 deletions
|
@ -1,18 +1,18 @@
|
||||||
# Copyright (c) 2018 Ultimaker B.V.
|
# Copyright (c) 2019 Ultimaker B.V.
|
||||||
# Cura is released under the terms of the LGPLv3 or higher.
|
# Cura is released under the terms of the LGPLv3 or higher.
|
||||||
|
|
||||||
from typing import Optional, Dict, Set
|
from typing import Optional, Dict, Set
|
||||||
|
|
||||||
from PyQt5.QtCore import Qt, pyqtSignal, pyqtProperty
|
from PyQt5.QtCore import Qt, pyqtSignal, pyqtProperty
|
||||||
from UM.Qt.ListModel import ListModel
|
from UM.Qt.ListModel import ListModel
|
||||||
|
|
||||||
|
from cura.Machines.MaterialNode import MaterialNode
|
||||||
|
from cura.Settings.CuraContainerRegistry import CuraContainerRegistry
|
||||||
|
|
||||||
## This is the base model class for GenericMaterialsModel and MaterialBrandsModel.
|
## This is the base model class for GenericMaterialsModel and MaterialBrandsModel.
|
||||||
# Those 2 models are used by the material drop down menu to show generic materials and branded materials separately.
|
# Those 2 models are used by the material drop down menu to show generic materials and branded materials separately.
|
||||||
# The extruder position defined here is being used to bound a menu to the correct extruder. This is used in the top
|
# The extruder position defined here is being used to bound a menu to the correct extruder. This is used in the top
|
||||||
# bar menu "Settings" -> "Extruder nr" -> "Material" -> this menu
|
# bar menu "Settings" -> "Extruder nr" -> "Material" -> this menu
|
||||||
from cura.Machines.MaterialNode import MaterialNode
|
|
||||||
|
|
||||||
|
|
||||||
class BaseMaterialsModel(ListModel):
|
class BaseMaterialsModel(ListModel):
|
||||||
|
|
||||||
extruderPositionChanged = pyqtSignal()
|
extruderPositionChanged = pyqtSignal()
|
||||||
|
@ -128,7 +128,7 @@ class BaseMaterialsModel(ListModel):
|
||||||
## This is another convenience function which is shared by all material
|
## This is another convenience function which is shared by all material
|
||||||
# models so it's put here to avoid having so much duplicated code.
|
# models so it's put here to avoid having so much duplicated code.
|
||||||
def _createMaterialItem(self, root_material_id, container_node):
|
def _createMaterialItem(self, root_material_id, container_node):
|
||||||
metadata = container_node.getMetadata()
|
metadata = CuraContainerRegistry.getInstance().findContainersMetadata(id = container_node.container_id)[0]
|
||||||
item = {
|
item = {
|
||||||
"root_material_id": root_material_id,
|
"root_material_id": root_material_id,
|
||||||
"id": metadata["id"],
|
"id": metadata["id"],
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
# Copyright (c) 2018 Ultimaker B.V.
|
# Copyright (c) 2019 Ultimaker B.V.
|
||||||
# Cura is released under the terms of the LGPLv3 or higher.
|
# Cura is released under the terms of the LGPLv3 or higher.
|
||||||
|
|
||||||
from cura.Machines.Models.BaseMaterialsModel import BaseMaterialsModel
|
from cura.Machines.Models.BaseMaterialsModel import BaseMaterialsModel
|
||||||
|
@ -19,10 +19,8 @@ class FavoriteMaterialsModel(BaseMaterialsModel):
|
||||||
item_list = []
|
item_list = []
|
||||||
|
|
||||||
for root_material_id, container_node in self._available_materials.items():
|
for root_material_id, container_node in self._available_materials.items():
|
||||||
metadata = container_node.getMetadata()
|
|
||||||
|
|
||||||
# Do not include the materials from a to-be-removed package
|
# Do not include the materials from a to-be-removed package
|
||||||
if bool(metadata.get("removed", False)):
|
if bool(container_node.getMetaDataEntry("removed", False)):
|
||||||
continue
|
continue
|
||||||
|
|
||||||
# Only add results for favorite materials
|
# Only add results for favorite materials
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
# Copyright (c) 2018 Ultimaker B.V.
|
# Copyright (c) 2019 Ultimaker B.V.
|
||||||
# Cura is released under the terms of the LGPLv3 or higher.
|
# Cura is released under the terms of the LGPLv3 or higher.
|
||||||
|
|
||||||
from cura.Machines.Models.BaseMaterialsModel import BaseMaterialsModel
|
from cura.Machines.Models.BaseMaterialsModel import BaseMaterialsModel
|
||||||
|
@ -19,14 +19,12 @@ class GenericMaterialsModel(BaseMaterialsModel):
|
||||||
item_list = []
|
item_list = []
|
||||||
|
|
||||||
for root_material_id, container_node in self._available_materials.items():
|
for root_material_id, container_node in self._available_materials.items():
|
||||||
metadata = container_node.getMetadata()
|
|
||||||
|
|
||||||
# Do not include the materials from a to-be-removed package
|
# Do not include the materials from a to-be-removed package
|
||||||
if bool(metadata.get("removed", False)):
|
if bool(container_node.getMetaDataEntry("removed", False)):
|
||||||
continue
|
continue
|
||||||
|
|
||||||
# Only add results for generic materials
|
# Only add results for generic materials
|
||||||
if metadata["brand"].lower() != "generic":
|
if container_node.getMetaDataEntry("brand").lower() != "generic":
|
||||||
continue
|
continue
|
||||||
|
|
||||||
item = self._createMaterialItem(root_material_id, container_node)
|
item = self._createMaterialItem(root_material_id, container_node)
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue