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

axiros-datetime-picker

v13.0.2

Published

Angular 13 compatible date time picker

Downloads

85

Readme

Angular Date Time Picker

npm npm

Angular date time picker - Angular reusable UI component with support for Angular 12+

Description

This is the modified version of date time picker package Angular Date Time Picker. In a nutshell this library is date time picker, that can work in single / range modes. There are two modes for picker UI - dialog and popup menu, so feel free to try it in your desktops, tablets and mobile devices.

The difference from original library - I have updated dependencies to Angular 11, did some refactoring and added native parsing of en-GB date format.

Online docs for original library is here. Demo page is here.

How to Use

  1. Install with npm:npm install axiros-datetime-picker --save

  2. Add styles. If you are using Angular CLI, you can add this to your styles.css:

    @import "~axiros-datetime-picker/assets/style/picker.min.css";

    If you are not using the Angular CLI, you can include the picker.min.css via a <link> element in your index.html.

  3. Add OwlDateTimeModule and OwlNativeDateTimeModule to your @NgModule like example below

     import { NgModule } from '@angular/core';
     import { BrowserModule } from '@angular/platform-browser';
     import { MyTestApp } from './my-test-app';
       
     import { OwlDateTimeModule, OwlNativeDateTimeModule } from 'axiros-datetime-picker';
       
     @NgModule({
         imports: [ 
             BrowserModule, 
             OwlDateTimeModule, 
             OwlNativeDateTimeModule,
         ],
         declarations: [ MyTestApp ],
         bootstrap:    [ MyTestApp ]
     })
     export class MyTestAppModule {}

    Also it is important to define date format that will be displayed in Input form. In the module add provider:

    providers: [
        { provide: OWL_DATE_TIME_FORMATS, useValue: MY_NATIVE_FORMATS },
    ],

    you can define any format for date, in my example i use:

    export const MY_NATIVE_FORMATS = {
        fullPickerInput: { year: 'numeric', month: '2-digit', day: '2-digit', hour: '2-digit', minute: '2-digit', hour12: false },
        datePickerInput: { year: 'numeric', month: 'numeric', day: 'numeric' },
        timePickerInput: { hour: 'numeric', minute: 'numeric' },
        monthYearLabel: { year: 'numeric', month: 'short' },
        dateA11yLabel: { year: 'numeric', month: 'long', day: 'numeric' },
        monthYearA11yLabel: { year: 'numeric', month: 'long' },
    };
  4. Connecting a picker to an input and a trigger.

    <input
        [owlDateTime]="dt1"
        [owlDateTimeTrigger]="dt1"
        placeholder="Date Time">
    <owl-date-time #dt1></owl-date-time>
    <input
        [owlDateTime]="dt2"
        placeholder="Date Time">
    <span
        [owlDateTimeTrigger]="dt2">
        <i class="fa fa-calendar"></i>
    </span>
    <owl-date-time #dt2></owl-date-time>

    The examples above are quite basic. The picker has much more features, and you could learn more about those from demo page.

    In addition, this is ngx-formly implementation

    import {Component, ElementRef, ViewChild} from '@angular/core';
    import {FieldType} from '@ngx-formly/material';
    import {DateTimeAdapter} from 'axiros-datetime-picker';
       
    @Component({
        selector: 'app-datetime-picker',
        styleUrls: ['./formly-datetime-picker.component.scss'],
        template: `
            <div fxLayout="row">
                <!--INPUT WITH PICKER TOGGLE-->
                <ng-container *ngIf="!to.showOpenPickerButton else withoutButton">
                    <input
                        #dateTimeInputWithoutButton
                        matInput
                        [formControl]="formControl"
                        [formlyAttributes]="field"
                        [owlDateTime]="dt"
                        [errorStateMatcher]="errorStateMatcher"
                        [owlDateTimeTrigger]="dt"
                    />
                </ng-container>
                <!--INPUT WITHOUT PICKER TOGGLE-->
                <ng-template #withoutButton>
                    <!--INPUT AREA-->
                    <input
                        #dateTimeInputWithButton
                        matInput
                        [formControl]="formControl"
                        [formlyAttributes]="field"
                        [owlDateTime]="dt"
                        [errorStateMatcher]="errorStateMatcher"
                    />
                </ng-template>
       
                <!--NULLIFY VALUE BUTTON-->
                <button mat-icon-button
                        [disabled]="to.disabled"
                        (click)="formControl.setValue(null)"
                        color="warn"
                        class="action-button">
                    <mat-icon>close</mat-icon>
                </button>
       
                <ng-container *ngIf="to.showOpenPickerButton">
                    <!--OPEN PICKER BUTTON-->
                    <button mat-icon-button
                            class="action-button"
                            fxFlex="0 1 auto"
                            [color]="'primary'"
                            [owlDateTimeTrigger]="dt"
                            matTooltip="Open date time picker"
                            [matTooltipPosition]="'below'">
                        <mat-icon>event_note</mat-icon>
                    </button>
                </ng-container>
       
                <!--DATE TIME PICKER-->
                <owl-date-time
                    #dt
                    [pickerMode]="'dialog'">
                </owl-date-time>
            </div>
        `
    })
    export class FormlyDatetimePickerComponent extends FieldType {
        constructor(
            dateTimeAdapter: DateTimeAdapter<any>,
        ) {
            super();
            dateTimeAdapter.setLocale('en-GB');
        }
       
        /**
         * reference to input with button
         */
        @ViewChild('dateTimeInputWithButton', { read: ElementRef, static: false }) dateTimeInputWithButton: ElementRef;
       
        /**
         * reference to input without button
         */
        @ViewChild('dateTimeInputWithoutButton', { read: ElementRef, static: false }) dateTimeInputWithoutButton: ElementRef;
       
        // @ts-ignore
        get empty() {
            // get input element
            const element = this.to.showOpenPickerButton ? this.dateTimeInputWithButton : this.dateTimeInputWithoutButton;
       
            // empty if input element is empty and picker value is empty
            return (element && !element.nativeElement.value) && (this.value == null || this.value === '');
        }
    }

Animation

This picker uses angular animations to improve the user experience, therefore you need to install @angular/animations and import BrowserAnimationsModule to your application.

npm install @angular/animations --save
import {BrowserModule} from '@angular/platform-browser';
import {BrowserAnimationsModule} from '@angular/platform-browser/animations';

@NgModule({
    imports: [
        BrowserModule,
        BrowserAnimationsModule,
        //...
    ],
    //...
})
export class YourAppModule { }

If you prefer to disable animation effect, use NoopAnimationsModule instead.

Choose a date implementation

The date-time picker was built to be date implementation agnostic. Developers need to make sure to provide the appropriate pieces for the picker to work with their chosen implementation. There are two pre-made modules, users need to import one of them or build your own one (learn more about this from here).

  • OwlNativeDateTimeModule - support for native JavaScript Date object
  • OwlMomentDateTimeModule - support for MomentJs

Properties for owl-date-time

|Name|Type|Required|Default|Description| |:--- |:--- |:--- |:--- |:--- | |pickerType|both, calendar, timer|Optional|both| Set the type of the dateTime picker. both: show both calendar and timer, calendar: only show calendar, timer: only show timer. | |pickerMode|popup, dialog|Optional|popup| The style the picker would open as. | |startView|month, year, multi-year|Optional|month| The view that the calendar should start in. | |startAt| T/null |Optional|null| The moment to open the picker to initially. | |firstDayOfWeek|number|Optional|0| Set the first day of week. Valid value is from 0 to 6. 0: Sunday ~ 6: Saturday| |showSecondsTimer|boolean|Optional|false| When specify it to true, it would show a timer to configure the second's value | |hideOtherMonths|boolean|Optional|false| Whether to hide dates in other months at the start or end of the current month | |hour12Timer|boolean|Optional|false| When specify it to true, the timer would be in hour12 format mode| |stepHour|number|Optional|1| Hours to change per step.| |stepMinute|number|Optional|1| Minutes to change per step.| |stepSecond|number|Optional|1| Seconds to change per step.| |scrollStrategy|ScrollStrategy|Optional|BlockScrollStrategy| Define the scroll strategy when the picker is open. Learn more this from https://material.angular.io/cdk/overlay/overview#scroll-strategies.| |disabled|boolean|Optional|false|When specify to true, it would disable the picker.| |backdropClass|string/string[]|Optional|null|Custom class for the picker backdrop.| |panelClass|string/string[]|Optional|null|Custom class for the picker overlay panel.|

Events for owl-date-time

|Events|Parameter|Description| |:--- |:--- |:--- | |afterPickerOpen|null|Callback to invoke when the picker is opened| |afterPickerClosed|null|Callback to invoke when the picker is closed.| |yearSelected|T|Callback to invoke when the year is selected.This doesn't imply a change on the selected date.| |monthSelected|T|Callback to invoke when the month is selected.This doesn't imply a change on the selected date.|

Properties for input[owlDateTime]

|Name|Type|Required|Default|Description| |:--- |:--- |:--- |:--- |:--- | |owlDateTime|OwlDateTimeComponent<T>|Require|null| The date time picker that this input is associated with.| |owlDateTimeFilter|( date: T)=>boolean |Optional|null|A function to filter date time.| |disabled|boolean|Optional|false|When specify to true, it would disable the picker's input.| |min|<T>|Optional|null| The minimum valid date time.| |max|<T>|Optional|null| The maximum valid date time.| |selectMode|single, range, rangeFrom, rangeTo|Optional|single| Specify the picker's select mode. single: a single value allowed, range: allow users to select a range of date-time, rangeFrom: the input would only show the 'from' value and the picker could only selects 'from' value, rangeTo: the input would only show the 'to' value and the picker could only selects 'to' value.| |rangeSeparator|string|Optional|~| The character to separate the 'from' and 'to' in input value in range selectMode.|

Events for input[owlDateTime]

|Events|Parameter|Description| |:--- |:--- |:--- | |dateTimeChange|source: OwlDateTimeInput, value: input value, input: the input element|Callback to invoke when change event is fired on this <input [owlDateTime]>| |dateTimeInput|source: OwlDateTimeInput, value: input value, input: the input element|Callback to invoke when an input event is fired on this <input [owlDateTime]>.|

Properties for [owlDateTimeTrigger]

|Name|Type|Required|Default|Description| |:--- |:--- |:--- |:--- |:--- | |owlDateTimeTrigger|OwlDateTimeComponent<T>|Require|null| The date time picker that this trigger is associated with.| |disabled|boolean|Optional|false|When specify to true, it would disable the trigger.|

Properties for [owlDateTimeTrigger]

|Name|Type|Required|Default|Description| |:--- |:--- |:--- |:--- |:--- | |owlDateTimeTrigger|OwlDateTimeComponent<T>|Require|null| The date time picker that this trigger is associated with.| |disabled|boolean|Optional|false|When specify to true, it would disable the trigger.|

Properties for owl-date-time-inline

|Name|Type|Required|Default|Description| |:--- |:--- |:--- |:--- |:--- | |pickerType|both, calendar, timer|Optional|both| Set the type of the dateTime picker. both: show both calendar and timer, calendar: only show calendar, timer: only show timer. | |startView|month, year, multi-year|Optional|month| The view that the calendar should start in. | |startAt| T/null |Optional|null| The moment to open the picker to initially. | |firstDayOfWeek|number|Optional|0| Set the first day of week. Valid value is from 0 to 6. 0: Sunday ~ 6: Saturday| |showSecondsTimer|boolean|Optional|false| When specify it to true, it would show a timer to configure the second's value | |hideOtherMonths|boolean|Optional|false| Whether to hide dates in other months at the start or end of the current month | |hour12Timer|boolean|Optional|false| When specify it to true, the timer would be in hour12 format mode| |stepHour|number|Optional|1| Hours to change per step.| |stepMinute|number|Optional|1| Minutes to change per step.| |stepSecond|number|Optional|1| Seconds to change per step.| |disabled|boolean|Optional|false|When specify to true, it would disable the picker.| |owlDateTimeFilter|( date: T)=>boolean |Optional|null|A function to filter date time.| |min|<T>|Optional|null| The minimum valid date time.| |max|<T>|Optional|null| The maximum valid date time.| |selectMode|single, range, rangeFrom, rangeTo|Optional|single| Specify the picker's select mode. single: a single value allowed, range: allow users to select a range of date-time, rangeFrom: the input would only show the 'from' value and the picker could only selects 'from' value, rangeTo: the input would only show the 'to' value and the picker could only selects 'to' value.|

Localization and DateTime Format

Localization for different languages and formats is defined by OWL_DATE_TIME_LOCALE and OWL_DATE_TIME_FORMATS. You could learn more about this from here.

Dependencies

none

License

  • License: MIT

Author

Original library author - Daniel YK Pan