aboutsummaryrefslogtreecommitdiffstats
path: root/web_src/js/features/formatting.js
blob: 5590ba44d144851f215b78e55a4231e560a990bb (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
const {lang} = document.documentElement;
const dateFormatter = new Intl.DateTimeFormat(lang, {year: 'numeric', month: 'long', day: 'numeric'});
const shortDateFormatter = new Intl.DateTimeFormat(lang, {year: 'numeric', month: 'short', day: 'numeric'});
const dateTimeFormatter = new Intl.DateTimeFormat(lang, {year: 'numeric', month: 'short', day: 'numeric', hour: 'numeric', minute: 'numeric', second: 'numeric'});

export function initFormattingReplacements() {
  // for each <time></time> tag, if it has the data-format attribute, format
  // the text according to the user's chosen locale and formatter.
  formatAllTimeElements();
}

function formatAllTimeElements() {
  const timeElements = document.querySelectorAll('time[data-format]');
  for (const timeElement of timeElements) {
    const formatter = getFormatter(timeElement.dataset.format);
    timeElement.textContent = formatter.format(new Date(timeElement.dateTime));
  }
}

function getFormatter(format) {
  switch (format) {
    case 'date':
      return dateFormatter;
    case 'short-date':
      return shortDateFormatter;
    case 'date-time':
      return dateTimeFormatter;
    default:
      throw new Error('Unknown format');
  }
}