diff --git a/Gemfile b/Gemfile
index cd4989cb68c..d03a8ac4a46 100644
--- a/Gemfile
+++ b/Gemfile
@@ -64,4 +64,5 @@ end
group :production do
gem 'rails_12factor'
+ gem 'lograge'
end
diff --git a/Gemfile.lock b/Gemfile.lock
index 1ff69cb710b..aab4ee335b6 100644
--- a/Gemfile.lock
+++ b/Gemfile.lock
@@ -158,6 +158,10 @@ GEM
letter_opener (1.4.1)
launchy (~> 2.2)
libv8 (3.16.14.15)
+ lograge (0.4.1)
+ actionpack (>= 4, < 5.1)
+ activesupport (>= 4, < 5.1)
+ railties (>= 4, < 5.1)
loofah (2.0.3)
nokogiri (>= 1.5.9)
mail (2.6.4)
@@ -377,6 +381,7 @@ DEPENDENCIES
jbuilder (~> 2.0)
jquery-rails
letter_opener
+ lograge
nokogiri
oj
onebox
diff --git a/app/assets/javascripts/components/components/media_gallery.jsx b/app/assets/javascripts/components/components/media_gallery.jsx
index 45d2f24920f..81bf7c87c7d 100644
--- a/app/assets/javascripts/components/components/media_gallery.jsx
+++ b/app/assets/javascripts/components/components/media_gallery.jsx
@@ -59,7 +59,7 @@ const MediaGallery = React.createClass({
}
}
- return ;
+ return ;
});
return (
diff --git a/app/assets/stylesheets/stream_entries.scss b/app/assets/stylesheets/stream_entries.scss
index 93880237c8f..25a536e2463 100644
--- a/app/assets/stylesheets/stream_entries.scss
+++ b/app/assets/stylesheets/stream_entries.scss
@@ -158,7 +158,7 @@
font-size: 14px;
padding: 0 10px;
padding-left: 8px;
- padding-bottom: 25px;
+ padding-bottom: 15px;
color: #282c37;
a {
@@ -189,4 +189,33 @@
text-decoration: underline;
}
}
+
+ .media-attachments {
+ list-style: none;
+ margin: 0;
+ padding: 0;
+ display: block;
+ overflow: hidden;
+ padding-left: 10px;
+
+ li {
+ display: block;
+ float: left;
+ width: 120px;
+ height: 100px;
+ border-radius: 4px;
+ margin-right: 4px;
+ margin-bottom: 25px;
+
+ a {
+ display: block;
+ width: 120px;
+ height: 100px;
+ border-radius: 4px;
+ background-position: center;
+ background-repeat: none;
+ background-size: cover;
+ }
+ }
+ }
}
diff --git a/app/controllers/accounts_controller.rb b/app/controllers/accounts_controller.rb
index 162e85dec0d..3c02e0becdf 100644
--- a/app/controllers/accounts_controller.rb
+++ b/app/controllers/accounts_controller.rb
@@ -11,7 +11,7 @@ class AccountsController < ApplicationController
format.atom do
@entries = @account.stream_entries.order('id desc').with_includes.paginate_by_max_id(20, params[:max_id] || nil)
- ActiveRecord::Associations::Preloader.new.preload(@entries.select { |a| a.activity_type == 'Status' }, activity: [:mentions, reblog: :account, thread: :account])
+ ActiveRecord::Associations::Preloader.new.preload(@entries.select { |a| a.activity_type == 'Status' }, activity: [:mentions, :media_attachments, reblog: :account, thread: :account])
ActiveRecord::Associations::Preloader.new.preload(@entries.select { |a| a.activity_type == 'Favourite' }, activity: [:account, :status])
ActiveRecord::Associations::Preloader.new.preload(@entries.select { |a| a.activity_type == 'Follow' }, activity: :target_account)
end
diff --git a/app/views/stream_entries/_status.html.haml b/app/views/stream_entries/_status.html.haml
index d210805fed7..defadffc64c 100644
--- a/app/views/stream_entries/_status.html.haml
+++ b/app/views/stream_entries/_status.html.haml
@@ -38,6 +38,10 @@
.content= content_for_status(proper_status(status))
+ %ul.media-attachments
+ - status.media_attachments.each do |media|
+ %li.transparent-background= link_to '', media.file.url, style: "background-image: url(#{media.file.url(:small)})", target: '_blank'
+
- if include_threads
- status.descendants.with_includes.with_counters.each do |status|
= render partial: 'status', locals: { status: status, is_successor: true }
diff --git a/config/environments/production.rb b/config/environments/production.rb
index 7322620cf69..ee7598c4cc9 100644
--- a/config/environments/production.rb
+++ b/config/environments/production.rb
@@ -64,6 +64,9 @@ Rails.application.configure do
# Use default logging formatter so that PID and timestamp are not suppressed.
config.log_formatter = ::Logger::Formatter.new
+ # Better log formatting
+ config.lograge.enabled = true
+
# Do not dump schema after migrations.
config.active_record.dump_schema_after_migration = false