How to perform advanced date sorting with M column type- Cloud

Overview

The recommended date format type to use for sorting dates is the M column type. The support for M type date sorting is built-in including multiple language support and does not require any additional server installation.

How to know if the M column type is available in my Confluence instance

In the macro browser, search for the Table Plus macro and find the Column types parameter. If M is listed in the help text, then it is available for use. See Column types for more information.

Acknowledgement

Advanced date sorting support with the M column type is provided using Javascript with the help of the Moment.js library (open source, MIT license). A summary of the relevant parts of the Moment.js documentation is repeated here.

Automatic support

On specifying just the M column type, default date parsing recognizes a number of common date formats including those recognized by the browser specific Javascript implementation. However, there can be browser specific inconsistencies. The following ISO-8601 formats are recognized consistently across browsers:

User-specified formats

On specifying a format string following the M column type, a specific date format can be handled. Construct the date format string from the set of format tokens.

Non-alphanumeric characters

Non-alphanumeric characters are ignored, so, for this example, both of the following are treated the same with the MM-DD-YYYY format:

12-25-1995
12/25/1995

Similarly, formats can be specified with or with non-alphanumeric separators. However, using separators helps with readability.

Format tokens 

See the Moment.js documentation for further information.

TokenDescription
M, MMMonth Number (1 - 12)
MMM, MMMMMonth Name (In current language)
D, DDDay of month
DDD, DDDDDay of year
d, dd, ddd, dddd

Day of week

The input for these tokens is ignored, as there are 4-5 weeks in a month, and it would be impossible to get the day of the month based off the day of the week.

YY2 digit year (if greater than 68, returns 1900's; else, 2000's)
YYYY4 digit year
a, AAM/PM
H, HH24 hour time
h, hh12 hour time (use in conjunction with a or A)
m, mmMinutes
s, ssSeconds
SDeciseconds (1/10th of a second)
SSCentiseconds (1/100th of a second)
SSSMilliseconds (1/1000th of a second)
Z, ZZTimezone offset as +07:00 or +0700
XUnix timestamp

Language support (i18n)

When the date format contains any other language words, the appropriate language must be indicated. English (US) is the default if nothing is specified. The language is specified by following the M with (language indicator) prior to the format string.

Examples

  • M(de)YYYY-MMM-DD for a German date: 2013-Mrz-10
  • M(fr) for a French date: Janv 10, 2013

Supported languages

Click the link, in the following list of languages supported by the Moment.js library, to get the details of the specific localization:

Log a request with our support team.

Confluence®, Jira®, Atlassian Bamboo®, Bitbucket®, Fisheye®, and Atlassian Crucible® are registered trademarks of Atlassian®
Copyright © 2005 - 2024 Appfire | All rights reserved. Appfire™, the 'Apps for makers™' slogan and Bob Swift Atlassian Apps™ are all trademarks of Appfire Technologies, LLC.