UX: open the change avatar modal when clicking the profile picture

This commit is contained in:
Régis Hanol 2018-07-24 15:13:21 +02:00
parent 7a3c541077
commit 8ca25f5aed
6 changed files with 70 additions and 73 deletions

View File

@ -9,6 +9,7 @@ import { findAll } from "discourse/models/login-method";
import { getOwner } from "discourse-common/lib/get-owner"; import { getOwner } from "discourse-common/lib/get-owner";
import { userPath } from "discourse/lib/url"; import { userPath } from "discourse/lib/url";
import Composer from "discourse/models/composer"; import Composer from "discourse/models/composer";
import { popupAjaxError } from "discourse/lib/ajax-error";
function unlessReadOnly(method, message) { function unlessReadOnly(method, message) {
return function() { return function() {
@ -195,6 +196,71 @@ const ApplicationRoute = Discourse.Route.extend(OpenComposer, {
createNewMessageViaParams(username, title, body) { createNewMessageViaParams(username, title, body) {
this.openComposerWithMessageParams(username, title, body); this.openComposerWithMessageParams(username, title, body);
},
showAvatarSelector(user) {
user = user || this.modelFor("user");
const props = user.getProperties(
"id",
"email",
"username",
"avatar_template",
"system_avatar_template",
"gravatar_avatar_template",
"custom_avatar_template",
"system_avatar_upload_id",
"gravatar_avatar_upload_id",
"custom_avatar_upload_id"
);
switch (props.avatar_template) {
case props.system_avatar_template:
props.selected = "system";
break;
case props.gravatar_avatar_template:
props.selected = "gravatar";
break;
default:
props.selected = "uploaded";
}
props.user = user;
const modal = showModal("avatar-selector");
modal.setProperties(props);
if (this.siteSettings.selectable_avatars_enabled) {
ajax("/site/selectable-avatars.json").then(avatars =>
modal.set("selectableAvatars", avatars)
);
}
},
selectAvatar(url) {
const modal = this.controllerFor("avatar-selector");
modal.send("closeModal");
modal
.get("user")
.selectAvatar(url)
.then(() => window.location.reload())
.catch(popupAjaxError);
},
saveAvatarSelection() {
const modal = this.controllerFor("avatar-selector");
const selectedUploadId = modal.get("selectedUploadId");
const selectedAvatarTemplate = modal.get("selectedAvatarTemplate");
const type = modal.get("selected");
modal.send("closeModal");
modal
.get("user")
.pickAvatar(selectedUploadId, type, selectedAvatarTemplate)
.then(() => window.location.reload())
.catch(popupAjaxError);
} }
}, },

View File

@ -1,77 +1,7 @@
import RestrictedUserRoute from "discourse/routes/restricted-user"; import RestrictedUserRoute from "discourse/routes/restricted-user";
import showModal from "discourse/lib/show-modal";
import { popupAjaxError } from "discourse/lib/ajax-error";
import { ajax } from "discourse/lib/ajax";
export default RestrictedUserRoute.extend({ export default RestrictedUserRoute.extend({
model() { model() {
return this.modelFor("user"); return this.modelFor("user");
},
actions: {
showAvatarSelector(user) {
user = user || this.modelFor("user");
const props = user.getProperties(
"id",
"email",
"username",
"avatar_template",
"system_avatar_template",
"gravatar_avatar_template",
"custom_avatar_template",
"system_avatar_upload_id",
"gravatar_avatar_upload_id",
"custom_avatar_upload_id"
);
switch (props.avatar_template) {
case props.system_avatar_template:
props.selected = "system";
break;
case props.gravatar_avatar_template:
props.selected = "gravatar";
break;
default:
props.selected = "uploaded";
}
props.user = user;
const controller = showModal("avatar-selector");
controller.setProperties(props);
if (this.siteSettings.selectable_avatars_enabled) {
ajax("/site/selectable-avatars.json").then(avatars =>
controller.set("selectableAvatars", avatars)
);
}
},
selectAvatar(url) {
const controller = this.controllerFor("avatar-selector");
controller.send("closeModal");
controller
.get("user")
.selectAvatar(url)
.then(() => window.location.reload())
.catch(popupAjaxError);
},
saveAvatarSelection() {
const controller = this.controllerFor("avatar-selector");
const selectedUploadId = controller.get("selectedUploadId");
const selectedAvatarTemplate = controller.get("selectedAvatarTemplate");
const type = controller.get("selected");
controller.send("closeModal");
controller
.get("user")
.pickAvatar(selectedUploadId, type, selectedAvatarTemplate)
.then(() => window.location.reload())
.catch(popupAjaxError);
}
} }
}); });

View File

@ -2,8 +2,7 @@ import Draft from "discourse/models/draft";
export default Discourse.Route.extend({ export default Discourse.Route.extend({
titleToken() { titleToken() {
const model = this.modelFor("user"); const username = this.modelFor("user").get("username");
const username = model.get("username");
if (username) { if (username) {
return [I18n.t("user.profile"), username]; return [I18n.t("user.profile"), username];
} }

View File

@ -39,7 +39,7 @@
<div class='profile-image'></div> <div class='profile-image'></div>
<div class='details'> <div class='details'>
<div class='primary'> <div class='primary'>
<div class='user-profile-avatar'> <div class='user-profile-avatar' {{action "showAvatarSelector"}} title="{{i18n 'user.change_avatar.label'}}">
{{bound-avatar model "huge"}} {{bound-avatar model "huge"}}
{{#if model.primary_group_name}} {{#if model.primary_group_name}}
{{avatar-flair {{avatar-flair

View File

@ -151,6 +151,7 @@
} }
.user-profile-avatar { .user-profile-avatar {
cursor: pointer;
position: relative; position: relative;
float: left; float: left;
height: 100%; height: 100%;

View File

@ -785,6 +785,7 @@ en:
change_avatar: change_avatar:
title: "Change your profile picture" title: "Change your profile picture"
label: "Change your profile picture"
gravatar: "<a href='//gravatar.com/emails' target='_blank'>Gravatar</a>, based on" gravatar: "<a href='//gravatar.com/emails' target='_blank'>Gravatar</a>, based on"
gravatar_title: "Change your avatar on Gravatar's website" gravatar_title: "Change your avatar on Gravatar's website"
gravatar_failed: "Could not fetch the Gravatar. Is there one associated to that email address?" gravatar_failed: "Could not fetch the Gravatar. Is there one associated to that email address?"