@tuhinkarmakar/relative-time
v1.0.1
Published
A relative time formatter for Angular.
Downloads
8
Maintainers
Readme
ng-relative-time
A simple relative time formatter for Angular. Uses bleeding-edge formatting APIs for headache-free internationalization.
Table of Contents
Features
- Internationalization: Formats strings using the browser's locale. Uses built-in browser APIs for internationalization. No setup required. The heavy-lifting is done by the browser.
- Time Travelling Formatter: The formatter works with both past and future timestamps.
Installation
Run npm i @tuhinkarmakar/relative-time
to install library into your project.
Usage
- First import the
RelativeTimeModule
in your root module.
import { BrowserModule } from "@angular/platform-browser"
import { NgModule } from "@angular/core"
import { RelativeTimeModule } from "@tuhinkarmakar/relative-time" // <-- Import the module like this
import { AppComponent } from "./app.component"
@NgModule({
declarations: [AppComponent],
imports: [BrowserModule, RelativeTimeModule], // <-- Add it to the imports array
providers: [],
bootstrap: [AppComponent],
})
export class AppModule {}
- Use the
relativeTime
pipe with a datetime string accepted by theDate()
constructor. See Date.parse() MDN page for supported formats.
{{ timestamp | relativeTime }} // Output: yesterday / tomorrow / 5 seconds ago / in 5 months etc.
Browser Support
Since the library uses Intl.RelativeTimeFormat
, it only works on Google Chrome 71+ and Mozilla Firefox 65+.
Browser support will get better as more vendors start implmenting the proposal.
See this MDN page for details.
Task List
- [ ] Add supoort for Schemantics
- [ ] Add a declaration file for
Intl.RelativeTimeFormat
Contributing
Report bugs and share enhancement ideas here. PRs are also welcome.