diff --git a/src/http-common/index.js b/src/http-common/index.js index 66835fc5..e6c116cd 100644 --- a/src/http-common/index.js +++ b/src/http-common/index.js @@ -1,7 +1,18 @@ import axios from 'axios' +import {getToken} from '@/helpers/auth' -export const HTTPFactory = () => { +export function HTTPFactory() { return axios.create({ baseURL: window.API_URL, }) } + +export function AuthenticatedHTTPFactory(token = getToken()) { + return axios.create({ + baseURL: window.API_URL, + headers: { + Authorization: `Bearer ${token}`, + 'Content-Type': 'application/json', + }, + }) +} diff --git a/src/i18n/lang/en.json b/src/i18n/lang/en.json index 585cdfb0..306eb3f5 100644 --- a/src/i18n/lang/en.json +++ b/src/i18n/lang/en.json @@ -85,7 +85,8 @@ "weekStartSunday": "Sunday", "weekStartMonday": "Monday", "language": "Language", - "defaultList": "Default List" + "defaultList": "Default List", + "timezone": "Time Zone" }, "totp": { "title": "Two Factor Authentication", diff --git a/src/models/userSettings.js b/src/models/userSettings.js index 6ed0ffe5..41932e26 100644 --- a/src/models/userSettings.js +++ b/src/models/userSettings.js @@ -11,6 +11,7 @@ export default class UserSettingsModel extends AbstractModel { overdueTasksRemindersEnabled: true, defaultListId: undefined, weekStart: 0, + timezone: '', } } } \ No newline at end of file diff --git a/src/store/modules/auth.js b/src/store/modules/auth.js index 9e2f9cbb..99291a2a 100644 --- a/src/store/modules/auth.js +++ b/src/store/modules/auth.js @@ -1,4 +1,4 @@ -import {HTTPFactory} from '@/http-common' +import {HTTPFactory, AuthenticatedHTTPFactory} from '@/http-common' import {i18n, getCurrentLanguage, saveLanguage} from '@/i18n' import {objectToSnakeCase} from '@/helpers/case' import {LOADING} from '../mutation-types' @@ -215,13 +215,9 @@ export default { return } - const HTTP = HTTPFactory() + const HTTP = AuthenticatedHTTPFactory(jwt) try { - const response = await HTTP.get('user', { - headers: { - Authorization: `Bearer ${jwt}`, - }, - }) + const response = await HTTP.get('user') const info = new UserModel(response.data) info.type = state.info.type info.email = state.info.email diff --git a/src/views/user/settings/General.vue b/src/views/user/settings/General.vue index 876bef26..279b004f 100644 --- a/src/views/user/settings/General.vue +++ b/src/views/user/settings/General.vue @@ -92,9 +92,9 @@