]> cat aescling's git repositories - mastodon.git/commitdiff
Reset preview image if avatar/header image selection was cancelled (#4893)
authorunarist <m.unarist@gmail.com>
Mon, 11 Sep 2017 14:19:54 +0000 (23:19 +0900)
committerEugen Rochko <eugen@zeonfederated.com>
Mon, 11 Sep 2017 14:19:54 +0000 (16:19 +0200)
app/javascript/packs/public.js
app/views/settings/profiles/show.html.haml

index 1a274c4cbd7ccbcb3d239fc89e644d197330a630..ca6f9eac6e957c67118469190be5bda9ee8f9320 100644 (file)
@@ -124,7 +124,7 @@ function main() {
   delegate(document, '#account_avatar', 'change', ({ target }) => {
     const avatar = document.querySelector('.card.compact .avatar img');
     const [file] = target.files || [];
-    const url = URL.createObjectURL(file);
+    const url = file ? URL.createObjectURL(file) : avatar.dataset.originalSrc;
 
     avatar.src = url;
   });
@@ -132,7 +132,7 @@ function main() {
   delegate(document, '#account_header', 'change', ({ target }) => {
     const header = document.querySelector('.card.compact');
     const [file] = target.files || [];
-    const url = URL.createObjectURL(file);
+    const url = file ? URL.createObjectURL(file) : header.dataset.originalSrc;
 
     header.style.backgroundImage = `url(${url})`;
   });
index e0fb613f83128705a60e459cd510decde1baead8..7a06cd0146bdf0e931fb93260d34614d0a8f376a 100644 (file)
@@ -8,8 +8,8 @@
     = f.input :display_name, placeholder: t('simple_form.labels.defaults.display_name'), hint: t('simple_form.hints.defaults.display_name', count: 30 - @account.display_name.size).html_safe
     = f.input :note, placeholder: t('simple_form.labels.defaults.note'), hint: t('simple_form.hints.defaults.note', count: 160 - @account.note.size).html_safe
 
-  .card.compact{ style: "background-image: url(#{@account.header.url(:original)})" }
-    .avatar= image_tag @account.avatar.url(:original)
+  .card.compact{ style: "background-image: url(#{@account.header.url(:original)})", data: { original_src: @account.header.url(:original) } }
+    .avatar= image_tag @account.avatar.url(:original), data: { original_src: @account.avatar.url(:original) }
 
   .fields-group
     = f.input :avatar, wrapper: :with_label, input_html: { accept: AccountAvatar::IMAGE_MIME_TYPES.join(',') }, hint: t('simple_form.hints.defaults.avatar')