Avatars are now obtained from Blender ID. They are downloaded from Blender ID and stored in the users' home project storage. Avatars can be synced via Celery and triggered from a webhook. The avatar can be obtained from the current user object in Python, or via pillar.api.users.avatar.url(user_dict). Avatars can be shown in the web frontend by: - an explicit image (like before but with a non-Gravatar URL) - a Vue.js component `user-avatar` - a Vue.js component `current-user-avatar` The latter is the most efficient for the current user, as it uses user info that's already injected into the webpage (so requires no extra queries).
51 lines
1.1 KiB
Plaintext
51 lines
1.1 KiB
Plaintext
| {% block menu_body %}
|
|
| {% if current_user.is_authenticated %}
|
|
|
|
li.dropdown
|
|
| {% block menu_avatar %}
|
|
a.navbar-item.dropdown-toggle(href="#", data-toggle="dropdown", title="{{ current_user.email }}")
|
|
current-user-avatar
|
|
script.
|
|
new Vue({el: 'current-user-avatar'})
|
|
| {% endblock menu_avatar %}
|
|
|
|
ul.dropdown-menu.dropdown-menu-right
|
|
| {% if not current_user.has_role('protected') %}
|
|
| {% block menu_list %}
|
|
|
|
li
|
|
a.navbar-item.px-2(
|
|
href="{{ url_for('projects.home_project') }}"
|
|
title="My cloud")
|
|
| #[i.pi-home] My cloud
|
|
|
|
li
|
|
a.navbar-item.px-2(
|
|
href="{{ url_for('settings.profile') }}"
|
|
title="Settings")
|
|
| #[i.pi-cog] Settings
|
|
|
|
| {% endblock menu_list %}
|
|
|
|
li.dropdown-divider(role="separator")
|
|
| {% endif %}
|
|
|
|
li
|
|
a.navbar-item(
|
|
href="{{ url_for('users.logout') }}")
|
|
i.pi-log-out(title="Log Out")
|
|
| Log out
|
|
a.navbar-item.subitem.pt-0(
|
|
href="{{ url_for('users.switch') }}")
|
|
i.pi-blank
|
|
| Not {{ current_user.full_name }}?
|
|
|
|
| {% else %}
|
|
|
|
li.pr-1
|
|
a.btn.btn-sm.btn-outline-primary.px-3(
|
|
href="{{ url_for('users.login') }}")
|
|
| Log In
|
|
| {% endif %}
|
|
| {% endblock menu_body %}
|