2021-04-26 16:41:12 +02:00
|
|
|
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
|
|
|
// See LICENSE.txt for license information.
|
|
|
|
|
2021-08-15 12:51:19 +02:00
|
|
|
import {notifySettingsChanged} from './nativeApp'
|
|
|
|
import {Utils} from './utils'
|
|
|
|
|
|
|
|
// eslint-disable-next-line no-shadow
|
2022-02-28 12:28:16 +01:00
|
|
|
export enum UserSettingKey {
|
2021-08-15 12:51:19 +02:00
|
|
|
Language = 'language',
|
|
|
|
Theme = 'theme',
|
2022-03-22 15:24:34 +01:00
|
|
|
LastTeamId = 'lastTeamId',
|
2021-08-15 12:51:19 +02:00
|
|
|
LastBoardId = 'lastBoardId',
|
|
|
|
LastViewId = 'lastViewId',
|
|
|
|
EmojiMartSkin = 'emoji-mart.skin',
|
|
|
|
EmojiMartLast = 'emoji-mart.last',
|
|
|
|
EmojiMartFrequently = 'emoji-mart.frequently',
|
2021-09-28 15:51:32 +02:00
|
|
|
RandomIcons = 'randomIcons',
|
2021-10-01 19:53:27 +02:00
|
|
|
MobileWarningClosed = 'mobileWarningClosed',
|
2021-10-04 23:27:30 +02:00
|
|
|
WelcomePageViewed = 'welcomePageViewed',
|
2022-07-08 16:43:43 +02:00
|
|
|
HideCloudMessage = 'hideCloudMessage',
|
|
|
|
NameFormat = 'nameFormat'
|
2021-08-15 12:51:19 +02:00
|
|
|
}
|
|
|
|
|
2021-04-28 00:09:26 +02:00
|
|
|
export class UserSettings {
|
2021-08-15 12:51:19 +02:00
|
|
|
static get(key: UserSettingKey): string | null {
|
|
|
|
return localStorage.getItem(key)
|
|
|
|
}
|
|
|
|
|
2021-09-30 01:58:36 +02:00
|
|
|
static set(key: UserSettingKey, value: string | null): void {
|
2021-08-15 12:51:19 +02:00
|
|
|
if (!Object.values(UserSettingKey).includes(key)) {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
if (value === null) {
|
|
|
|
localStorage.removeItem(key)
|
|
|
|
} else {
|
|
|
|
localStorage.setItem(key, value)
|
|
|
|
}
|
|
|
|
notifySettingsChanged(key)
|
|
|
|
}
|
|
|
|
|
|
|
|
static get language(): string | null {
|
|
|
|
return UserSettings.get(UserSettingKey.Language)
|
|
|
|
}
|
|
|
|
|
|
|
|
static set language(newValue: string | null) {
|
|
|
|
UserSettings.set(UserSettingKey.Language, newValue)
|
|
|
|
}
|
|
|
|
|
|
|
|
static get theme(): string | null {
|
|
|
|
return UserSettings.get(UserSettingKey.Theme)
|
|
|
|
}
|
|
|
|
|
|
|
|
static set theme(newValue: string | null) {
|
|
|
|
UserSettings.set(UserSettingKey.Theme, newValue)
|
|
|
|
}
|
|
|
|
|
2022-03-22 15:24:34 +01:00
|
|
|
static get lastTeamId(): string | null {
|
|
|
|
return UserSettings.get(UserSettingKey.LastTeamId)
|
2021-09-15 08:48:25 +02:00
|
|
|
}
|
|
|
|
|
2022-03-22 15:24:34 +01:00
|
|
|
static set lastTeamId(newValue: string | null) {
|
|
|
|
UserSettings.set(UserSettingKey.LastTeamId, newValue)
|
2021-09-15 08:48:25 +02:00
|
|
|
}
|
|
|
|
|
2022-03-22 15:24:34 +01:00
|
|
|
// maps last board ID for each team
|
|
|
|
// maps teamID -> board ID
|
|
|
|
static get lastBoardId(): {[key: string]: string} {
|
|
|
|
let rawData = UserSettings.get(UserSettingKey.LastBoardId) || '{}'
|
|
|
|
if (rawData[0] !== '{') {
|
|
|
|
rawData = '{}'
|
|
|
|
}
|
|
|
|
|
|
|
|
let mapping: {[key: string]: string}
|
|
|
|
try {
|
|
|
|
mapping = JSON.parse(rawData)
|
|
|
|
} catch {
|
|
|
|
// revert to empty data if JSON conversion fails.
|
|
|
|
// This will happen when users run the new code for the first time
|
|
|
|
mapping = {}
|
|
|
|
}
|
|
|
|
|
|
|
|
return mapping
|
2021-08-15 12:51:19 +02:00
|
|
|
}
|
|
|
|
|
2022-03-22 15:24:34 +01:00
|
|
|
static setLastTeamID(teamID: string | null): void {
|
|
|
|
UserSettings.set(UserSettingKey.LastTeamId, teamID)
|
2021-08-15 12:51:19 +02:00
|
|
|
}
|
|
|
|
|
2022-03-22 15:24:34 +01:00
|
|
|
static setLastBoardID(teamID: string, boardID: string | null): void {
|
|
|
|
const data = this.lastBoardId
|
|
|
|
if (boardID === null) {
|
|
|
|
delete data[teamID]
|
|
|
|
} else {
|
|
|
|
data[teamID] = boardID
|
|
|
|
}
|
|
|
|
UserSettings.set(UserSettingKey.LastBoardId, JSON.stringify(data))
|
|
|
|
}
|
|
|
|
|
|
|
|
static get lastViewId(): {[key: string]: string} {
|
|
|
|
const rawData = UserSettings.get(UserSettingKey.LastViewId) || '{}'
|
|
|
|
let mapping: {[key: string]: string}
|
|
|
|
try {
|
|
|
|
mapping = JSON.parse(rawData)
|
|
|
|
} catch {
|
|
|
|
// revert to empty data if JSON conversion fails.
|
|
|
|
// This will happen when users run the new code for the first time
|
|
|
|
mapping = {}
|
|
|
|
}
|
|
|
|
|
|
|
|
return mapping
|
2021-08-15 12:51:19 +02:00
|
|
|
}
|
|
|
|
|
2022-03-22 15:24:34 +01:00
|
|
|
static setLastViewId(boardID: string, viewID: string | null): void {
|
|
|
|
const data = this.lastViewId
|
|
|
|
if (viewID === null) {
|
|
|
|
delete data[boardID]
|
|
|
|
} else {
|
|
|
|
data[boardID] = viewID
|
|
|
|
}
|
|
|
|
UserSettings.set(UserSettingKey.LastViewId, JSON.stringify(data))
|
2021-08-15 12:51:19 +02:00
|
|
|
}
|
|
|
|
|
2021-04-26 16:41:12 +02:00
|
|
|
static get prefillRandomIcons(): boolean {
|
2021-08-15 12:51:19 +02:00
|
|
|
return UserSettings.get(UserSettingKey.RandomIcons) !== 'false'
|
2021-04-26 16:41:12 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
static set prefillRandomIcons(newValue: boolean) {
|
2021-08-15 12:51:19 +02:00
|
|
|
UserSettings.set(UserSettingKey.RandomIcons, JSON.stringify(newValue))
|
|
|
|
}
|
|
|
|
|
|
|
|
static getEmojiMartSetting(key: string): any {
|
|
|
|
const prefixed = `emoji-mart.${key}`
|
|
|
|
Utils.assert((Object as any).values(UserSettingKey).includes(prefixed))
|
|
|
|
const json = UserSettings.get(prefixed as UserSettingKey)
|
|
|
|
return json ? JSON.parse(json) : null
|
2021-04-26 16:41:12 +02:00
|
|
|
}
|
|
|
|
|
2021-09-30 01:58:36 +02:00
|
|
|
static setEmojiMartSetting(key: string, value: any): void {
|
2021-08-15 12:51:19 +02:00
|
|
|
const prefixed = `emoji-mart.${key}`
|
|
|
|
Utils.assert((Object as any).values(UserSettingKey).includes(prefixed))
|
|
|
|
UserSettings.set(prefixed as UserSettingKey, JSON.stringify(value))
|
|
|
|
}
|
2021-10-01 19:53:27 +02:00
|
|
|
|
|
|
|
static get mobileWarningClosed(): boolean {
|
|
|
|
return UserSettings.get(UserSettingKey.MobileWarningClosed) === 'true'
|
|
|
|
}
|
|
|
|
|
|
|
|
static set mobileWarningClosed(newValue: boolean) {
|
|
|
|
UserSettings.set(UserSettingKey.MobileWarningClosed, String(newValue))
|
|
|
|
}
|
2022-06-16 13:16:45 +02:00
|
|
|
|
|
|
|
static get hideCloudMessage(): boolean {
|
|
|
|
return localStorage.getItem(UserSettingKey.HideCloudMessage) === 'true'
|
|
|
|
}
|
|
|
|
|
|
|
|
static set hideCloudMessage(newValue: boolean) {
|
|
|
|
localStorage.setItem(UserSettingKey.HideCloudMessage, JSON.stringify(newValue))
|
|
|
|
}
|
2022-07-08 16:43:43 +02:00
|
|
|
|
|
|
|
static get nameFormat(): string | null {
|
|
|
|
return UserSettings.get(UserSettingKey.NameFormat)
|
|
|
|
}
|
|
|
|
|
|
|
|
static set nameFormat(newValue: string | null) {
|
|
|
|
UserSettings.set(UserSettingKey.NameFormat, newValue)
|
|
|
|
}
|
|
|
|
|
2021-08-15 12:51:19 +02:00
|
|
|
}
|
2021-04-28 00:09:26 +02:00
|
|
|
|
|
|
|
export function exportUserSettingsBlob(): string {
|
|
|
|
return window.btoa(exportUserSettings())
|
|
|
|
}
|
|
|
|
|
|
|
|
function exportUserSettings(): string {
|
2021-08-15 12:51:19 +02:00
|
|
|
const keys = Object.values(UserSettingKey)
|
2021-04-28 00:09:26 +02:00
|
|
|
const settings = Object.fromEntries(keys.map((key) => [key, localStorage.getItem(key)]))
|
|
|
|
settings.timestamp = `${Date.now()}`
|
|
|
|
return JSON.stringify(settings)
|
|
|
|
}
|
|
|
|
|
2021-08-15 12:51:19 +02:00
|
|
|
export function importUserSettingsBlob(blob: string): string[] {
|
2021-04-28 00:09:26 +02:00
|
|
|
return importUserSettings(window.atob(blob))
|
|
|
|
}
|
|
|
|
|
2021-08-15 12:51:19 +02:00
|
|
|
function importUserSettings(json: string): string[] {
|
2021-04-28 00:09:26 +02:00
|
|
|
const settings = parseUserSettings(json)
|
2021-08-15 12:51:19 +02:00
|
|
|
if (!settings) {
|
|
|
|
return []
|
|
|
|
}
|
2021-04-28 00:09:26 +02:00
|
|
|
const timestamp = settings.timestamp
|
|
|
|
const lastTimestamp = localStorage.getItem('timestamp')
|
|
|
|
if (!timestamp || (lastTimestamp && Number(timestamp) <= Number(lastTimestamp))) {
|
2021-08-15 12:51:19 +02:00
|
|
|
return []
|
2021-04-28 00:09:26 +02:00
|
|
|
}
|
2021-08-15 12:51:19 +02:00
|
|
|
const importedKeys = []
|
2021-04-28 00:09:26 +02:00
|
|
|
for (const [key, value] of Object.entries(settings)) {
|
2021-08-15 12:51:19 +02:00
|
|
|
if (Object.values(UserSettingKey).includes(key as UserSettingKey)) {
|
|
|
|
if (value) {
|
|
|
|
localStorage.setItem(key, value as string)
|
|
|
|
} else {
|
|
|
|
localStorage.removeItem(key)
|
|
|
|
}
|
|
|
|
importedKeys.push(key)
|
2021-05-24 18:59:30 +02:00
|
|
|
}
|
2021-04-28 00:09:26 +02:00
|
|
|
}
|
2021-08-15 12:51:19 +02:00
|
|
|
return importedKeys
|
2021-04-28 00:09:26 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function parseUserSettings(json: string): any {
|
|
|
|
try {
|
|
|
|
return JSON.parse(json)
|
|
|
|
} catch (e) {
|
2021-08-15 12:51:19 +02:00
|
|
|
return undefined
|
2021-04-28 00:09:26 +02:00
|
|
|
}
|
|
|
|
}
|