Source code for web.tables.account_tables.BaseAccountTable

# SPDX-License-Identifier: AGPL-3.0-or-later
#
# Eonvelope - a open-source self-hostable email archiving server
# Copyright (C) 2024 David Aderbauer & The Eonvelope Contributors
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero 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 Affero General Public License for more details.
#
# You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <https://www.gnu.org/licenses/>.

"""Module with the :class:`web.tables.BaseAccountTable` table class."""

from django_tables2 import Column, Table

from core.models import Account
from web.utils.columns import CheckboxColumn, IsFavoriteColumn, IsHealthyColumn


[docs] class BaseAccountTable(Table): """Table class for :class:`core.models.Account.Account`.""" checkbox = CheckboxColumn() is_favorite = IsFavoriteColumn() is_healthy = IsHealthyColumn() mail_address = Column(linkify=True)
[docs] class Meta: """Metadata class for the table.""" model = Account fields = ( "is_favorite", "mail_address", "mail_host", "mail_host_port", "protocol", "timeout", "allow_insecure_connection", "is_healthy", ) sequence = ("checkbox", *fields)
[docs] def render_mail_address(self, record: Account) -> str: """Render the complete mail address instead of the pure username field.""" return record.complete_mail_address