Source code for spinetoolbox.spine_db_editor.mvcmodels.metadata_table_model
######################################################################################################################
# Copyright (C) 2017-2022 Spine project consortium
# Copyright Spine Toolbox contributors
# This file is part of Spine Toolbox.
# Spine Toolbox is free software: you can redistribute it and/or modify it under the terms of the GNU Lesser General
# Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option)
# any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
# without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General
# Public License for more details. You should have received a copy of the GNU Lesser General Public License along with
# this program. If not, see <http://www.gnu.org/licenses/>.
######################################################################################################################
"""Contains :class:`MetadataTableModel` and associated functionality."""
from enum import IntEnum, unique
from spinetoolbox.fetch_parent import FlexibleFetchParent
from .metadata_table_model_base import Column, FLAGS_FIXED, FLAGS_EDITABLE, MetadataTableModelBase
@unique
[docs]class MetadataTableModel(MetadataTableModelBase):
"""Model for metadata."""
def __init__(self, db_mngr, db_maps, db_editor):
"""
Args:
db_mngr (SpineDBManager): database manager
db_maps (Iterable of DatabaseMapping): database maps
db_editor (SpineDBEditor): DB editor
"""
super().__init__(db_mngr, db_maps, db_editor)
self._metadata_fetch_parent = FlexibleFetchParent(
"metadata",
handle_items_added=self.add_metadata,
handle_items_removed=self.remove_metadata,
handle_items_updated=self.update_metadata,
owner=self,
)
@staticmethod
[docs] def _add_data_to_db_mngr(self, name, value, db_map):
"""See base class."""
self._db_mngr.add_metadata({db_map: [{"name": name, "value": value}]})
[docs] def _update_data_in_db_mngr(self, id_, name, value, db_map):
"""See base class"""
self._db_mngr.update_metadata({db_map: [{"id": id_, "name": name, "value": value}]})
[docs] def flags(self, index):
row = index.row()
column = index.column()
if column == Column.DB_MAP and row < len(self._data) and self._data[row][ExtraColumn.ID] is not None:
return FLAGS_FIXED
return FLAGS_EDITABLE
@staticmethod
@staticmethod
[docs] def add_metadata(self, db_map_data):
"""Adds new metadata from database manager to the model.
Args:
db_map_data (dict): added metadata items keyed by database mapping
"""
self._add_data(db_map_data)
[docs] def update_metadata(self, db_map_data):
"""Updates model according to data received from database manager.
Args:
db_map_data (dict): updated metadata items keyed by database mapping
"""
self._update_data(db_map_data, ExtraColumn.ID)
[docs] def remove_metadata(self, db_map_data):
"""Removes metadata from model after it has been removed from databases.
Args:
db_map_data (dict): removed items keyed by database mapping
"""
self._remove_data(db_map_data, ExtraColumn.ID)