Properties: let the user customize the way Dates/Times are displayed (independently from OS)

+1,I need it

4 Likes

I’m going to add another explicit +1 in addition to hearting the FR. Even if I wanted to change my OS date format for this one app (without even thinking what else that might affect, like scripts), this in practice is broken on Linux. I have spent more time than I’d like trying to see where Obsidian is getting the date settings from on Ubuntu 20.04 with i3.

18 Likes

+1 - A workaround is to set ā€œdateā€ as text. not ideal but

5 Likes

Another voice asking for the setting for display of date formats to be in Obsidian and independent of the system settings. Like many others I use multiple setting depending on the task but for my Obsidian vault I want dates to display in a certain way that is different from my normal system use.

11 Likes

Same problem here, does not work on macOS either…

(current stable version = macOS 13.5.1)

IMO it makes little sense to unchangably link the format to an OS setting because quite a lot of users use the date in all kinds of scripts, plugins and templates and it’s confusing to have multiple formats.

It should simply default to the system settings but be configurable.

Imagine using a spreadsheet or an accounting software where you’d have to change your OS locale settings to use a different currency or a navigation software to switch between imperial or metric etc.

7 Likes

I think the solution is probably more complicated than that, because users can have multiple devices with different locale settings…
Or, multiple users sharing the same vault, can have different OS / App locale settings.

I’m sure someone who understands the whole underlying system will eventually clarify / solve it :smiling_face:

Windows straight up does not have an option to display dates as I’d like to (yyyy.mm.dd, and no, yyyy-mm-dd is not acceptable), and doesn’t allow customization beyond a dropdown menu. And even if it did… it’s not the format I’d want to use in some other programs.

I’m using multiple computers with different regional settings, and with the properties view this is really confusing. Even with non-slash regions slashes are used, but the order of DD/MM are reversed. I want to see the date as I’ve set up in my templates, not some random format. I can of course set the field to text as a workaround.

I’d appreciate getting the customizability back.

6 Likes

According to How to get the Date format in electron - javascript - Stack Overflow Electron uses the system locale to set the date/time format - which is correct for anyone who doesn’t have a different LANG and LC_TIME set. I use en_US for language and en_DK for date/time on Linux, and Obsidian is displaying en_US date format.

The implication of the Stack Overflow discussion is that Electron won’t (and can’t) display the preferred date/time format if it’s not the same as the locale setting, without some work. Though one could hack the locale setting on Linux to ā€œsolveā€ that.

Looking forward to being able to manually set the display in the app itself, I do so on other apps (Thunderbird for example), so that;s a good solution to my mind.

7 Likes

+1, I work on multiple devices and I can’t change all of the OS settings to adapt, my cellphone dosen’t even give me that option

1 Like

This seems to be a popular topic, pease refrain from +1s.

The thread will get unruly and people will get unnecessary notifications.

See Obsidian Forum - FAQ - Keep It Tidy

6 Likes

A possible workaround on Linux is to change the current locales in the obsidian.desktop file.

  1. Locate the .desktop file
    (normally in /usr/share/applications/)

  2. Change the Exec line with the locale you want (here an example): Exec=env LANG=fr_FR.utf8 LC_ALL=fr_CH.utf8 LANGUAGE=fr_FR /opt/Obsidian/obsidian %U

You can see your current locales by writing locale in a terminal and locale -a to see all locales available.

3 Likes

This is (generally) broken on Linux.

I have a similar setup to @am4c130d with LANG=en_GB.UTF-8 and LC_TIME=de_DE.UTF-8, yet the dates are showing up as 19/09/2023 instead of German style, which should be 19.09.2023 according to my settings.

Testing @iomys solution with en_DK for ISO dates (https://askubuntu.com/questions/1226698/how-do-i-change-my-systemwide-date-and-time-format-to-iso-8601-yyyy-mm-dd-hhmm) was unsuccessful, even if the date command on the terminal does return the correct format.
Here’s my obsidian.desktop in case it matters:

[Desktop Entry]
Name=Obsidian
Comment=Markdown Notetaking App
GenericName=Text Editor
Type=Application
Exec=env LANG=en_DK.utf8 LC_ALL=en_DK.utf8 LANGUAGE=en_DK /home/argen/bin/obsidian %U
Icon=obsidian
StartupWMClass=obsidian
Categories=Work
MimeType=x-scheme-handler/obsidian;application/x-obsidian;

Here’s the output of locale:

LANG=en_GB.UTF-8
LANGUAGE=en_GB:en
LC_CTYPE="en_GB.UTF-8"
LC_NUMERIC=de_DE.UTF-8
LC_TIME=de_DE.UTF-8
LC_COLLATE="en_GB.UTF-8"
LC_MONETARY=de_DE.UTF-8
LC_MESSAGES="en_GB.UTF-8"
LC_PAPER=de_DE.UTF-8
LC_NAME=de_DE.UTF-8
LC_ADDRESS=de_DE.UTF-8
LC_TELEPHONE=de_DE.UTF-8
LC_MEASUREMENT=de_DE.UTF-8
LC_IDENTIFICATION=de_DE.UTF-8
LC_ALL=

And en_DK is in my locale list in the output of locale -a


As an additional comment not covered in my previous reply: This is philosophically very different from the per-vault settings that we have for everything else, e.g. see the contrast to this other open FR: Global Settings / Same settings, themes, and plugins across multiple vaults.

3 Likes

There is parallel precedent of sorts. Obsidian’s core Daily Note plugin accepts any date formatting supported by moments.js, as does the core plugin Templates, and the core plugin Unique Note Creator. In fact, all three of those core plugins can have different date formats.

(One might wonder why ā€œdateā€ formatting is handed internally within Obsidian settings for the most part, except for the one case where date formatting is tied to the OS. Noting in the UI tells us to look in OS settings.)

1 Like

Yeah, I made this mistake recently… didn’t corrupt worksheet data, but did mess with reporting. Have since gone back to previous OS date format.

I appear to have found a resolution for my Chromebook.

I was searching Google’s support forums and found a similar reference. The end result was that I had to run

sudo dpkg-reconfigure locales

then remove en_US and then restart the chromebook

I am now able to see dates ā€œcorrectlyā€ (in the format used in Australia)

Another +1 for this, changing system settings just for one app is very weird. But regardless of that I’m on Linux so it’s more of a hassle and I haven’t been able to get it working in the first place as others have mentioned.

I did want to call out one extra part that I don’t see people discussing:

When you make this change please also add an option to switch between 24hr and 12hr time modes independant of the date format.

I am in the US so the date format works fine for me but I much much prefer 24hr times and the new datetime picker has no way to change that.

5 Likes

This is definitely broken on Win 10. Obsidian does not respect the OS short-date setting.
I like Obsidian, but to expect me to change the OS language setting is a bridge to far…

Could a possible workaround be to format the date using the ā€˜locale’ and ā€˜options’ parameters in Date.toLocaleString([locale], [options]). Then you could read those values from settings?

Also +1 that the setting needs to take time into account.

In the console I got the following results when trying different options:

navigator.language
ā€˜en-US’

navigator.languages
(2) [ā€˜en-US’, ā€˜sv-SE’]

new Date()
Tue Sep 26 2023 14:05:19 GMT+0200 (Central European Summer Time)

new Date().toLocaleString()
ā€˜9/26/2023, 2:05:53 PM’

new Date().toLocaleString(ā€˜sv-se’)
ā€˜2023-09-26 14:07:45’

new Date().toISOString()
ā€˜2023-09-26T12:09:17.555Z’

new Date().toDateString()
ā€˜Tue Sep 26 2023’

new Date().toLocaleString(ā€˜en-us’, {year: ā€œnumericā€, month: ā€œshortā€, weekday: ā€œshortā€})
ā€˜Sep 2023 Tue’

1 Like

+1s have always been welcome. And people have been adding useful comments.

Users can unsubscribe from notifications from single topics. If you are overwhelmed with notifications, you should do so.

1 Like