From 9ba0e52bb7945ae1698710e2149c2c5d6a9b4051 Mon Sep 17 00:00:00 2001
From: Cassie Esposito
Date: Fri, 17 Jun 2022 01:26:10 -0700
Subject: [PATCH] Added an option to change date format
---
client/pages/config/index.vue | 12 ++++++++++++
client/pages/item/_id/index.vue | 7 +++++--
client/plugins/init.client.js | 2 +-
client/store/globals.js | 17 +++++++++++++++--
server/objects/settings/ServerSettings.js | 5 ++++-
5 files changed, 37 insertions(+), 6 deletions(-)
diff --git a/client/pages/config/index.vue b/client/pages/config/index.vue
index 3dda0a60..1b46046f 100644
--- a/client/pages/config/index.vue
+++ b/client/pages/config/index.vue
@@ -156,6 +156,15 @@
+
+
Your Progress: {{ Math.round(progressPercent * 100) }}%
-
Finished {{ $formatDate(userProgressFinishedAt, 'MM/dd/yyyy') }}
+
Finished {{ $formatDate(userProgressFinishedAt, dateFormat) }}
{{ $elapsedPretty(userTimeRemaining) }} remaining
-
Started {{ $formatDate(userProgressStartedAt, 'MM/dd/yyyy') }}
+
Started {{ $formatDate(userProgressStartedAt, dateFormat) }}
close
@@ -226,6 +226,9 @@ export default {
}
},
computed: {
+ dateFormat() {
+ return this.$store.state.serverSettings.dateFormat
+ },
showExperimentalFeatures() {
return this.$store.state.showExperimentalFeatures
},
diff --git a/client/plugins/init.client.js b/client/plugins/init.client.js
index bdc1b2f5..4e39ef51 100644
--- a/client/plugins/init.client.js
+++ b/client/plugins/init.client.js
@@ -169,7 +169,7 @@ Vue.prototype.$sanitizeSlug = (str) => {
str = str.replace(new RegExp(from.charAt(i), 'g'), to.charAt(i))
}
- str = str.replace('.', '-') // replace a dot by a dash
+ str = str.replace('.', '-') // replace a dot by a dash
.replace(/[^a-z0-9 -_]/g, '') // remove invalid chars
.replace(/\s+/g, '-') // collapse whitespace and replace by a dash
.replace(/-+/g, '-') // collapse dashes
diff --git a/client/store/globals.js b/client/store/globals.js
index b02eb286..f1bb51f4 100644
--- a/client/store/globals.js
+++ b/client/store/globals.js
@@ -1,4 +1,3 @@
-
export const state = () => ({
isMobile: false,
isMobileLandscape: false,
@@ -12,7 +11,21 @@ export const state = () => ({
selectedCollection: null,
selectedAuthor: null,
isCasting: false, // Actively casting
- isChromecastInitialized: false // Script loaded
+ isChromecastInitialized: false, // Script loaded
+ dateFormats: [
+ {
+ text: 'MM/DD/YYYY',
+ value: 'MM/dd/yyyy'
+ },
+ {
+ text: 'DD/MM/YYYY',
+ value: 'dd/MM/yyyy'
+ },
+ {
+ text: 'YYYY-MM-DD',
+ value: 'yyyy-MM-dd'
+ }
+ ]
})
export const getters = {
diff --git a/server/objects/settings/ServerSettings.js b/server/objects/settings/ServerSettings.js
index 00c56b2a..5a83f330 100644
--- a/server/objects/settings/ServerSettings.js
+++ b/server/objects/settings/ServerSettings.js
@@ -12,7 +12,7 @@ class ServerSettings {
this.scannerPreferAudioMetadata = false
this.scannerPreferOpfMetadata = false
this.scannerPreferMatchedMetadata = false
- this.scannerDisableWatcher = false
+ this.scannerDisableWatcher = false
this.scannerPreferOverdriveMediaMarker = false
// Metadata - choose to store inside users library item folder
@@ -48,6 +48,7 @@ class ServerSettings {
// Misc Flags
this.chromecastEnabled = false
this.enableEReader = false
+ this.dateFormat="MM/dd/yyyy"
this.logLevel = Logger.logLevel
@@ -95,6 +96,7 @@ class ServerSettings {
this.sortingPrefixes = settings.sortingPrefixes || ['the', 'a']
this.chromecastEnabled = !!settings.chromecastEnabled
this.enableEReader = !!settings.enableEReader
+ this.dateFormat = settings.dateFormat
this.logLevel = settings.logLevel || Logger.logLevel
this.version = settings.version || null
@@ -130,6 +132,7 @@ class ServerSettings {
sortingPrefixes: [...this.sortingPrefixes],
chromecastEnabled: this.chromecastEnabled,
enableEReader: this.enableEReader,
+ dateFormat: this.dateFormat,
logLevel: this.logLevel,
version: this.version
}