|
|
|
@ -29,6 +29,35 @@ module StreamEntriesHelper
|
|
|
|
|
[prepend_str, account.note].join(' · ')
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def media_summary(status)
|
|
|
|
|
attachments = { image: 0, video: 0 }
|
|
|
|
|
|
|
|
|
|
status.media_attachments.each do |media|
|
|
|
|
|
if media.video?
|
|
|
|
|
attachments[:video] += 1
|
|
|
|
|
else
|
|
|
|
|
attachments[:image] += 1
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
text = attachments.to_a.reject { |_, value| value.zero? }.map { |key, value| t("statuses.attached.#{key}", count: value) }.join(' · ')
|
|
|
|
|
|
|
|
|
|
return if text.blank?
|
|
|
|
|
|
|
|
|
|
t('statuses.attached.description', attached: text)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def status_text_summary(status)
|
|
|
|
|
return if status.spoiler_text.blank?
|
|
|
|
|
t('statuses.content_warning', warning: status.spoiler_text)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def status_description(status)
|
|
|
|
|
components = [[media_summary(status), status_text_summary(status)].reject(&:blank?).join(' · ')]
|
|
|
|
|
components << status.text if status.spoiler_text.blank?
|
|
|
|
|
components.reject(&:blank?).join("\n\n")
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def stream_link_target
|
|
|
|
|
embedded_view? ? '_blank' : nil
|
|
|
|
|
end
|
|
|
|
|