mirror of
https://github.com/jellyfin/jellyfin-web
synced 2025-03-30 19:56:21 +00:00
move usersettings to server
This commit is contained in:
parent
8fc34293c7
commit
5ec5a0d9fa
48 changed files with 1295 additions and 815 deletions
|
@ -1,27 +1,35 @@
|
|||
define(['appSettings', 'apiClientResolver', 'events'], function (appsettings, apiClientResolver, events) {
|
||||
define(['appSettings', 'events'], function (appsettings, events) {
|
||||
|
||||
return function (configuredUserId) {
|
||||
return function () {
|
||||
|
||||
var self = this;
|
||||
var currentUserId;
|
||||
var currentApiClient;
|
||||
var displayPrefs;
|
||||
|
||||
function getUserId(apiClient) {
|
||||
self.setUserInfo = function (userId, apiClient) {
|
||||
|
||||
if (configuredUserId) {
|
||||
return configuredUserId;
|
||||
currentUserId = userId;
|
||||
currentApiClient = apiClient;
|
||||
|
||||
if (!userId) {
|
||||
displayPrefs = null;
|
||||
return Promise.resolve();
|
||||
}
|
||||
|
||||
var apiClientInstance = apiClient || apiClientResolver();
|
||||
return apiClient.getDisplayPreferences('usersettings', userId, 'emby').then(function (result) {
|
||||
result.CustomPrefs = result.CustomPrefs || {};
|
||||
displayPrefs = result;
|
||||
});
|
||||
};
|
||||
|
||||
if (apiClientInstance) {
|
||||
return apiClientInstance.getCurrentUserId();
|
||||
}
|
||||
|
||||
return null;
|
||||
function saveServerPreferences() {
|
||||
currentApiClient.updateDisplayPreferences('usersettings', displayPrefs, currentUserId, 'emby');
|
||||
}
|
||||
|
||||
self.set = function (name, value) {
|
||||
self.set = function (name, value, enableOnServer) {
|
||||
|
||||
var userId = getUserId();
|
||||
var userId = currentUserId;
|
||||
if (!userId) {
|
||||
throw new Error('userId cannot be null');
|
||||
}
|
||||
|
@ -29,16 +37,28 @@ define(['appSettings', 'apiClientResolver', 'events'], function (appsettings, ap
|
|||
var currentValue = self.get(name);
|
||||
appsettings.set(name, value, userId);
|
||||
|
||||
if (enableOnServer !== false && displayPrefs) {
|
||||
displayPrefs.CustomPrefs[name] = value == null ? value : value.toString();
|
||||
saveServerPreferences();
|
||||
}
|
||||
|
||||
if (currentValue != value) {
|
||||
events.trigger(self, 'change', [name]);
|
||||
}
|
||||
};
|
||||
|
||||
self.get = function (name) {
|
||||
var userId = getUserId();
|
||||
self.get = function (name, enableOnServer) {
|
||||
var userId = currentUserId;
|
||||
if (!userId) {
|
||||
throw new Error('userId cannot be null');
|
||||
}
|
||||
|
||||
if (enableOnServer !== false) {
|
||||
if (displayPrefs) {
|
||||
return displayPrefs.CustomPrefs[name];
|
||||
}
|
||||
}
|
||||
|
||||
return appsettings.get(name, userId);
|
||||
};
|
||||
|
||||
|
@ -48,7 +68,7 @@ define(['appSettings', 'apiClientResolver', 'events'], function (appsettings, ap
|
|||
self.set('enableCinemaMode', val.toString());
|
||||
}
|
||||
|
||||
val = self.get('enableCinemaMode');
|
||||
val = self.get('enableCinemaMode', false);
|
||||
|
||||
if (val) {
|
||||
return val != 'false';
|
||||
|
@ -86,15 +106,15 @@ define(['appSettings', 'apiClientResolver', 'events'], function (appsettings, ap
|
|||
|
||||
self.serverConfig = function (config) {
|
||||
|
||||
var apiClient = apiClientResolver();
|
||||
var apiClient = currentApiClient;
|
||||
|
||||
if (config) {
|
||||
|
||||
return apiClient.updateUserConfiguration(getUserId(apiClient), config);
|
||||
return apiClient.updateUserConfiguration(currentUserId, config);
|
||||
|
||||
} else {
|
||||
|
||||
return apiClient.getUser(getUserId(apiClient)).then(function (user) {
|
||||
return apiClient.getUser(currentUserId).then(function (user) {
|
||||
|
||||
return user.Configuration;
|
||||
});
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue