Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix: Advanced format output with short offset name #2637

Open
wants to merge 1 commit into
base: dev
Choose a base branch
from

Conversation

klm-turing
Copy link
Contributor

@klm-turing klm-turing commented Apr 23, 2024

  • Used of long timezone name by default in Intl.DateTimeFormat
  • Extract and cached short offset name from the long one in the offsetName function
  • Writing related unit test

This fix 1713 issue

Used of long timezone name by default in Intl.DateTimeFormat
Extract and cached short offset name from the long one in the offsetName function
Writing related unit test
@et
Copy link

et commented May 20, 2024

Thanks for adding this! I definitely could use this in a moment migration.
@iamkun - curious if we can get this in?

Alternatively, have we considered replicating moment-timezone's zoneAbbr functionality?
https://momentjs.com/timezone/docs/#/using-timezones/formatting/

const result = makeFormatParts(this.valueOf(), zone, { timeZoneName: type }).find(m => m.type.toLowerCase() === 'timezonename')
return result && result.value
if (type === 'short') {

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for putting this PR together, I found it really helpful! 🎉

There's a small issue where the value for Istanbul is 'GMT+03:00' so the returned abbreviation becomes G.

Maybe you could add a check to see if there are any digits in the value and then return the value instead of abbreviating it?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

advancedFormat's z outputs offset instead of abbreviated offset name for Central European Standard Time
4 participants