|
@@ -8,8 +8,10 @@ import EmojiInput from 'src/components/emoji_input/emoji_input.vue'
|
|
|
import suggestor from 'src/components/emoji_input/suggestor.js'
|
|
|
import Autosuggest from 'src/components/autosuggest/autosuggest.vue'
|
|
|
import Checkbox from 'src/components/checkbox/checkbox.vue'
|
|
|
+import InterfaceLanguageSwitcher from 'src/components/interface_language_switcher/interface_language_switcher.vue'
|
|
|
import BooleanSetting from '../helpers/boolean_setting.vue'
|
|
|
import SharedComputedObject from '../helpers/shared_computed_object.js'
|
|
|
+import localeService from 'src/services/locale/locale.service.js'
|
|
|
|
|
|
import { library } from '@fortawesome/fontawesome-svg-core'
|
|
|
import {
|
|
@@ -40,7 +42,8 @@ const ProfileTab = {
|
|
|
banner: null,
|
|
|
bannerPreview: null,
|
|
|
background: null,
|
|
|
- backgroundPreview: null
|
|
|
+ backgroundPreview: null,
|
|
|
+ emailLanguage: this.$store.state.users.currentUser.language || ''
|
|
|
}
|
|
|
},
|
|
|
components: {
|
|
@@ -50,7 +53,8 @@ const ProfileTab = {
|
|
|
Autosuggest,
|
|
|
ProgressButton,
|
|
|
Checkbox,
|
|
|
- BooleanSetting
|
|
|
+ BooleanSetting,
|
|
|
+ InterfaceLanguageSwitcher
|
|
|
},
|
|
|
computed: {
|
|
|
user () {
|
|
@@ -111,19 +115,25 @@ const ProfileTab = {
|
|
|
},
|
|
|
methods: {
|
|
|
updateProfile () {
|
|
|
+ const params = {
|
|
|
+ note: this.newBio,
|
|
|
+ locked: this.newLocked,
|
|
|
+ // Backend notation.
|
|
|
+ /* eslint-disable camelcase */
|
|
|
+ display_name: this.newName,
|
|
|
+ fields_attributes: this.newFields.filter(el => el != null),
|
|
|
+ bot: this.bot,
|
|
|
+ show_role: this.showRole
|
|
|
+ /* eslint-enable camelcase */
|
|
|
+ }
|
|
|
+
|
|
|
+ if (this.emailLanguage) {
|
|
|
+ params.language = localeService.internalToBackendLocale(this.emailLanguage)
|
|
|
+ }
|
|
|
+
|
|
|
this.$store.state.api.backendInteractor
|
|
|
- .updateProfile({
|
|
|
- params: {
|
|
|
- note: this.newBio,
|
|
|
- locked: this.newLocked,
|
|
|
- // Backend notation.
|
|
|
- /* eslint-disable camelcase */
|
|
|
- display_name: this.newName,
|
|
|
- fields_attributes: this.newFields.filter(el => el != null),
|
|
|
- bot: this.bot,
|
|
|
- show_role: this.showRole
|
|
|
- /* eslint-enable camelcase */
|
|
|
- } }).then((user) => {
|
|
|
+ .updateProfile({ params })
|
|
|
+ .then((user) => {
|
|
|
this.newFields.splice(user.fields.length)
|
|
|
merge(this.newFields, user.fields)
|
|
|
this.$store.commit('addNewUsers', [user])
|