npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

ember-dayjs

v0.12.3

Published

day.js template helpers and a service for Ember.

Downloads

4,661

Readme

ember-dayjs

day.js template helpers and a service for Ember. Nearly drop-in replacement for ember-moment. Just replace all moment- with dayjs- and try.

Compatibility

  • Ember.js v3.28 or above
  • Embroider or ember-auto-import v2

Installation

ember install ember-dayjs

Usage

Helpers

dayjs

{{dayjs <date>}}

| Parameters | Values | | ---------- | -------------------------------------------------------------------------------------------------------------------------------------------- | | <date> | Any value(s) interpretable as a date/time by dayjs (a date String or a Dayjs or a Date...) |

Returns a Dayjs.

{{utc <date>}}
{{utc}}

| Parameters | Values | | ---------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | | <date> | Any value(s) interpretable as a date/time by dayjs (a date String or a Dayjs or a Date...) |

Returns a Dayjs with UTC mode set.

Example

{{utc '2001-10-31T08:24:56'}}
{{! Wed Oct 31 2001 08:24:56 GMT+0000 }}
{{utc}}
{{! current time utc, like Mon Feb 12 2018 20:33:08 GMT+0000 }}
{{utc (dayjs '2018-01-01T00:00:00+01:00' 'YYYY-MM-DD HH:mm:ssZ')}}
{{! Sun Dec 31 2017 23:00:00 GMT+0000 }}

dayjs-format

{{dayjs-format <date> [outputFormat=dayjs.defaultFormat] [<inputFormat>] [<advanced>]}}

| Parameters | Values | | -------------- | -------------------------------------------------------------------------------------------------------------------------------------------- | | <date> | Any value(s) interpretable as a date/time by dayjs (a date String or a Dayjs or a Date...) | | outputFormat | An optional date/time String output format, defaults to dayjs.defaultFormat | | inputFormat | An optional named argument for date/time String input format | | advanced | Pass true to be able to use advanced format |

Example

{{dayjs-format '12-1995-25' 'MM/DD/YYYY' inputFormat='MM-YYYY-DD'}}
{{! 25/12/1995 }}

timezone

{{dayjs-tz <date> [timeZone]}}

| Parameters | Values | | ------------ | -------------------------------------------------------------------------------------------------------------------------------------------- | | <date> | Any value(s) interpretable as a date/time by dayjs (a date String or a Dayjs or a Date...) | | <timeZone> | Optional: Time Zone Name Ex: America/Los_Angeles |

Returns a Dayjs corresponding to the <timestamp>.

Examples

{{dayjs-tz '2014-06-01 12:00' 'America/Los_Angeles'}}

dayjs-from / dayjs-from-now

{{dayjs-from <dateA> [<dateB>] [hideAffix=false]}}
{{dayjs-from-now <dateA> [hideAffix=false]}}

| Parameters | Values | | ----------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------- | | <dateA> | Any value(s) interpretable as a date/time by dayjs (a date String or a Dayjs or a Date...) | | <dateB> | An optional value(s) interpretable as a date/time by dayjs (a date String or a Dayjs or a Date...), defaults to now | | hideAffix | An optional Boolean to hide the relative prefix/suffix not. |

Returns the time between <dateA> and <dateB> relative to <dateB>. See dayjs#from.

Examples

{{! in January 2018 at time of writing }}
{{dayjs-from '2995-12-25'}}
{{! in 978 years }}
{{dayjs-from-now '2995-12-25'}}
{{! in 978 years }}
{{dayjs-from '1995-12-25' '2995-12-25' hideAffix=true}}
{{! 1000 years }}

dayjs-to / dayjs-to-now

{{dayjs-to <dateA> [<dateB>] [hideAffix=false]}}
{{dayjs-to-now <dateA> [hideAffix=false]}}

| Parameters | Values | | ----------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------- | | <dateA> | Any value(s) interpretable as a date/time by dayjs (a date String or a Dayjs or a Date...) | | <dateB> | An optional value(s) interpretable as a date/time by dayjs (a date String or a Dayjs or a Date...), defaults to now | | hideAffix | An optional Boolean to hide the relative prefix/suffix or not. |

Returns the time between <dateA> and <dateB> relative to <dateA>. See dayjs#to.

Note that dayjs-to-now is just a more verbose dayjs-to without dateB. You don't need to use it anymore.

Examples

{{! in January 2018 at time of writing }}
{{dayjs-to '2995-12-25'}}
{{! 978 years ago }}
{{dayjs-to '1995-12-25' '2995-12-25'}}
{{! in 1000 years }}
{{dayjs-to-now '1995-12-25' hideAffix=true}}
{{! 22 years }}

dayjs-duration

{{dayjs-duration <number> [<units>]}}

| Parameters | Values | | ---------- | ------------------------------------------------------------------------------------------------------------------------- | | <number> | Any value(s) interpretable as a duration by dayjs (typically a Number in milliseconds) | | <units> | An optional String to specify the units of <number> (typically 'seconds', 'minutes', 'hours'...) |

Examples

{{dayjs-duration 100}}
{{! duration object }}
{{dayjs-duration 24 'hours'}}
{{! duration object }}

dayjs-duration-humanize

{{dayjs-duration-humanize <number> [<units>]}}

| Parameters | Values | | ---------- | ------------------------------------------------------------------------------------------------------------------------- | | <number> | Any value(s) interpretable as a duration by dayjs (typically a Number in milliseconds) | | <units> | An optional String to specify the units of <number> (typically 'seconds', 'minutes', 'hours'...) |

Examples

{{dayjs-duration-humanize 100}}
{{! a few seconds }}
{{dayjs-duration-humanize 24 'hours'}}
{{! a day }}

dayjs-calendar

{{dayjs-calendar <dateA> [<formatHash>]}}

| Parameters | Values | | -------------- | -------------------------------------------------------------------------------------------------------------------------------------------- | | <dateA> | Any value(s) interpretable as a date/time by dayjs (a date String or a Dayjs or a Date...) | | <formatHash> | An optional output format hash, defaults to {} |

Examples

{{! in March 2021 at time of writing }}
{{dayjs-from-now '2021-03-19'}}
{{! 2 days ago }}
{{dayjs-calendar '2021-03-20'}}
{{! Yesterday at 12:00 AM }}

dayjs-diff

{{dayjs-diff <dateA> <dateB> [precision='milliseconds' [float=false]]}}

| Parameters | Values | | ----------- | -------------------------------------------------------------------------------------------------------------------------------------------- | | <dateA> | Any value(s) interpretable as a date/time by dayjs (a date String or a Dayjs or a Date...) | | <dateB> | Any value(s) interpretable as a date/time by dayjs (a date String or a Dayjs or a Date...) | | precision | An optional unit of measurement, defaults to 'milliseconds' | | float | An optional Boolean to get the floating point result, rather than the integer value |

Returns the difference in precision units between <dateA> and <dateB> with floating point accuracy if float is true. See dayjs#diff.

Examples

{{dayjs-diff '2018-01-25' '2018-01-26'}}
{{! 86400000 }}
{{dayjs-diff '2018-01-25' '2018-01-26' precision='years' float=true}}
{{! 0.0026881720430107525 }}

dayjs-add

{{dayjs-add <date> <number> [precision='milliseconds']}}

| Parameters | Values | | ----------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | | <date> | An optional value interpretable as a date/time by dayjs (a date String or a Dayjs or a Date...). Defaults to value of dayjs() | | <number> | Any value(s) interpretable as a duration by dayjs that is the amount of the precision you want to add to the date provided | | precision | An optional unit of measurement, defaults to 'milliseconds' |

Mutates the original dayjs by adding time. See dayjs#add.

Examples

{{! Add 6 days to a date }}
{{dayjs-add '10-19-2019' 6 precision='days'}}

{{! Add 6 days to a date }}
{{dayjs-add '10-19-2019' (dayjs-duration (hash days=6))}}

{{! Print a date 6 days from now }}
{{dayjs-add 6 precision='days'}}

dayjs-subtract

{{dayjs-subtract <date> <number> [precision='milliseconds']}}

| Parameters | Values | | ----------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | | <date> | An optional value interpretable as a date/time by dayjs (a date String or a Dayjs or a Date...). Defaults to value of dayjs() | | <number> | Any value(s) interpretable as a duration by dayjs that is the amount of the precision you want to subtract from the date provided | | precision | An optional unit of measurement, defaults to 'milliseconds' |

Mutates the original dayjs by removing time. See dayjs#subtract.

Examples

{{! Remove 6 days from a date }}
{{dayjs-subtract '10-19-2019' 6 precision='days'}}

{{! Remove 6 days from a date }}
{{dayjs-subtract '10-19-2019' (dayjs-duration (hash days=6))}}

{{! Print a date 6 days earlier }}
{{dayjs-subtract 6 precision='days'}}

dayjs-is-before / dayjs-is-after / dayjs-is-same / dayjs-is-same-or-before / dayjs-is-same-or-after

{{dayjs-is-before <dateA> [<dateB>] [precision='milliseconds']}}
{{dayjs-is-after <dateA> [<dateB>] [precision='milliseconds']}}
{{dayjs-is-same <dateA> [<dateB>] [precision='milliseconds']}}
{{dayjs-is-same-or-before <dateA> [<dateB>] [precision='milliseconds']}}
{{dayjs-is-same-or-after <dateA> [<dateB>] [precision='milliseconds']}}

| Parameters | Values | | ----------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | | <dateA> | Any value(s) interpretable as a date/time by dayjs (a date String or a Dayjs or a Date...) | | <dateB> | An optional value(s) interpretable as a date/time by dayjs (a date String or a Dayjs or a Date...). If not given, <dateA> becomes now and <dateB> becomes <dateA> | | precision | An optional String unit of comparison precision, defaults to 'milliseconds' |

Returns a Boolean that indicates if <dateA> is respectively before/after/the same/same or before/ same or after <dateB> to the precision level. See dayjs#queries.

Examples

{{dayjs-is-before '2995-12-25'}}
{{! false }}
{{dayjs-is-before '2018-01-25' '2018-01-26' precision='years'}}
{{! false }}
{{dayjs-is-same-or-after '2018-01-25' '2018-01-26' precision='years'}}
{{! true }}

is-between

{{dayjs-is-between <date> <dateA> [<dateB>] [precision='year' inclusivity='[)']}}

| Parameters | Values | | ------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | | <date> | Any value(s) interpretable as a date/time by dayjs (a date String or a Dayjs or a Date...) | | <dateA> | A boundary value(s) interpretable as a date/time by dayjs (a date String or a Dayjs or a Date...) | | <dateB> | An optional boundary value(s) interpretable as a date/time by dayjs (a date String or a Dayjs or a Date...). If not given <date> is assigned now, <dateA> is assigned <date> and <dateB> is assigned <dateA>. | | precision | An optional String unit of comparison precision, defaults to 'milliseconds' | | inclusivity | An optional String indicating inclusivity of the boundaries, defaults to () |

Returns a Boolean that indicates if <date> is between <dateA> and <dateB> to the precision level and with boundary inclusions specified by inclusivity. See dayjs#is-between.

Examples

{{dayjs-is-between '1995-12-25' '2995-12-25'}}
{{! true }}
{{dayjs-is-between
  '1995-12-25'
  '1995-12-25'
  '2995-12-25'
  precision='years'
  inclusivity='()'
}}
{{! true }}

now

{{now}}
{{dayjs-format (now) 'MM-DD-YYYY'}}

Returns the present Dayjs.

Examples

{{now}}
{{! Current Date Time }}
{{now interval=1000}}
{{! <current date and updating every 1-second (1000 milliseconds).> }}

unix

{{unix <timestamp>}}

| Parameters | Values | | ------------- | ---------------------------------------------------------------------------------------------------------------- | | <timestamp> | An integer Number value representing the number of milliseconds since the Unix Epoch (January 1 1970 12AM UTC) |

Returns a Dayjs corresponding to the <timestamp>.

Examples

{{unix 1548381600000}}
{{! Thursday, 26 January 2023 19:11:32 }}
{{! Warning: The passing argument must be a number }}
{{unix '1548381600000'}}
{{! Invalid date }}

Common optional named arguments

All helpers accept the following optional named arguments (even though they are not always applicable):

| Parameters | Values | | ---------- | -------------------------------------------------------------------------------------------- | | locale | An optional String locale, to override the default global dayjs.locale | | interval | An optional interval Number of milliseconds when the helper should be recomputed |

Examples

{{now interval=1000}}
{{! <current date and updating every 1-second (1000 milliseconds)> }}
{{dayjs-is-before (now) '2018-01-26' interval=60000}}
{{! if this was true initially, it will always be true despite interval }}

Configure default runtime locale/timeZone

Globally set locale

import Controller from '@ember/controller';
import { action } from '@ember/object';
import { inject as service } from '@ember/service';

export default class ApplicationController extends Controller {
  @service dayjs;

  @action
  changeLanguage(locale) {
    this.dayjs.setLocale(locale); // tr
  }
}

Globally set time zone

import Controller from '@ember/controller';
import { action } from '@ember/object';
import { inject as service } from '@ember/service';

export default class ApplicationController extends Controller {
  @service dayjs;

  @action
  changeTimeZone(timeZone) {
    this.dayjs.setTimeZone(timeZone); // 'America/Los_Angeles'
  }
}

Reset time zone

import Controller from '@ember/controller';
import { action } from '@ember/object';
import { inject as service } from '@ember/service';

export default class ApplicationController extends Controller {
  @service dayjs;

  @action
  resetTimezone() {
    this.dayjs.resetTimezone();
  }
}

Contributing

See the Contributing guide for details.

License

This project is licensed under the MIT License.