mirror of
https://github.com/inventree/InvenTree.git
synced 2025-04-29 12:06:44 +00:00
* Fix docstring for NotificationMessage class * Fix for 'refresh' button in notification table * Simplify API for marking notifications as 'read' - Simply update the detail serializer - No requirement for extra API endpoints - Same updates for news feed entry - Hide 'read' news on the home page - Add ability to mark news items as read via table * Bug fix for build.js * Fix for part category template
225 lines
6.0 KiB
Python
225 lines
6.0 KiB
Python
"""JSON serializers for common components."""
|
|
|
|
from django.urls import reverse
|
|
|
|
from rest_framework import serializers
|
|
|
|
from common.models import (InvenTreeSetting, InvenTreeUserSetting,
|
|
NewsFeedEntry, NotificationMessage)
|
|
from InvenTree.helpers import construct_absolute_url, get_objectreference
|
|
from InvenTree.serializers import InvenTreeModelSerializer
|
|
|
|
|
|
class SettingsSerializer(InvenTreeModelSerializer):
|
|
"""Base serializer for a settings object."""
|
|
|
|
key = serializers.CharField(read_only=True)
|
|
|
|
name = serializers.CharField(read_only=True)
|
|
|
|
description = serializers.CharField(read_only=True)
|
|
|
|
type = serializers.CharField(source='setting_type', read_only=True)
|
|
|
|
choices = serializers.SerializerMethodField()
|
|
|
|
model_name = serializers.CharField(read_only=True)
|
|
|
|
api_url = serializers.CharField(read_only=True)
|
|
|
|
def get_choices(self, obj):
|
|
"""Returns the choices available for a given item."""
|
|
results = []
|
|
|
|
choices = obj.choices()
|
|
|
|
if choices:
|
|
for choice in choices:
|
|
results.append({
|
|
'value': choice[0],
|
|
'display_name': choice[1],
|
|
})
|
|
|
|
return results
|
|
|
|
def get_value(self, obj):
|
|
"""Make sure protected values are not returned."""
|
|
# never return protected values
|
|
if obj.protected:
|
|
result = '***'
|
|
else:
|
|
result = obj.value
|
|
|
|
return result
|
|
|
|
|
|
class GlobalSettingsSerializer(SettingsSerializer):
|
|
"""Serializer for the InvenTreeSetting model."""
|
|
|
|
class Meta:
|
|
"""Meta options for GlobalSettingsSerializer."""
|
|
|
|
model = InvenTreeSetting
|
|
fields = [
|
|
'pk',
|
|
'key',
|
|
'value',
|
|
'name',
|
|
'description',
|
|
'type',
|
|
'choices',
|
|
'model_name',
|
|
'api_url',
|
|
'typ',
|
|
]
|
|
|
|
|
|
class UserSettingsSerializer(SettingsSerializer):
|
|
"""Serializer for the InvenTreeUserSetting model."""
|
|
|
|
user = serializers.PrimaryKeyRelatedField(read_only=True)
|
|
|
|
class Meta:
|
|
"""Meta options for UserSettingsSerializer."""
|
|
|
|
model = InvenTreeUserSetting
|
|
fields = [
|
|
'pk',
|
|
'key',
|
|
'value',
|
|
'name',
|
|
'description',
|
|
'user',
|
|
'type',
|
|
'choices',
|
|
'model_name',
|
|
'api_url',
|
|
'typ',
|
|
]
|
|
|
|
|
|
class GenericReferencedSettingSerializer(SettingsSerializer):
|
|
"""Serializer for a GenericReferencedSetting model.
|
|
|
|
Args:
|
|
MODEL: model class for the serializer
|
|
EXTRA_FIELDS: fields that need to be appended to the serializer
|
|
field must also be defined in the custom class
|
|
"""
|
|
|
|
MODEL = None
|
|
EXTRA_FIELDS = None
|
|
|
|
def __init__(self, *args, **kwargs):
|
|
"""Init overrides the Meta class to make it dynamic."""
|
|
class CustomMeta:
|
|
"""Scaffold for custom Meta class."""
|
|
fields = [
|
|
'pk',
|
|
'key',
|
|
'value',
|
|
'name',
|
|
'description',
|
|
'type',
|
|
'choices',
|
|
'model_name',
|
|
'api_url',
|
|
'typ',
|
|
]
|
|
|
|
# set Meta class
|
|
self.Meta = CustomMeta
|
|
self.Meta.model = self.MODEL
|
|
# extend the fields
|
|
self.Meta.fields.extend(self.EXTRA_FIELDS)
|
|
|
|
# resume operations
|
|
super().__init__(*args, **kwargs)
|
|
|
|
|
|
class NotificationMessageSerializer(InvenTreeModelSerializer):
|
|
"""Serializer for the InvenTreeUserSetting model."""
|
|
|
|
target = serializers.SerializerMethodField(read_only=True)
|
|
|
|
source = serializers.SerializerMethodField(read_only=True)
|
|
|
|
user = serializers.PrimaryKeyRelatedField(read_only=True)
|
|
|
|
category = serializers.CharField(read_only=True)
|
|
|
|
name = serializers.CharField(read_only=True)
|
|
|
|
message = serializers.CharField(read_only=True)
|
|
|
|
creation = serializers.CharField(read_only=True)
|
|
|
|
age = serializers.IntegerField(read_only=True)
|
|
|
|
age_human = serializers.CharField(read_only=True)
|
|
|
|
read = serializers.BooleanField()
|
|
|
|
def get_target(self, obj):
|
|
"""Function to resolve generic object reference to target."""
|
|
target = get_objectreference(obj, 'target_content_type', 'target_object_id')
|
|
|
|
if target and 'link' not in target:
|
|
# Check if object has an absolute_url function
|
|
if hasattr(obj.target_object, 'get_absolute_url'):
|
|
target['link'] = obj.target_object.get_absolute_url()
|
|
else:
|
|
# check if user is staff - link to admin
|
|
request = self.context['request']
|
|
if request.user and request.user.is_staff:
|
|
meta = obj.target_object._meta
|
|
target['link'] = construct_absolute_url(reverse(
|
|
f'admin:{meta.db_table}_change',
|
|
kwargs={'object_id': obj.target_object_id}
|
|
))
|
|
|
|
return target
|
|
|
|
def get_source(self, obj):
|
|
"""Function to resolve generic object reference to source."""
|
|
return get_objectreference(obj, 'source_content_type', 'source_object_id')
|
|
|
|
class Meta:
|
|
"""Meta options for NotificationMessageSerializer."""
|
|
|
|
model = NotificationMessage
|
|
fields = [
|
|
'pk',
|
|
'target',
|
|
'source',
|
|
'user',
|
|
'category',
|
|
'name',
|
|
'message',
|
|
'creation',
|
|
'age',
|
|
'age_human',
|
|
'read',
|
|
]
|
|
|
|
|
|
class NewsFeedEntrySerializer(InvenTreeModelSerializer):
|
|
"""Serializer for the NewsFeedEntry model."""
|
|
|
|
read = serializers.BooleanField()
|
|
|
|
class Meta:
|
|
"""Meta options for NewsFeedEntrySerializer."""
|
|
|
|
model = NewsFeedEntry
|
|
fields = [
|
|
'pk',
|
|
'feed_id',
|
|
'title',
|
|
'link',
|
|
'published',
|
|
'author',
|
|
'summary',
|
|
'read',
|
|
]
|