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 ExtraColumn(IntEnum): """Identifiers for hidden table columns."""
[docs] ID = Column.max() + 1
[docs]class MetadataTableModel(MetadataTableModelBase): """Model for metadata."""
[docs] _ITEM_NAME_KEY = "name"
[docs] _ITEM_VALUE_KEY = "value"
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 _make_hidden_adder_columns(): """See base class.""" return [None]
[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 _database_table_name(self): """See base class""" return "metadata"
[docs] def _row_id(self, row): """See base class.""" return row[ExtraColumn.ID]
[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
[docs] def _fetch_parents(self): yield self._metadata_fetch_parent
@staticmethod
[docs] def _ids_from_added_item(item): """See base class.""" return item["id"]
@staticmethod
[docs] def _extra_cells_from_added_item(item): """See base class.""" return [item["id"]]
[docs] def _set_extra_columns(self, row, ids): """See base class.""" row[ExtraColumn.ID] = ids
[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)