mirror of
https://codeberg.org/rimu/pyfedi
synced 2025-01-23 19:36:56 -08:00
Use 'Image' type in attachment for image posts so alt-text is in same place as Lemmy #102
This commit is contained in:
parent
1af76320b7
commit
d255f676c8
3 changed files with 12 additions and 14 deletions
|
@ -190,8 +190,10 @@ def post_to_page(post: Post):
|
|||
activity_data["attachment"] = [{"href": post.url, "type": "Link"}]
|
||||
if post.image_id is not None:
|
||||
activity_data["image"] = {"url": post.image.view_url(), "type": "Image"}
|
||||
if post.image.alt_text:
|
||||
activity_data["image"]['altText'] = post.image.alt_text
|
||||
if post.type == POST_TYPE_IMAGE:
|
||||
activity_data['attachment'] = [{'type': 'Image',
|
||||
'url': post.image.source_url,
|
||||
'name': post.image.alt_text}]
|
||||
if post.type == POST_TYPE_POLL:
|
||||
poll = Poll.query.filter_by(post_id=post.id).first()
|
||||
activity_data['type'] = 'Question'
|
||||
|
|
|
@ -696,8 +696,9 @@ def federate_post(community, post):
|
|||
# NB image is a dict while attachment is a list of dicts (usually just one dict in the list)
|
||||
page['image'] = {'type': 'Image', 'url': image_url}
|
||||
if post.type == POST_TYPE_IMAGE:
|
||||
page['attachment'] = [{'type': 'Link',
|
||||
'href': post.image.source_url}] # source_url is always a https link, no need for .replace() as done above
|
||||
page['attachment'] = [{'type': 'Image',
|
||||
'url': post.image.source_url, # source_url is always a https link, no need for .replace() as done above
|
||||
'name': post.image.alt_text}]
|
||||
|
||||
if post.type == POST_TYPE_POLL:
|
||||
poll = Poll.query.filter_by(post_id=post.id).first()
|
||||
|
@ -801,10 +802,7 @@ def federate_post_to_user_followers(post):
|
|||
elif post.type == POST_TYPE_IMAGE:
|
||||
note['content'] = '<p>' + post.title + '</p>'
|
||||
if post.image_id and post.image.source_url:
|
||||
if post.image.alt_text:
|
||||
note['attachment'] = [{'type': 'Document', 'url': post.image.source_url, 'name': post.image.alt_text}]
|
||||
else:
|
||||
note['attachment'] = [{'type': 'Document', 'url': post.image.source_url}]
|
||||
note['attachment'] = [{'type': 'Image', 'url': post.image.source_url, 'name': post.image.alt_text}]
|
||||
|
||||
if post.body_html:
|
||||
note['content'] = note['content'] + '<p>' + post.body_html + '</p>'
|
||||
|
|
|
@ -1055,8 +1055,9 @@ def federate_post_update(post):
|
|||
# NB image is a dict while attachment is a list of dicts (usually just one dict in the list)
|
||||
page_json['image'] = {'type': 'Image', 'url': image_url}
|
||||
if post.type == POST_TYPE_IMAGE:
|
||||
page_json['attachment'] = [{'type': 'Link',
|
||||
'href': post.image.source_url}] # source_url is always a https link, no need for .replace() as done above
|
||||
page_json['attachment'] = [{'type': 'Image',
|
||||
'url': post.image.source_url, # source_url is always a https link, no need for .replace() as done above
|
||||
'name': post.image.alt_text}]
|
||||
if post.type == POST_TYPE_POLL:
|
||||
poll = Poll.query.filter_by(post_id=post.id).first()
|
||||
page_json['type'] = 'Question'
|
||||
|
@ -1151,10 +1152,7 @@ def federate_post_edit_to_user_followers(post):
|
|||
elif post.type == POST_TYPE_IMAGE:
|
||||
note['content'] = '<p>' + post.title + '</p>'
|
||||
if post.image_id and post.image.source_url:
|
||||
if post.image.alt_text:
|
||||
note['attachment'] = [{'type': 'Document', 'url': post.image.source_url, 'name': post.image.alt_text}]
|
||||
else:
|
||||
note['attachment'] = [{'type': 'Document', 'url': post.image.source_url}]
|
||||
note['attachment'] = [{'type': 'Image', 'url': post.image.source_url, 'name': post.image.alt_text}]
|
||||
elif post.type == POST_TYPE_POLL:
|
||||
poll = Poll.query.filter_by(post_id=post.id).first()
|
||||
note['type'] = 'Question'
|
||||
|
|
Loading…
Reference in a new issue