#今回の問題
chat-space/app/views/messages/_message.html.hamlに
.main-content__chat--contents
.chat-message
.chat-message--name
= message.user.name
.chat-message--time
= message.created_at.strftime("%Y/%m/%d %H:%M")
.chat-message--comment
- if message.content.present?
%p.lower-message__content
= message.content
= image_tag message.image.url, class: 'lower-message__image' if message.image.present?
と記述し、ビューを表示させると、
data:image/s3,"s3://crabby-images/845a1/845a1846d0acc5099c703898886d71ceffee67f7" alt="スクリーンショット 2019-06-07 12.32.28.png"
imageも大きいが、messageもimageと同じ大きさで表示されてしまう。
#やりたいゴール
ちょうどいい大きさで、messageのみの時は、それ相応の大きさにする
data:image/s3,"s3://crabby-images/a4350/a4350cb425318d1c1fc372f1924feb4d648e9e8f" alt="スクリーンショット 2019-06-07 12.34.33.png"
app/assets/stylesheets/_groups.scssに高さを指定してしまっていた。
&__chat--contents{
background-color: #fafafa;
height: 500px;
padding: 10px 20px;
overflow: scroll;
heightをコメントアウトするとmessageのみの表示がちょうどいい大きさに変化した。
data:image/s3,"s3://crabby-images/bafd3/bafd36dcedb85063dbc52ba2d230f71b8565b2b3" alt="スクリーンショット 2019-06-07 12.54.42.png"
しかし画像が馬鹿でかすぎる
#process resize_to_limit: [XXX, XXX]
resize_to_fitは縦横比を維持したまま、width, heightをXXXpxにリサイズしてくれる
app/uploaders/image_uploader.rbに
process resize_to_limit: [200, 200]
を記述する
#結果
data:image/s3,"s3://crabby-images/f2e90/f2e907d43143bb3d196446c6590e54ac91f167b5" alt="スクリーンショット 2019-06-07 17.36.18.png"
ちょうどいい感じに表示されるようになりました!