Augment fields in content list item
This commit is contained in:
parent
251c05abad
commit
599344e4be
|
|
@ -107,7 +107,7 @@
|
||||||
{
|
{
|
||||||
text_block,
|
text_block,
|
||||||
content_list_item: [contents...],
|
content_list_item: [contents...],
|
||||||
contentlist_item: [contents...],
|
content_list_item: [contents...],
|
||||||
text_block
|
text_block
|
||||||
} becomes
|
} becomes
|
||||||
{
|
{
|
||||||
|
|
|
||||||
|
|
@ -18,59 +18,67 @@ class GenericStreamFieldType(Scalar):
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def serialize(stream_value):
|
def serialize(stream_value):
|
||||||
stream_data = stream_value.stream_data
|
stream_data = stream_value.stream_data
|
||||||
|
return augment_fields(stream_data)
|
||||||
for d in stream_data:
|
|
||||||
if isinstance(d, dict):
|
|
||||||
_type = d['type']
|
|
||||||
if _type == 'image_block':
|
|
||||||
_value = d['value']
|
|
||||||
value = {
|
|
||||||
# 'value': _value,
|
|
||||||
# 'id': d['id'],
|
|
||||||
'path': Image.objects.get(id=_value).file.url
|
|
||||||
}
|
|
||||||
d['value'] = value
|
|
||||||
if _type == 'assignment':
|
|
||||||
_value = d['value']
|
|
||||||
assignment_id = _value['assignment_id']
|
|
||||||
try:
|
|
||||||
assignment = Assignment.objects.get(pk=assignment_id)
|
|
||||||
value = {
|
|
||||||
'title': assignment.title,
|
|
||||||
'assignment': assignment.assignment,
|
|
||||||
'id': to_global_id('AssignmentNode', assignment.pk)
|
|
||||||
}
|
|
||||||
d['value'] = value
|
|
||||||
except Assignment.DoesNotExist:
|
|
||||||
logger.error('Assignment {} does not exist'.format(assignment_id))
|
|
||||||
if _type == 'basic_knowledge' or _type == 'instrument':
|
|
||||||
_value = d['value']
|
|
||||||
basic_knowledge = BasicKnowledge.objects.get(pk=_value['basic_knowledge'])
|
|
||||||
_value.update({
|
|
||||||
'slug': basic_knowledge.slug
|
|
||||||
})
|
|
||||||
d['value'] = _value
|
|
||||||
|
|
||||||
# value = dict(d['value'])
|
|
||||||
# if 'document' in value:
|
|
||||||
# value['document'] = Document.objects.get(id=value['document']).file.url
|
|
||||||
# if 'image' in value:
|
|
||||||
# value['image'] = Image.objects.get(id=value['image']).file.url
|
|
||||||
|
|
||||||
# else:
|
|
||||||
# _type = d[0]
|
|
||||||
# value = dict(d[1])
|
|
||||||
# if 'document' in value:
|
|
||||||
# value['document'] = value['document'].file.url
|
|
||||||
# if 'image' in value:
|
|
||||||
# value['image'] = value['image'].file.url
|
|
||||||
|
|
||||||
return stream_data
|
|
||||||
|
|
||||||
# by_api = stream_value.stream_block.get_api_representation(stream_value)
|
# by_api = stream_value.stream_block.get_api_representation(stream_value)
|
||||||
# return by_api
|
# return by_api
|
||||||
|
|
||||||
|
|
||||||
|
def augment_fields(stream_data):
|
||||||
|
for data in stream_data:
|
||||||
|
if isinstance(data, dict):
|
||||||
|
_type = data['type']
|
||||||
|
if _type == 'image_block':
|
||||||
|
_value = data['value']
|
||||||
|
value = {
|
||||||
|
# 'value': _value,
|
||||||
|
# 'id': d['id'],
|
||||||
|
'path': Image.objects.get(id=_value).file.url
|
||||||
|
}
|
||||||
|
data['value'] = value
|
||||||
|
if _type == 'assignment':
|
||||||
|
_value = data['value']
|
||||||
|
assignment_id = _value['assignment_id']
|
||||||
|
try:
|
||||||
|
assignment = Assignment.objects.get(pk=assignment_id)
|
||||||
|
value = {
|
||||||
|
'title': assignment.title,
|
||||||
|
'assignment': assignment.assignment,
|
||||||
|
'id': to_global_id('AssignmentNode', assignment.pk)
|
||||||
|
}
|
||||||
|
data['value'] = value
|
||||||
|
except Assignment.DoesNotExist:
|
||||||
|
logger.error('Assignment {} does not exist'.format(assignment_id))
|
||||||
|
if _type == 'basic_knowledge' or _type == 'instrument':
|
||||||
|
_value = data['value']
|
||||||
|
basic_knowledge = BasicKnowledge.objects.get(pk=_value['basic_knowledge'])
|
||||||
|
_value.update({
|
||||||
|
'slug': basic_knowledge.slug
|
||||||
|
})
|
||||||
|
data['value'] = _value
|
||||||
|
|
||||||
|
# value = dict(d['value'])
|
||||||
|
# if 'document' in value:
|
||||||
|
# value['document'] = Document.objects.get(id=value['document']).file.url
|
||||||
|
# if 'image' in value:
|
||||||
|
# value['image'] = Image.objects.get(id=value['image']).file.url
|
||||||
|
|
||||||
|
# else:
|
||||||
|
# _type = d[0]
|
||||||
|
# value = dict(d[1])
|
||||||
|
# if 'document' in value:
|
||||||
|
# value['document'] = value['document'].file.url
|
||||||
|
# if 'image' in value:
|
||||||
|
# value['image'] = value['image'].file.url
|
||||||
|
|
||||||
|
if _type == 'content_list_item':
|
||||||
|
item_data = data['value']
|
||||||
|
data['value'] = augment_fields(item_data)
|
||||||
|
|
||||||
|
return stream_data
|
||||||
|
|
||||||
|
|
||||||
@convert_django_field.register(StreamField)
|
@convert_django_field.register(StreamField)
|
||||||
def convert_stream_field(field, registry=None):
|
def convert_stream_field(field, registry=None):
|
||||||
return GenericStreamFieldType(description=field.help_text, required=not field.null)
|
return GenericStreamFieldType(description=field.help_text, required=not field.null)
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue