|
@@ -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
|