Latest Threat Research:SANDWORM_MODE: Shai-Hulud-Style npm Worm Hijacks CI Workflows and Poisons AI Toolchains.Details
Socket
Book a DemoInstallSign in
Socket

angularx-flatpickr

Package Overview
Dependencies
Maintainers
1
Versions
29
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

angularx-flatpickr - npm Package Compare versions

Comparing version
7.3.0
to
8.0.0
+5
esm2022/angularx-flatpickr.mjs
/**
* Generated bundle index. Do not edit.
*/
export * from './public-api';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhcngtZmxhdHBpY2tyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhcngtZmxhdHBpY2tyL3NyYy9hbmd1bGFyeC1mbGF0cGlja3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==
import { Injectable } from '@angular/core';
import * as i0 from "@angular/core";
export class FlatpickrDefaults {
constructor() {
/**
* Exactly the same as date format, but for the altInput field.
*/
this.altFormat = 'F j, Y';
/**
* Show the user a readable date (as per altFormat), but return something totally different to the server.
*/
this.altInput = false;
/**
* This class will be added to the input element created by the altInput option.
* Note that `altInput` already inherits classes from the original input.
*/
this.altInputClass = '';
/**
* Allows the user to enter a date directly input the input field. By default, direct entry is disabled.
*/
this.allowInput = false;
/**
* Allows the preloading of an invalid date. When disabled, the field will be cleared if the provided date is invalid
*/
this.allowInvalidPreload = false;
/**
* Instead of `body`, appends the calendar to the specified node instead.
*/
this.appendTo = undefined;
/**
* Defines how the date will be formatted in the aria-label for calendar days, using the same tokens as dateFormat. If you change this, you should choose a value that will make sense if a screen reader reads it out loud.
*/
this.ariaDateFormat = 'F j, Y';
/**
* Whether clicking on the input should open the picker.
* You could disable this if you wish to open the calendar manually `with.open()`.
*/
this.clickOpens = true;
/**
* A string of characters which are used to define how the date will be displayed in the input box.
* The supported characters are defined in the table below.
*/
this.dateFormat = 'Y-m-d';
/**
* Initial value of the hour element.
*/
this.defaultHour = 12;
/**
* Initial value of the minute element.
*/
this.defaultMinute = 0;
/**
* Initial value of the seconds element.
*/
this.defaultSeconds = 0;
/**
* See <a href="https://chmln.github.io/flatpickr/examples/#disabling-specific-dates">disabling dates</a>.
*/
this.disable = [];
/**
* Set disableMobile to true to always use the non-native picker.
* By default, Flatpickr utilizes native datetime widgets unless certain options (e.g. disable) are used.
*/
this.disableMobile = false;
/**
* Enables time picker.
*/
this.enableTime = false;
/**
* Enables seconds in the time picker.
*/
this.enableSeconds = false;
/**
* Allows using a custom date formatting function instead of the built-in handling for date formats using dateFormat, altFormat, etc.
*/
this.formatDate = undefined;
/**
* Adjusts the step for the hour input (incl. scrolling).
*/
this.hourIncrement = 1;
/**
* Displays the calendar inline.
*/
this.inline = false;
/**
* The maximum date that a user can pick to (inclusive).
*/
this.maxDate = undefined;
/**
* The minimum date that a user can start picking from (inclusive).
*/
this.minDate = undefined;
/**
* The maximum time that a user can pick to (inclusive).
*/
this.maxTime = undefined;
/**
* The minimum time that a user can start picking from (inclusive).
*/
this.minTime = undefined;
/**
* Adjusts the step for the minute input (incl. scrolling).
*/
this.minuteIncrement = 5;
/**
* Select a single date, multiple dates or a date range.
*/
this.mode = 'single';
/**
* HTML for the arrow icon, used to switch months.
*/
this.nextArrow = '>';
/**
* Hides the day selection in calendar. Use it along with `enableTime` to create a time picker.
*/
this.noCalendar = false;
/**
* Default now to the current date
*/
this.now = new Date();
/**
* HTML for the left arrow icon.
*/
this.prevArrow = '<';
/**
* Show the month using the shorthand version (ie, Sep instead of September).
*/
this.shorthandCurrentMonth = false;
/**
* Position the calendar inside the wrapper and next to the input element. (Leave `false` unless you know what you're doing).
*/
this.static = false;
/**
* Displays time picker in 24 hour mode without AM/PM selection when enabled.
*/
this.time24hr = false;
/**
* When true, dates will parsed, formatted, and displayed in UTC.
* It's recommended that date strings contain the timezone, but not necessary.
*/
this.utc = false;
/**
* Enables display of week numbers in calendar.
*/
this.weekNumbers = false;
/**
* Custom elements and input groups.
*/
this.wrap = false;
/**
* Array of plugin instances to use.
*/
this.plugins = [];
/**
* The locale object or string to use for the locale.
*/
this.locale = 'default';
/**
* Auto convert the ngModel value from a string to a date / array of dates / from - to date object depending on the `mode`
*/
this.convertModelValue = false;
/**
* The number of months shown.
*/
this.showMonths = 1;
/**
* How the month should be displayed in the header of the calendar.
*/
this.monthSelectorType = 'static';
/**
* Array of HTML elements that should not close the picker on click.
*/
this.ignoredFocusElements = [];
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FlatpickrDefaults, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FlatpickrDefaults }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FlatpickrDefaults, decorators: [{
type: Injectable
}] });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"flatpickr-defaults.service.js","sourceRoot":"","sources":["../../../../projects/angularx-flatpickr/src/lib/flatpickr-defaults.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;;AAwO3C,MAAM,OAAO,iBAAiB;IAD9B;QAEE;;WAEG;QACH,cAAS,GAAW,QAAQ,CAAC;QAE7B;;WAEG;QACH,aAAQ,GAAY,KAAK,CAAC;QAE1B;;;WAGG;QACH,kBAAa,GAAW,EAAE,CAAC;QAE3B;;WAEG;QACH,eAAU,GAAY,KAAK,CAAC;QAE5B;;WAEG;QACH,wBAAmB,GAAY,KAAK,CAAC;QAErC;;WAEG;QACH,aAAQ,GAA4B,SAAS,CAAC;QAE9C;;WAEG;QACH,mBAAc,GAAY,QAAQ,CAAC;QAEnC;;;WAGG;QACH,eAAU,GAAY,IAAI,CAAC;QAE3B;;;WAGG;QACH,eAAU,GAAW,OAAO,CAAC;QAE7B;;WAEG;QACH,gBAAW,GAAY,EAAE,CAAC;QAE1B;;WAEG;QACH,kBAAa,GAAY,CAAC,CAAC;QAE3B;;WAEG;QACH,mBAAc,GAAY,CAAC,CAAC;QAE5B;;WAEG;QACH,YAAO,GAAwB,EAAE,CAAC;QAElC;;;WAGG;QACH,kBAAa,GAAY,KAAK,CAAC;QAO/B;;WAEG;QACH,eAAU,GAAY,KAAK,CAAC;QAE5B;;WAEG;QACH,kBAAa,GAAY,KAAK,CAAC;QAE/B;;WAEG;QACH,eAAU,GAA4B,SAAS,CAAC;QAEhD;;WAEG;QACH,kBAAa,GAAW,CAAC,CAAC;QAE1B;;WAEG;QACH,WAAM,GAAY,KAAK,CAAC;QAExB;;WAEG;QACH,YAAO,GAA8B,SAAS,CAAC;QAE/C;;WAEG;QACH,YAAO,GAA8B,SAAS,CAAC;QAE/C;;WAEG;QACH,YAAO,GAAuB,SAAS,CAAC;QAExC;;WAEG;QACH,YAAO,GAAuB,SAAS,CAAC;QAExC;;WAEG;QACH,oBAAe,GAAW,CAAC,CAAC;QAE5B;;WAEG;QACH,SAAI,GAAoC,QAAQ,CAAC;QAEjD;;WAEG;QACH,cAAS,GAAW,GAAG,CAAC;QAExB;;WAEG;QACH,eAAU,GAAY,KAAK,CAAC;QAE5B;;WAEG;QACH,QAAG,GAA2B,IAAI,IAAI,EAAE,CAAC;QAOzC;;WAEG;QACH,cAAS,GAAW,GAAG,CAAC;QAExB;;WAEG;QACH,0BAAqB,GAAY,KAAK,CAAC;QAEvC;;WAEG;QACH,WAAM,GAAY,KAAK,CAAC;QAExB;;WAEG;QACH,aAAQ,GAAY,KAAK,CAAC;QAE1B;;;WAGG;QACH,QAAG,GAAY,KAAK,CAAC;QAErB;;WAEG;QACH,gBAAW,GAAY,KAAK,CAAC;QAQ7B;;WAEG;QACH,SAAI,GAAY,KAAK,CAAC;QAEtB;;WAEG;QACH,YAAO,GAAU,EAAE,CAAC;QAEpB;;WAEG;QACH,WAAM,GAAoB,SAAS,CAAC;QAEpC;;WAEG;QACH,sBAAiB,GAAY,KAAK,CAAC;QAEnC;;WAEG;QACH,eAAU,GAAW,CAAC,CAAC;QAEvB;;WAEG;QACH,sBAAiB,GAA0B,QAAQ,CAAC;QAEpD;;WAEG;QACH,yBAAoB,GAAkB,EAAE,CAAC;KAC1C;+GAlOY,iBAAiB;mHAAjB,iBAAiB;;4FAAjB,iBAAiB;kBAD7B,UAAU","sourcesContent":["import { Injectable } from '@angular/core';\n\nexport type DisableEnableDate =\n  | string\n  | Date\n  | { from: Date | string; to: Date | string }\n  | ((date: Date) => boolean);\n\nexport interface FlatpickrDefaultsInterface {\n  /**\n   * Exactly the same as date format, but for the altInput field.\n   */\n  altFormat?: string;\n\n  /**\n   * \tShow the user a readable date (as per altFormat), but return something totally different to the server.\n   */\n  altInput?: boolean;\n\n  /**\n   * This class will be added to the input element created by the altInput option.\n   * Note that `altInput` already inherits classes from the original input.\n   */\n  altInputClass?: string;\n\n  /**\n   * Allows the user to enter a date directly input the input field. By default, direct entry is disabled.\n   */\n  allowInput?: boolean;\n\n  /**\n   * Allows the preloading of an invalid date. When disabled, the field will be cleared if the provided date is invalid\n   */\n  allowInvalidPreload?: boolean;\n\n  /**\n   * Instead of `body`, appends the calendar to the specified node instead.\n   */\n  appendTo?: HTMLElement;\n\n  /**\n   * Defines how the date will be formatted in the aria-label for calendar days, using the same tokens as dateFormat. If you change this, you should choose a value that will make sense if a screen reader reads it out loud.\n   */\n  ariaDateFormat?: string;\n\n  /**\n   * Whether clicking on the input should open the picker.\n   * You could disable this if you wish to open the calendar manually `with.open()`.\n   */\n  clickOpens?: boolean;\n\n  /**\n   * A string of characters which are used to define how the date will be displayed in the input box.\n   * The supported characters are defined in the table below.\n   */\n  dateFormat?: string;\n  /**\n   * Initial value of the hour element.\n   */\n  defaultHour?: number;\n  /**\n   * Initial value of the minute element.\n   */\n  defaultMinute?: number;\n  /**\n   * Initial value of the seconds element.\n   */\n  defaultSeconds?: number;\n\n  /**\n   * See <a href=\"https://chmln.github.io/flatpickr/examples/#disabling-specific-dates\">disabling dates</a>.\n   */\n  disable?: DisableEnableDate[];\n\n  /**\n   * Set disableMobile to true to always use the non-native picker.\n   * By default, Flatpickr utilizes native datetime widgets unless certain options (e.g. disable) are used.\n   */\n  disableMobile?: boolean;\n\n  /**\n   * See <a href=\"https://chmln.github.io/flatpickr/examples/#disabling-all-dates-except-select-few\">enabling dates</a>.\n   */\n  enable?: DisableEnableDate[];\n\n  /**\n   * Enables time picker.\n   */\n  enableTime?: boolean;\n\n  /**\n   * Enables seconds in the time picker.\n   */\n  enableSeconds?: boolean;\n  /**\n   * Allows using a custom date formatting function instead of the built-in handling for date formats using dateFormat, altFormat, etc.\n   */\n  formatDate?: (value: any) => string;\n  /**\n   * Adjusts the step for the hour input (incl. scrolling).\n   */\n  hourIncrement?: number;\n\n  /**\n   * Displays the calendar inline.\n   */\n  inline?: boolean;\n\n  /**\n   * The maximum date that a user can pick to (inclusive).\n   */\n  maxDate?: string | Date;\n\n  /**\n   * The minimum date that a user can start picking from (inclusive).\n   */\n  minDate?: string | Date;\n\n  /**\n   * The maximum time that a user can pick to (inclusive).\n   */\n  maxTime?: string;\n\n  /**\n   * The minimum time that a user can start picking from (inclusive).\n   */\n  minTime?: string;\n\n  /**\n   * Adjusts the step for the minute input (incl. scrolling).\n   */\n  minuteIncrement?: number;\n\n  /**\n   * Select a single date, multiple dates or a date range.\n   */\n  mode?: 'single' | 'multiple' | 'range';\n\n  /**\n   * HTML for the arrow icon, used to switch months.\n   */\n  nextArrow?: string;\n\n  /**\n   * Hides the day selection in calendar. Use it along with `enableTime` to create a time picker.\n   */\n  noCalendar?: boolean;\n\n  /**\n   * Provide a date for 'today', which will be used instead of \"new Date()\"\n   */\n  now?: Date | string | number;\n\n  /**\n   * Function that expects a date string and must return a Date object.\n   */\n  parseDate?: (str: string) => Date;\n\n  /**\n   * HTML for the left arrow icon.\n   */\n  prevArrow?: string;\n\n  /**\n   * Show the month using the shorthand version (ie, Sep instead of September).\n   */\n  shorthandCurrentMonth?: boolean;\n\n  /**\n   * Position the calendar inside the wrapper and next to the input element. (Leave `false` unless you know what you're doing).\n   */\n  static?: boolean;\n\n  /**\n   * Displays time picker in 24 hour mode without AM/PM selection when enabled.\n   */\n  time24hr?: boolean;\n\n  /**\n   * When true, dates will parsed, formatted, and displayed in UTC.\n   * It's recommended that date strings contain the timezone, but not necessary.\n   */\n  utc?: boolean;\n\n  /**\n   * Enables display of week numbers in calendar.\n   */\n  weekNumbers?: boolean;\n\n  /**\n   * You may override the function that extracts the week numbers from a Date by supplying a getWeek function.\n   * It takes in a date as a parameter and should return a corresponding string that you want to appear left of every week.\n   */\n  getWeek?: (date: Date) => string;\n\n  /**\n   * Custom elements and input groups.\n   */\n  wrap?: boolean;\n\n  /**\n   * Array of plugin instances to use.\n   */\n  plugins?: any[];\n\n  /**\n   * The locale object or string to use for the locale.\n   */\n  locale?: object | string;\n\n  /**\n   * Auto convert the ngModel value from a string to a date / array of dates / from - to date object depending on the `mode`\n   */\n  convertModelValue?: boolean;\n\n  /**\n   * The number of months shown.\n   */\n  showMonths?: number;\n\n  /**\n   * How the month should be displayed in the header of the calendar.\n   */\n  monthSelectorType?: 'static' | 'dropdown';\n\n  /**\n   * Array of HTML elements that should not close the picker on click.\n   */\n  ignoredFocusElements?: HTMLElement[];\n}\n\n@Injectable()\nexport class FlatpickrDefaults implements FlatpickrDefaultsInterface {\n  /**\n   * Exactly the same as date format, but for the altInput field.\n   */\n  altFormat: string = 'F j, Y';\n\n  /**\n   * \tShow the user a readable date (as per altFormat), but return something totally different to the server.\n   */\n  altInput: boolean = false;\n\n  /**\n   * This class will be added to the input element created by the altInput option.\n   * Note that `altInput` already inherits classes from the original input.\n   */\n  altInputClass: string = '';\n\n  /**\n   * Allows the user to enter a date directly input the input field. By default, direct entry is disabled.\n   */\n  allowInput: boolean = false;\n\n  /**\n   * Allows the preloading of an invalid date. When disabled, the field will be cleared if the provided date is invalid\n   */\n  allowInvalidPreload: boolean = false;\n\n  /**\n   * Instead of `body`, appends the calendar to the specified node instead.\n   */\n  appendTo: HTMLElement | undefined = undefined;\n\n  /**\n   * Defines how the date will be formatted in the aria-label for calendar days, using the same tokens as dateFormat. If you change this, you should choose a value that will make sense if a screen reader reads it out loud.\n   */\n  ariaDateFormat?: string = 'F j, Y';\n\n  /**\n   * Whether clicking on the input should open the picker.\n   * You could disable this if you wish to open the calendar manually `with.open()`.\n   */\n  clickOpens: boolean = true;\n\n  /**\n   * A string of characters which are used to define how the date will be displayed in the input box.\n   * The supported characters are defined in the table below.\n   */\n  dateFormat: string = 'Y-m-d';\n\n  /**\n   * Initial value of the hour element.\n   */\n  defaultHour?: number = 12;\n\n  /**\n   * Initial value of the minute element.\n   */\n  defaultMinute?: number = 0;\n\n  /**\n   * Initial value of the seconds element.\n   */\n  defaultSeconds?: number = 0;\n\n  /**\n   * See <a href=\"https://chmln.github.io/flatpickr/examples/#disabling-specific-dates\">disabling dates</a>.\n   */\n  disable: DisableEnableDate[] = [];\n\n  /**\n   * Set disableMobile to true to always use the non-native picker.\n   * By default, Flatpickr utilizes native datetime widgets unless certain options (e.g. disable) are used.\n   */\n  disableMobile: boolean = false;\n\n  /**\n   * See <a href=\"https://chmln.github.io/flatpickr/examples/#disabling-all-dates-except-select-few\">enabling dates</a>.\n   */\n  enable: DisableEnableDate[];\n\n  /**\n   * Enables time picker.\n   */\n  enableTime: boolean = false;\n\n  /**\n   * Enables seconds in the time picker.\n   */\n  enableSeconds: boolean = false;\n\n  /**\n   * Allows using a custom date formatting function instead of the built-in handling for date formats using dateFormat, altFormat, etc.\n   */\n  formatDate?: (value: any) => string = undefined;\n\n  /**\n   * Adjusts the step for the hour input (incl. scrolling).\n   */\n  hourIncrement: number = 1;\n\n  /**\n   * Displays the calendar inline.\n   */\n  inline: boolean = false;\n\n  /**\n   * The maximum date that a user can pick to (inclusive).\n   */\n  maxDate: string | Date | undefined = undefined;\n\n  /**\n   * The minimum date that a user can start picking from (inclusive).\n   */\n  minDate: string | Date | undefined = undefined;\n\n  /**\n   * The maximum time that a user can pick to (inclusive).\n   */\n  maxTime: string | undefined = undefined;\n\n  /**\n   * The minimum time that a user can start picking from (inclusive).\n   */\n  minTime: string | undefined = undefined;\n\n  /**\n   * Adjusts the step for the minute input (incl. scrolling).\n   */\n  minuteIncrement: number = 5;\n\n  /**\n   * Select a single date, multiple dates or a date range.\n   */\n  mode: 'single' | 'multiple' | 'range' = 'single';\n\n  /**\n   * HTML for the arrow icon, used to switch months.\n   */\n  nextArrow: string = '>';\n\n  /**\n   * Hides the day selection in calendar. Use it along with `enableTime` to create a time picker.\n   */\n  noCalendar: boolean = false;\n\n  /**\n   * Default now to the current date\n   */\n  now: Date | string | number = new Date();\n\n  /**\n   * Function that expects a date string and must return a Date object.\n   */\n  parseDate: (str: string) => Date;\n\n  /**\n   * HTML for the left arrow icon.\n   */\n  prevArrow: string = '<';\n\n  /**\n   * Show the month using the shorthand version (ie, Sep instead of September).\n   */\n  shorthandCurrentMonth: boolean = false;\n\n  /**\n   * Position the calendar inside the wrapper and next to the input element. (Leave `false` unless you know what you're doing).\n   */\n  static: boolean = false;\n\n  /**\n   * Displays time picker in 24 hour mode without AM/PM selection when enabled.\n   */\n  time24hr: boolean = false;\n\n  /**\n   * When true, dates will parsed, formatted, and displayed in UTC.\n   * It's recommended that date strings contain the timezone, but not necessary.\n   */\n  utc: boolean = false;\n\n  /**\n   * Enables display of week numbers in calendar.\n   */\n  weekNumbers: boolean = false;\n\n  /**\n   * You may override the function that extracts the week numbers from a Date by supplying a getWeek function.\n   * It takes in a date as a parameter and should return a corresponding string that you want to appear left of every week.\n   */\n  getWeek: (date: Date) => string;\n\n  /**\n   * Custom elements and input groups.\n   */\n  wrap: boolean = false;\n\n  /**\n   * Array of plugin instances to use.\n   */\n  plugins: any[] = [];\n\n  /**\n   * The locale object or string to use for the locale.\n   */\n  locale: object | string = 'default';\n\n  /**\n   * Auto convert the ngModel value from a string to a date / array of dates / from - to date object depending on the `mode`\n   */\n  convertModelValue: boolean = false;\n\n  /**\n   * The number of months shown.\n   */\n  showMonths: number = 1;\n\n  /**\n   * How the month should be displayed in the header of the calendar.\n   */\n  monthSelectorType: 'static' | 'dropdown' = 'static';\n\n  /**\n   * Array of HTML elements that should not close the picker on click.\n   */\n  ignoredFocusElements: HTMLElement[] = [];\n}\n"]}
import { Directive, Input, Output, EventEmitter, forwardRef, HostListener, PLATFORM_ID, Inject, } from '@angular/core';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
import flatpickr from 'flatpickr';
import { isPlatformBrowser } from '@angular/common';
import * as i0 from "@angular/core";
import * as i1 from "./flatpickr-defaults.service";
export const FLATPICKR_CONTROL_VALUE_ACCESSOR = {
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(() => FlatpickrDirective),
multi: true,
};
export class FlatpickrDirective {
constructor(elm, defaults, renderer, platformId) {
this.elm = elm;
this.defaults = defaults;
this.renderer = renderer;
this.platformId = platformId;
/**
* Object-options that can be user for multiple instances of Flatpickr.
* Option from this object is applied only if specific option is not specified.
* Example:
* ```typescript
* options: FlatpickrDefaultsInterface = {
* altFormat: 'd/m/Y', // will be ignored since altFormat is provided via specific attribute
* altInput: true // will be used since specific attribute is not provided
* };
* ```
* ```html
* <input
* class="form-control"
* type="text"
* mwlFlatpickr
* [options]="options"
* altFormat="d/m/Y">
* ```
*/
this.options = {};
/**
* Array of HTML elements that should not close the picker on click.
*/
this.ignoredFocusElements = [];
/**
* Gets triggered once the calendar is in a ready state
*/
this.flatpickrReady = new EventEmitter();
/**
* Gets triggered when the user selects a date, or changes the time on a selected date.
*/
this.flatpickrChange = new EventEmitter();
/**
* Gets triggered when the input value is updated with a new date string.
*/
this.flatpickrValueUpdate = new EventEmitter();
/**
* Gets triggered when the calendar is opened.
*/
this.flatpickrOpen = new EventEmitter();
/**
* Gets triggered when the calendar is closed.
*/
this.flatpickrClose = new EventEmitter();
/**
* Gets triggered when the month is changed, either by the user or programmatically.
*/
this.flatpickrMonthChange = new EventEmitter();
/**
* Gets triggered when the year is changed, either by the user or programmatically.
*/
this.flatpickrYearChange = new EventEmitter();
/**
* Take full control of every date cell with this output
*/
this.flatpickrDayCreate = new EventEmitter();
this.isDisabled = false;
this.onChangeFn = () => { };
this.onTouchedFn = () => { };
}
ngAfterViewInit() {
const options = {
altFormat: this.altFormat,
altInput: this.altInput,
altInputClass: this.altInputClass,
allowInput: this.allowInput,
allowInvalidPreload: this.allowInvalidPreload,
appendTo: this.appendTo,
ariaDateFormat: this.ariaDateFormat,
clickOpens: this.clickOpens,
dateFormat: this.dateFormat,
defaultHour: this.defaultHour,
defaultMinute: this.defaultMinute,
defaultSeconds: this.defaultSeconds,
disable: this.disable,
disableMobile: this.disableMobile,
enable: this.enable,
enableTime: this.enableTime,
enableSeconds: this.enableSeconds,
formatDate: this.formatDate,
hourIncrement: this.hourIncrement,
defaultDate: this.initialValue,
inline: this.inline,
maxDate: this.maxDate,
minDate: this.minDate,
maxTime: this.maxTime,
minTime: this.minTime,
minuteIncrement: this.minuteIncrement,
mode: this.mode,
nextArrow: this.nextArrow,
noCalendar: this.noCalendar,
now: this.now,
parseDate: this.parseDate,
prevArrow: this.prevArrow,
shorthandCurrentMonth: this.shorthandCurrentMonth,
showMonths: this.showMonths,
monthSelectorType: this.monthSelectorType,
static: this.static,
time24hr: this.time24hr,
weekNumbers: this.weekNumbers,
getWeek: this.getWeek,
wrap: this.wrap,
plugins: this.plugins,
locale: this.locale,
ignoredFocusElements: this.ignoredFocusElements,
onChange: (selectedDates, dateString, instance) => {
this.flatpickrChange.emit({ selectedDates, dateString, instance });
},
onOpen: (selectedDates, dateString, instance) => {
this.flatpickrOpen.emit({ selectedDates, dateString, instance });
},
onClose: (selectedDates, dateString, instance) => {
this.flatpickrClose.emit({ selectedDates, dateString, instance });
},
onMonthChange: (selectedDates, dateString, instance) => {
this.flatpickrMonthChange.emit({ selectedDates, dateString, instance });
},
onYearChange: (selectedDates, dateString, instance) => {
this.flatpickrYearChange.emit({ selectedDates, dateString, instance });
},
onReady: (selectedDates, dateString, instance) => {
this.flatpickrReady.emit({ selectedDates, dateString, instance });
},
onValueUpdate: (selectedDates, dateString, instance) => {
this.flatpickrValueUpdate.emit({ selectedDates, dateString, instance });
},
onDayCreate: (selectedDates, dateString, instance, dayElement) => {
this.flatpickrDayCreate.emit({
selectedDates,
dateString,
instance,
dayElement,
});
},
};
Object.keys(options).forEach((key) => {
if (typeof options[key] === 'undefined') {
if (typeof this.options[key] !== 'undefined') {
options[key] = this.options[key];
}
else {
options[key] = this.defaults[key];
}
}
});
// @ts-ignore
options.time_24hr = options.time24hr;
// workaround bug in flatpickr 4.6 where it doesn't copy the classes across
// TODO - remove once fix in https://github.com/flatpickr/flatpickr/issues/1860 is released
options.altInputClass =
(options.altInputClass || '') + ' ' + this.elm.nativeElement.className;
if (!options.enable) {
delete options.enable;
}
if (isPlatformBrowser(this.platformId)) {
this.instance = flatpickr(this.elm.nativeElement, options);
this.setDisabledState(this.isDisabled);
}
}
ngOnChanges(changes) {
if (this.instance) {
Object.keys(changes).forEach((inputKey) => {
this.instance.set(inputKey, this[inputKey]);
});
}
}
ngOnDestroy() {
if (this.instance) {
this.instance.destroy();
}
}
writeValue(value) {
let convertedValue = value;
if (this.convertModelValue && this.mode === 'range' && value) {
convertedValue = [value.from, value.to];
}
if (this.instance) {
this.instance.setDate(convertedValue);
}
else {
// flatpickr hasn't been initialised yet, store the value for later use
this.initialValue = convertedValue;
}
}
registerOnChange(fn) {
this.onChangeFn = fn;
}
registerOnTouched(fn) {
this.onTouchedFn = fn;
}
setDisabledState(isDisabled) {
this.isDisabled = isDisabled;
if (this.instance) {
if (this.isDisabled) {
this.renderer.setProperty(this.instance._input, 'disabled', 'disabled');
}
else {
this.renderer.removeAttribute(this.instance._input, 'disabled');
}
}
}
inputChanged() {
const value = this.elm.nativeElement.value;
if (this.convertModelValue && typeof value === 'string') {
switch (this.mode) {
case 'multiple':
const dates = value
.split('; ')
.map((str) => this.instance.parseDate(str, this.instance.config.dateFormat, !this.instance.config.enableTime));
this.onChangeFn(dates);
break;
case 'range':
const [from, to] = value
.split(this.instance.l10n.rangeSeparator)
.map((str) => this.instance.parseDate(str, this.instance.config.dateFormat, !this.instance.config.enableTime));
this.onChangeFn({ from, to });
break;
case 'single':
default:
this.onChangeFn(this.instance.parseDate(value, this.instance.config.dateFormat, !this.instance.config.enableTime));
}
}
else {
this.onChangeFn(value);
}
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FlatpickrDirective, deps: [{ token: i0.ElementRef }, { token: i1.FlatpickrDefaults }, { token: i0.Renderer2 }, { token: PLATFORM_ID }], target: i0.ɵɵFactoryTarget.Directive }); }
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.12", type: FlatpickrDirective, selector: "[mwlFlatpickr]", inputs: { options: "options", altFormat: "altFormat", altInput: "altInput", altInputClass: "altInputClass", allowInput: "allowInput", allowInvalidPreload: "allowInvalidPreload", appendTo: "appendTo", ariaDateFormat: "ariaDateFormat", clickOpens: "clickOpens", dateFormat: "dateFormat", defaultHour: "defaultHour", defaultMinute: "defaultMinute", defaultSeconds: "defaultSeconds", disable: "disable", disableMobile: "disableMobile", enable: "enable", enableTime: "enableTime", enableSeconds: "enableSeconds", formatDate: "formatDate", hourIncrement: "hourIncrement", inline: "inline", maxDate: "maxDate", minDate: "minDate", maxTime: "maxTime", minTime: "minTime", minuteIncrement: "minuteIncrement", mode: "mode", nextArrow: "nextArrow", noCalendar: "noCalendar", now: "now", parseDate: "parseDate", prevArrow: "prevArrow", shorthandCurrentMonth: "shorthandCurrentMonth", showMonths: "showMonths", static: "static", time24hr: "time24hr", weekNumbers: "weekNumbers", getWeek: "getWeek", wrap: "wrap", plugins: "plugins", locale: "locale", convertModelValue: "convertModelValue", monthSelectorType: "monthSelectorType", ignoredFocusElements: "ignoredFocusElements" }, outputs: { flatpickrReady: "flatpickrReady", flatpickrChange: "flatpickrChange", flatpickrValueUpdate: "flatpickrValueUpdate", flatpickrOpen: "flatpickrOpen", flatpickrClose: "flatpickrClose", flatpickrMonthChange: "flatpickrMonthChange", flatpickrYearChange: "flatpickrYearChange", flatpickrDayCreate: "flatpickrDayCreate" }, host: { listeners: { "blur": "onTouchedFn()", "input": "inputChanged()" } }, providers: [FLATPICKR_CONTROL_VALUE_ACCESSOR], exportAs: ["mwlFlatpickr"], usesOnChanges: true, ngImport: i0 }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FlatpickrDirective, decorators: [{
type: Directive,
args: [{
selector: '[mwlFlatpickr]',
providers: [FLATPICKR_CONTROL_VALUE_ACCESSOR],
exportAs: 'mwlFlatpickr',
}]
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.FlatpickrDefaults }, { type: i0.Renderer2 }, { type: Object, decorators: [{
type: Inject,
args: [PLATFORM_ID]
}] }], propDecorators: { options: [{
type: Input
}], altFormat: [{
type: Input
}], altInput: [{
type: Input
}], altInputClass: [{
type: Input
}], allowInput: [{
type: Input
}], allowInvalidPreload: [{
type: Input
}], appendTo: [{
type: Input
}], ariaDateFormat: [{
type: Input
}], clickOpens: [{
type: Input
}], dateFormat: [{
type: Input
}], defaultHour: [{
type: Input
}], defaultMinute: [{
type: Input
}], defaultSeconds: [{
type: Input
}], disable: [{
type: Input
}], disableMobile: [{
type: Input
}], enable: [{
type: Input
}], enableTime: [{
type: Input
}], enableSeconds: [{
type: Input
}], formatDate: [{
type: Input
}], hourIncrement: [{
type: Input
}], inline: [{
type: Input
}], maxDate: [{
type: Input
}], minDate: [{
type: Input
}], maxTime: [{
type: Input
}], minTime: [{
type: Input
}], minuteIncrement: [{
type: Input
}], mode: [{
type: Input
}], nextArrow: [{
type: Input
}], noCalendar: [{
type: Input
}], now: [{
type: Input
}], parseDate: [{
type: Input
}], prevArrow: [{
type: Input
}], shorthandCurrentMonth: [{
type: Input
}], showMonths: [{
type: Input
}], static: [{
type: Input
}], time24hr: [{
type: Input
}], weekNumbers: [{
type: Input
}], getWeek: [{
type: Input
}], wrap: [{
type: Input
}], plugins: [{
type: Input
}], locale: [{
type: Input
}], convertModelValue: [{
type: Input
}], monthSelectorType: [{
type: Input
}], ignoredFocusElements: [{
type: Input
}], flatpickrReady: [{
type: Output
}], flatpickrChange: [{
type: Output
}], flatpickrValueUpdate: [{
type: Output
}], flatpickrOpen: [{
type: Output
}], flatpickrClose: [{
type: Output
}], flatpickrMonthChange: [{
type: Output
}], flatpickrYearChange: [{
type: Output
}], flatpickrDayCreate: [{
type: Output
}], onTouchedFn: [{
type: HostListener,
args: ['blur']
}], inputChanged: [{
type: HostListener,
args: ['input']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"flatpickr.directive.js","sourceRoot":"","sources":["../../../../projects/angularx-flatpickr/src/lib/flatpickr.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  AfterViewInit,\n  Input,\n  Output,\n  EventEmitter,\n  OnChanges,\n  SimpleChanges,\n  OnDestroy,\n  forwardRef,\n  HostListener,\n  Renderer2,\n  PLATFORM_ID,\n  Inject,\n} from '@angular/core';\nimport {\n  FlatpickrDefaults,\n  DisableEnableDate,\n  FlatpickrDefaultsInterface,\n} from './flatpickr-defaults.service';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport flatpickr from 'flatpickr';\nimport { isPlatformBrowser } from '@angular/common';\n\nexport interface FlatPickrOutputOptions {\n  selectedDates: Date[];\n  dateString: string;\n  instance: any;\n}\n\nexport interface FlatPickrDayCreateOutputOptions\n  extends FlatPickrOutputOptions {\n  dayElement: HTMLElement;\n}\n\nexport const FLATPICKR_CONTROL_VALUE_ACCESSOR: any = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => FlatpickrDirective),\n  multi: true,\n};\n\n@Directive({\n  selector: '[mwlFlatpickr]',\n  providers: [FLATPICKR_CONTROL_VALUE_ACCESSOR],\n  exportAs: 'mwlFlatpickr',\n})\nexport class FlatpickrDirective\n  implements AfterViewInit, OnChanges, OnDestroy, ControlValueAccessor\n{\n  /**\n   * Object-options that can be user for multiple instances of Flatpickr.\n   * Option from this object is applied only if specific option is not specified.\n   * Example:\n   * ```typescript\n   * options: FlatpickrDefaultsInterface = {\n   *      altFormat: 'd/m/Y',   // will be ignored since altFormat is provided via specific attribute\n   *      altInput: true        // will be used since specific attribute is not provided\n   * };\n   * ```\n   * ```html\n   * <input\n   *   class=\"form-control\"\n   *   type=\"text\"\n   *   mwlFlatpickr\n   *   [options]=\"options\"\n   *   altFormat=\"d/m/Y\">\n   * ```\n   */\n  @Input() options: FlatpickrDefaultsInterface = {};\n\n  /**\n   * Exactly the same as date format, but for the altInput field.\n   */\n  @Input() altFormat: string;\n\n  /**\n   * \tShow the user a readable date (as per altFormat), but return something totally different to the server.\n   */\n  @Input() altInput: boolean;\n\n  /**\n   * This class will be added to the input element created by the altInput option.\n   * Note that `altInput` already inherits classes from the original input.\n   */\n  @Input() altInputClass: string;\n\n  /**\n   * Allows the user to enter a date directly input the input field. By default, direct entry is disabled.\n   */\n  @Input() allowInput: boolean;\n\n  /**\n   * Allows the preloading of an invalid date. When disabled, the field will be cleared if the provided date is invalid\n   */\n  @Input() allowInvalidPreload: boolean;\n\n  /**\n   * Instead of `body`, appends the calendar to the specified node instead.\n   */\n  @Input() appendTo: HTMLElement;\n\n  /**\n   * Defines how the date will be formatted in the aria-label for calendar days, using the same tokens as dateFormat. If you change this, you should choose a value that will make sense if a screen reader reads it out loud.\n   */\n  @Input() ariaDateFormat?: string;\n\n  /**\n   * Whether clicking on the input should open the picker.\n   * You could disable this if you wish to open the calendar manually `with.open()`.\n   */\n  @Input() clickOpens: boolean;\n\n  /**\n   * A string of characters which are used to define how the date will be displayed in the input box.\n   * The supported characters are defined in the table below.\n   */\n  @Input() dateFormat: string;\n\n  /**\n   * Initial value of the hour element.\n   */\n  @Input() defaultHour?: number;\n  /**\n   * Initial value of the minute element.\n   */\n  @Input() defaultMinute?: number;\n\n  /**\n   * Initial value of the seconds element.\n   */\n  @Input() defaultSeconds?: number;\n\n  /**\n   * See <a href=\"https://chmln.github.io/flatpickr/examples/#disabling-specific-dates\">disabling dates</a>.\n   */\n  @Input() disable: DisableEnableDate[];\n\n  /**\n   * Set disableMobile to true to always use the non-native picker.\n   * By default, Flatpickr utilizes native datetime widgets unless certain options (e.g. disable) are used.\n   */\n  @Input() disableMobile: boolean;\n\n  /**\n   * See <a href=\"https://chmln.github.io/flatpickr/examples/#disabling-all-dates-except-select-few\">enabling dates</a>.\n   */\n  @Input() enable: DisableEnableDate[];\n\n  /**\n   * Enables time picker.\n   */\n  @Input() enableTime: boolean;\n\n  /**\n   * Enables seconds in the time picker.\n   */\n  @Input() enableSeconds: boolean;\n\n  /**\n   * Allows using a custom date formatting function instead of the built-in handling for date formats using dateFormat, altFormat, etc.\n   */\n  @Input() formatDate?: (value: any) => string;\n\n  /**\n   * Adjusts the step for the hour input (incl. scrolling).\n   */\n  @Input() hourIncrement: number;\n\n  /**\n   * Displays the calendar inline.\n   */\n  @Input() inline: boolean;\n\n  /**\n   * The maximum date that a user can pick to (inclusive).\n   */\n  @Input() maxDate: string | Date;\n\n  /**\n   * The minimum date that a user can start picking from (inclusive).\n   */\n  @Input() minDate: string | Date;\n\n  /**\n   * The maximum time that a user can pick to (inclusive).\n   */\n  @Input() maxTime: string;\n\n  /**\n   * The minimum time that a user can start picking from (inclusive).\n   */\n  @Input() minTime: string;\n\n  /**\n   * Adjusts the step for the minute input (incl. scrolling).\n   */\n  @Input() minuteIncrement: number;\n\n  /**\n   * Select a single date, multiple dates or a date range.\n   */\n  @Input() mode: 'single' | 'multiple' | 'range';\n\n  /**\n   * HTML for the arrow icon, used to switch months.\n   */\n  @Input() nextArrow: string;\n\n  /**\n   * Hides the day selection in calendar. Use it along with `enableTime` to create a time picker.\n   */\n  @Input() noCalendar: boolean;\n\n  /**\n   * Provide a date for 'today', which will be used instead of \"new Date()\"\n   */\n  @Input() now?: Date | string | number;\n\n  /**\n   * Function that expects a date string and must return a Date object.\n   */\n  @Input() parseDate: (str: string) => Date;\n\n  /**\n   * HTML for the left arrow icon.\n   */\n  @Input() prevArrow: string;\n\n  /**\n   * Show the month using the shorthand version (ie, Sep instead of September).\n   */\n  @Input() shorthandCurrentMonth: boolean;\n\n  /**\n   * The number of months shown.\n   */\n  @Input() showMonths: number;\n\n  /**\n   * Position the calendar inside the wrapper and next to the input element. (Leave `false` unless you know what you're doing).\n   */\n  @Input() static: boolean;\n\n  /**\n   * Displays time picker in 24 hour mode without AM/PM selection when enabled.\n   */\n  @Input() time24hr: boolean;\n\n  /**\n   * Enables display of week numbers in calendar.\n   */\n  @Input() weekNumbers: boolean;\n\n  /**\n   * You may override the function that extracts the week numbers from a Date by supplying a getWeek function.\n   * It takes in a date as a parameter and should return a corresponding string that you want to appear left of every week.\n   */\n  @Input() getWeek: (date: Date) => string;\n\n  /**\n   * Custom elements and input groups.\n   */\n  @Input() wrap: boolean;\n\n  /**\n   * Array of plugin instances to use.\n   */\n  @Input() plugins: any[];\n\n  /**\n   * The locale object or string to use for the locale.\n   */\n  @Input() locale: object | string;\n\n  /**\n   * Auto convert the ngModel value from a string to a date / array of dates / from - to date object depending on the `mode`\n   */\n  @Input() convertModelValue: boolean;\n\n  /**\n   * How the month should be displayed in the header of the calendar.\n   */\n  @Input() monthSelectorType: 'static' | 'dropdown';\n\n  /**\n   * Array of HTML elements that should not close the picker on click.\n   */\n  @Input() ignoredFocusElements: HTMLElement[] = [];\n\n  /**\n   * Gets triggered once the calendar is in a ready state\n   */\n  @Output()\n  flatpickrReady: EventEmitter<FlatPickrOutputOptions> = new EventEmitter();\n\n  /**\n   * Gets triggered when the user selects a date, or changes the time on a selected date.\n   */\n  @Output()\n  flatpickrChange: EventEmitter<FlatPickrOutputOptions> = new EventEmitter();\n\n  /**\n   * Gets triggered when the input value is updated with a new date string.\n   */\n  @Output()\n  flatpickrValueUpdate: EventEmitter<FlatPickrOutputOptions> =\n    new EventEmitter();\n\n  /**\n   * Gets triggered when the calendar is opened.\n   */\n  @Output()\n  flatpickrOpen: EventEmitter<FlatPickrOutputOptions> = new EventEmitter();\n\n  /**\n   * Gets triggered when the calendar is closed.\n   */\n  @Output()\n  flatpickrClose: EventEmitter<FlatPickrOutputOptions> = new EventEmitter();\n\n  /**\n   * Gets triggered when the month is changed, either by the user or programmatically.\n   */\n  @Output()\n  flatpickrMonthChange: EventEmitter<FlatPickrOutputOptions> =\n    new EventEmitter();\n\n  /**\n   * Gets triggered when the year is changed, either by the user or programmatically.\n   */\n  @Output()\n  flatpickrYearChange: EventEmitter<FlatPickrOutputOptions> =\n    new EventEmitter();\n\n  /**\n   * Take full control of every date cell with this output\n   */\n  @Output()\n  flatpickrDayCreate: EventEmitter<FlatPickrDayCreateOutputOptions> =\n    new EventEmitter();\n\n  /**\n   * The flatpickr instance where you can call methods like toggle(), open(), close() etc\n   */\n  instance: flatpickr.Instance;\n\n  private isDisabled = false;\n  private initialValue: any;\n\n  onChangeFn: (value: any) => void = () => {};\n\n  @HostListener('blur')\n  onTouchedFn = () => {};\n\n  constructor(\n    private elm: ElementRef,\n    private defaults: FlatpickrDefaults,\n    private renderer: Renderer2,\n    @Inject(PLATFORM_ID) private platformId: Object,\n  ) {}\n\n  ngAfterViewInit(): void {\n    const options: any = {\n      altFormat: this.altFormat,\n      altInput: this.altInput,\n      altInputClass: this.altInputClass,\n      allowInput: this.allowInput,\n      allowInvalidPreload: this.allowInvalidPreload,\n      appendTo: this.appendTo,\n      ariaDateFormat: this.ariaDateFormat,\n      clickOpens: this.clickOpens,\n      dateFormat: this.dateFormat,\n      defaultHour: this.defaultHour,\n      defaultMinute: this.defaultMinute,\n      defaultSeconds: this.defaultSeconds,\n      disable: this.disable,\n      disableMobile: this.disableMobile,\n      enable: this.enable,\n      enableTime: this.enableTime,\n      enableSeconds: this.enableSeconds,\n      formatDate: this.formatDate,\n      hourIncrement: this.hourIncrement,\n      defaultDate: this.initialValue,\n      inline: this.inline,\n      maxDate: this.maxDate,\n      minDate: this.minDate,\n      maxTime: this.maxTime,\n      minTime: this.minTime,\n      minuteIncrement: this.minuteIncrement,\n      mode: this.mode,\n      nextArrow: this.nextArrow,\n      noCalendar: this.noCalendar,\n      now: this.now,\n      parseDate: this.parseDate,\n      prevArrow: this.prevArrow,\n      shorthandCurrentMonth: this.shorthandCurrentMonth,\n      showMonths: this.showMonths,\n      monthSelectorType: this.monthSelectorType,\n      static: this.static,\n      time24hr: this.time24hr,\n      weekNumbers: this.weekNumbers,\n      getWeek: this.getWeek,\n      wrap: this.wrap,\n      plugins: this.plugins,\n      locale: this.locale,\n      ignoredFocusElements: this.ignoredFocusElements,\n      onChange: (selectedDates: Date[], dateString: string, instance: any) => {\n        this.flatpickrChange.emit({ selectedDates, dateString, instance });\n      },\n      onOpen: (selectedDates: Date[], dateString: string, instance: any) => {\n        this.flatpickrOpen.emit({ selectedDates, dateString, instance });\n      },\n      onClose: (selectedDates: Date[], dateString: string, instance: any) => {\n        this.flatpickrClose.emit({ selectedDates, dateString, instance });\n      },\n      onMonthChange: (\n        selectedDates: Date[],\n        dateString: string,\n        instance: any,\n      ) => {\n        this.flatpickrMonthChange.emit({ selectedDates, dateString, instance });\n      },\n      onYearChange: (\n        selectedDates: Date[],\n        dateString: string,\n        instance: any,\n      ) => {\n        this.flatpickrYearChange.emit({ selectedDates, dateString, instance });\n      },\n      onReady: (selectedDates: Date[], dateString: string, instance: any) => {\n        this.flatpickrReady.emit({ selectedDates, dateString, instance });\n      },\n      onValueUpdate: (\n        selectedDates: Date[],\n        dateString: string,\n        instance: any,\n      ) => {\n        this.flatpickrValueUpdate.emit({ selectedDates, dateString, instance });\n      },\n      onDayCreate: (\n        selectedDates: Date[],\n        dateString: string,\n        instance: any,\n        dayElement: HTMLElement,\n      ) => {\n        this.flatpickrDayCreate.emit({\n          selectedDates,\n          dateString,\n          instance,\n          dayElement,\n        });\n      },\n    };\n\n    Object.keys(options).forEach((key) => {\n      if (typeof options[key] === 'undefined') {\n        if (typeof (this.options as any)[key] !== 'undefined') {\n          options[key] = (this.options as any)[key];\n        } else {\n          options[key] = (this.defaults as any)[key];\n        }\n      }\n    });\n\n    // @ts-ignore\n    options.time_24hr = options.time24hr;\n\n    // workaround bug in flatpickr 4.6 where it doesn't copy the classes across\n    // TODO - remove once fix in https://github.com/flatpickr/flatpickr/issues/1860 is released\n    options.altInputClass =\n      (options.altInputClass || '') + ' ' + this.elm.nativeElement.className;\n\n    if (!options.enable) {\n      delete options.enable;\n    }\n\n    if (isPlatformBrowser(this.platformId)) {\n      this.instance = flatpickr(\n        this.elm.nativeElement,\n        options,\n      ) as flatpickr.Instance;\n      this.setDisabledState(this.isDisabled);\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (this.instance) {\n      Object.keys(changes).forEach((inputKey) => {\n        this.instance.set(inputKey as any, (this as any)[inputKey]);\n      });\n    }\n  }\n\n  ngOnDestroy(): void {\n    if (this.instance) {\n      this.instance.destroy();\n    }\n  }\n\n  writeValue(value: any): void {\n    let convertedValue: any = value;\n    if (this.convertModelValue && this.mode === 'range' && value) {\n      convertedValue = [value.from, value.to];\n    }\n\n    if (this.instance) {\n      this.instance.setDate(convertedValue);\n    } else {\n      // flatpickr hasn't been initialised yet, store the value for later use\n      this.initialValue = convertedValue;\n    }\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChangeFn = fn;\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.onTouchedFn = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.isDisabled = isDisabled;\n    if (this.instance) {\n      if (this.isDisabled) {\n        this.renderer.setProperty(this.instance._input, 'disabled', 'disabled');\n      } else {\n        this.renderer.removeAttribute(this.instance._input, 'disabled');\n      }\n    }\n  }\n\n  @HostListener('input')\n  inputChanged(): void {\n    const value: string = this.elm.nativeElement.value;\n    if (this.convertModelValue && typeof value === 'string') {\n      switch (this.mode) {\n        case 'multiple':\n          const dates: Array<Date | undefined> = value\n            .split('; ')\n            .map((str) =>\n              this.instance.parseDate(\n                str,\n                this.instance.config.dateFormat,\n                !this.instance.config.enableTime,\n              ),\n            );\n          this.onChangeFn(dates);\n          break;\n\n        case 'range':\n          const [from, to] = value\n            .split(this.instance.l10n.rangeSeparator)\n            .map((str) =>\n              this.instance.parseDate(\n                str,\n                this.instance.config.dateFormat,\n                !this.instance.config.enableTime,\n              ),\n            );\n          this.onChangeFn({ from, to });\n          break;\n\n        case 'single':\n        default:\n          this.onChangeFn(\n            this.instance.parseDate(\n              value,\n              this.instance.config.dateFormat,\n              !this.instance.config.enableTime,\n            ),\n          );\n      }\n    } else {\n      this.onChangeFn(value);\n    }\n  }\n}\n"]}
import { NgModule, InjectionToken, } from '@angular/core';
import { FlatpickrDirective } from './flatpickr.directive';
import { FlatpickrDefaults, } from './flatpickr-defaults.service';
import * as i0 from "@angular/core";
export const USER_DEFAULTS = new InjectionToken('flatpickr defaults');
export function defaultsFactory(userDefaults) {
const defaults = new FlatpickrDefaults();
Object.assign(defaults, userDefaults);
return defaults;
}
export class FlatpickrModule {
static forRoot(userDefaults = {}) {
return {
ngModule: FlatpickrModule,
providers: [
{
provide: USER_DEFAULTS,
useValue: userDefaults,
},
{
provide: FlatpickrDefaults,
useFactory: defaultsFactory,
deps: [USER_DEFAULTS],
},
],
};
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FlatpickrModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.12", ngImport: i0, type: FlatpickrModule, declarations: [FlatpickrDirective], exports: [FlatpickrDirective] }); }
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FlatpickrModule }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FlatpickrModule, decorators: [{
type: NgModule,
args: [{
declarations: [FlatpickrDirective],
exports: [FlatpickrDirective],
}]
}] });
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmxhdHBpY2tyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXJ4LWZsYXRwaWNrci9zcmMvbGliL2ZsYXRwaWNrci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLFFBQVEsRUFFUixjQUFjLEdBRWYsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDM0QsT0FBTyxFQUNMLGlCQUFpQixHQUVsQixNQUFNLDhCQUE4QixDQUFDOztBQUV0QyxNQUFNLENBQUMsTUFBTSxhQUFhLEdBQUcsSUFBSSxjQUFjLENBQUMsb0JBQW9CLENBQUMsQ0FBQztBQUV0RSxNQUFNLFVBQVUsZUFBZSxDQUM3QixZQUF3QztJQUV4QyxNQUFNLFFBQVEsR0FBc0IsSUFBSSxpQkFBaUIsRUFBRSxDQUFDO0lBQzVELE1BQU0sQ0FBQyxNQUFNLENBQUMsUUFBUSxFQUFFLFlBQVksQ0FBQyxDQUFDO0lBQ3RDLE9BQU8sUUFBUSxDQUFDO0FBQ2xCLENBQUM7QUFNRCxNQUFNLE9BQU8sZUFBZTtJQUMxQixNQUFNLENBQUMsT0FBTyxDQUNaLGVBQTJDLEVBQUU7UUFFN0MsT0FBTztZQUNMLFFBQVEsRUFBRSxlQUFlO1lBQ3pCLFNBQVMsRUFBRTtnQkFDVDtvQkFDRSxPQUFPLEVBQUUsYUFBYTtvQkFDdEIsUUFBUSxFQUFFLFlBQVk7aUJBQ3ZCO2dCQUNEO29CQUNFLE9BQU8sRUFBRSxpQkFBaUI7b0JBQzFCLFVBQVUsRUFBRSxlQUFlO29CQUMzQixJQUFJLEVBQUUsQ0FBQyxhQUFhLENBQUM7aUJBQ3RCO2FBQ0Y7U0FDRixDQUFDO0lBQ0osQ0FBQzsrR0FsQlUsZUFBZTtnSEFBZixlQUFlLGlCQUhYLGtCQUFrQixhQUN2QixrQkFBa0I7Z0hBRWpCLGVBQWU7OzRGQUFmLGVBQWU7a0JBSjNCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMsa0JBQWtCLENBQUM7b0JBQ2xDLE9BQU8sRUFBRSxDQUFDLGtCQUFrQixDQUFDO2lCQUM5QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIE5nTW9kdWxlLFxuICBNb2R1bGVXaXRoUHJvdmlkZXJzLFxuICBJbmplY3Rpb25Ub2tlbixcbiAgUHJvdmlkZXIsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRmxhdHBpY2tyRGlyZWN0aXZlIH0gZnJvbSAnLi9mbGF0cGlja3IuZGlyZWN0aXZlJztcbmltcG9ydCB7XG4gIEZsYXRwaWNrckRlZmF1bHRzLFxuICBGbGF0cGlja3JEZWZhdWx0c0ludGVyZmFjZSxcbn0gZnJvbSAnLi9mbGF0cGlja3ItZGVmYXVsdHMuc2VydmljZSc7XG5cbmV4cG9ydCBjb25zdCBVU0VSX0RFRkFVTFRTID0gbmV3IEluamVjdGlvblRva2VuKCdmbGF0cGlja3IgZGVmYXVsdHMnKTtcblxuZXhwb3J0IGZ1bmN0aW9uIGRlZmF1bHRzRmFjdG9yeShcbiAgdXNlckRlZmF1bHRzOiBGbGF0cGlja3JEZWZhdWx0c0ludGVyZmFjZSxcbik6IEZsYXRwaWNrckRlZmF1bHRzIHtcbiAgY29uc3QgZGVmYXVsdHM6IEZsYXRwaWNrckRlZmF1bHRzID0gbmV3IEZsYXRwaWNrckRlZmF1bHRzKCk7XG4gIE9iamVjdC5hc3NpZ24oZGVmYXVsdHMsIHVzZXJEZWZhdWx0cyk7XG4gIHJldHVybiBkZWZhdWx0cztcbn1cblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbRmxhdHBpY2tyRGlyZWN0aXZlXSxcbiAgZXhwb3J0czogW0ZsYXRwaWNrckRpcmVjdGl2ZV0sXG59KVxuZXhwb3J0IGNsYXNzIEZsYXRwaWNrck1vZHVsZSB7XG4gIHN0YXRpYyBmb3JSb290KFxuICAgIHVzZXJEZWZhdWx0czogRmxhdHBpY2tyRGVmYXVsdHNJbnRlcmZhY2UgPSB7fSxcbiAgKTogTW9kdWxlV2l0aFByb3ZpZGVyczxGbGF0cGlja3JNb2R1bGU+IHtcbiAgICByZXR1cm4ge1xuICAgICAgbmdNb2R1bGU6IEZsYXRwaWNrck1vZHVsZSxcbiAgICAgIHByb3ZpZGVyczogW1xuICAgICAgICB7XG4gICAgICAgICAgcHJvdmlkZTogVVNFUl9ERUZBVUxUUyxcbiAgICAgICAgICB1c2VWYWx1ZTogdXNlckRlZmF1bHRzLFxuICAgICAgICB9LFxuICAgICAgICB7XG4gICAgICAgICAgcHJvdmlkZTogRmxhdHBpY2tyRGVmYXVsdHMsXG4gICAgICAgICAgdXNlRmFjdG9yeTogZGVmYXVsdHNGYWN0b3J5LFxuICAgICAgICAgIGRlcHM6IFtVU0VSX0RFRkFVTFRTXSxcbiAgICAgICAgfSxcbiAgICAgIF0sXG4gICAgfTtcbiAgfVxufVxuIl19
/*
* Public API Surface of angularx-flatpickr
*/
export * from './lib/flatpickr.module';
export { FlatpickrDefaults, } from './lib/flatpickr-defaults.service';
export { FlatpickrDirective } from './lib/flatpickr.directive';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXJ4LWZsYXRwaWNrci9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsT0FBTyxFQUNMLGlCQUFpQixHQUVsQixNQUFNLGtDQUFrQyxDQUFDO0FBQzFDLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBhbmd1bGFyeC1mbGF0cGlja3JcbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9mbGF0cGlja3IubW9kdWxlJztcbmV4cG9ydCB7XG4gIEZsYXRwaWNrckRlZmF1bHRzLFxuICBGbGF0cGlja3JEZWZhdWx0c0ludGVyZmFjZSxcbn0gZnJvbSAnLi9saWIvZmxhdHBpY2tyLWRlZmF1bHRzLnNlcnZpY2UnO1xuZXhwb3J0IHsgRmxhdHBpY2tyRGlyZWN0aXZlIH0gZnJvbSAnLi9saWIvZmxhdHBpY2tyLmRpcmVjdGl2ZSc7XG4iXX0=
import * as i0 from '@angular/core';
import { Injectable, forwardRef, EventEmitter, PLATFORM_ID, Directive, Inject, Input, Output, HostListener, InjectionToken, NgModule } from '@angular/core';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
import flatpickr from 'flatpickr';
import { isPlatformBrowser } from '@angular/common';
class FlatpickrDefaults {
constructor() {
/**
* Exactly the same as date format, but for the altInput field.
*/
this.altFormat = 'F j, Y';
/**
* Show the user a readable date (as per altFormat), but return something totally different to the server.
*/
this.altInput = false;
/**
* This class will be added to the input element created by the altInput option.
* Note that `altInput` already inherits classes from the original input.
*/
this.altInputClass = '';
/**
* Allows the user to enter a date directly input the input field. By default, direct entry is disabled.
*/
this.allowInput = false;
/**
* Allows the preloading of an invalid date. When disabled, the field will be cleared if the provided date is invalid
*/
this.allowInvalidPreload = false;
/**
* Instead of `body`, appends the calendar to the specified node instead.
*/
this.appendTo = undefined;
/**
* Defines how the date will be formatted in the aria-label for calendar days, using the same tokens as dateFormat. If you change this, you should choose a value that will make sense if a screen reader reads it out loud.
*/
this.ariaDateFormat = 'F j, Y';
/**
* Whether clicking on the input should open the picker.
* You could disable this if you wish to open the calendar manually `with.open()`.
*/
this.clickOpens = true;
/**
* A string of characters which are used to define how the date will be displayed in the input box.
* The supported characters are defined in the table below.
*/
this.dateFormat = 'Y-m-d';
/**
* Initial value of the hour element.
*/
this.defaultHour = 12;
/**
* Initial value of the minute element.
*/
this.defaultMinute = 0;
/**
* Initial value of the seconds element.
*/
this.defaultSeconds = 0;
/**
* See <a href="https://chmln.github.io/flatpickr/examples/#disabling-specific-dates">disabling dates</a>.
*/
this.disable = [];
/**
* Set disableMobile to true to always use the non-native picker.
* By default, Flatpickr utilizes native datetime widgets unless certain options (e.g. disable) are used.
*/
this.disableMobile = false;
/**
* Enables time picker.
*/
this.enableTime = false;
/**
* Enables seconds in the time picker.
*/
this.enableSeconds = false;
/**
* Allows using a custom date formatting function instead of the built-in handling for date formats using dateFormat, altFormat, etc.
*/
this.formatDate = undefined;
/**
* Adjusts the step for the hour input (incl. scrolling).
*/
this.hourIncrement = 1;
/**
* Displays the calendar inline.
*/
this.inline = false;
/**
* The maximum date that a user can pick to (inclusive).
*/
this.maxDate = undefined;
/**
* The minimum date that a user can start picking from (inclusive).
*/
this.minDate = undefined;
/**
* The maximum time that a user can pick to (inclusive).
*/
this.maxTime = undefined;
/**
* The minimum time that a user can start picking from (inclusive).
*/
this.minTime = undefined;
/**
* Adjusts the step for the minute input (incl. scrolling).
*/
this.minuteIncrement = 5;
/**
* Select a single date, multiple dates or a date range.
*/
this.mode = 'single';
/**
* HTML for the arrow icon, used to switch months.
*/
this.nextArrow = '>';
/**
* Hides the day selection in calendar. Use it along with `enableTime` to create a time picker.
*/
this.noCalendar = false;
/**
* Default now to the current date
*/
this.now = new Date();
/**
* HTML for the left arrow icon.
*/
this.prevArrow = '<';
/**
* Show the month using the shorthand version (ie, Sep instead of September).
*/
this.shorthandCurrentMonth = false;
/**
* Position the calendar inside the wrapper and next to the input element. (Leave `false` unless you know what you're doing).
*/
this.static = false;
/**
* Displays time picker in 24 hour mode without AM/PM selection when enabled.
*/
this.time24hr = false;
/**
* When true, dates will parsed, formatted, and displayed in UTC.
* It's recommended that date strings contain the timezone, but not necessary.
*/
this.utc = false;
/**
* Enables display of week numbers in calendar.
*/
this.weekNumbers = false;
/**
* Custom elements and input groups.
*/
this.wrap = false;
/**
* Array of plugin instances to use.
*/
this.plugins = [];
/**
* The locale object or string to use for the locale.
*/
this.locale = 'default';
/**
* Auto convert the ngModel value from a string to a date / array of dates / from - to date object depending on the `mode`
*/
this.convertModelValue = false;
/**
* The number of months shown.
*/
this.showMonths = 1;
/**
* How the month should be displayed in the header of the calendar.
*/
this.monthSelectorType = 'static';
/**
* Array of HTML elements that should not close the picker on click.
*/
this.ignoredFocusElements = [];
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FlatpickrDefaults, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FlatpickrDefaults }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FlatpickrDefaults, decorators: [{
type: Injectable
}] });
const FLATPICKR_CONTROL_VALUE_ACCESSOR = {
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(() => FlatpickrDirective),
multi: true,
};
class FlatpickrDirective {
constructor(elm, defaults, renderer, platformId) {
this.elm = elm;
this.defaults = defaults;
this.renderer = renderer;
this.platformId = platformId;
/**
* Object-options that can be user for multiple instances of Flatpickr.
* Option from this object is applied only if specific option is not specified.
* Example:
* ```typescript
* options: FlatpickrDefaultsInterface = {
* altFormat: 'd/m/Y', // will be ignored since altFormat is provided via specific attribute
* altInput: true // will be used since specific attribute is not provided
* };
* ```
* ```html
* <input
* class="form-control"
* type="text"
* mwlFlatpickr
* [options]="options"
* altFormat="d/m/Y">
* ```
*/
this.options = {};
/**
* Array of HTML elements that should not close the picker on click.
*/
this.ignoredFocusElements = [];
/**
* Gets triggered once the calendar is in a ready state
*/
this.flatpickrReady = new EventEmitter();
/**
* Gets triggered when the user selects a date, or changes the time on a selected date.
*/
this.flatpickrChange = new EventEmitter();
/**
* Gets triggered when the input value is updated with a new date string.
*/
this.flatpickrValueUpdate = new EventEmitter();
/**
* Gets triggered when the calendar is opened.
*/
this.flatpickrOpen = new EventEmitter();
/**
* Gets triggered when the calendar is closed.
*/
this.flatpickrClose = new EventEmitter();
/**
* Gets triggered when the month is changed, either by the user or programmatically.
*/
this.flatpickrMonthChange = new EventEmitter();
/**
* Gets triggered when the year is changed, either by the user or programmatically.
*/
this.flatpickrYearChange = new EventEmitter();
/**
* Take full control of every date cell with this output
*/
this.flatpickrDayCreate = new EventEmitter();
this.isDisabled = false;
this.onChangeFn = () => { };
this.onTouchedFn = () => { };
}
ngAfterViewInit() {
const options = {
altFormat: this.altFormat,
altInput: this.altInput,
altInputClass: this.altInputClass,
allowInput: this.allowInput,
allowInvalidPreload: this.allowInvalidPreload,
appendTo: this.appendTo,
ariaDateFormat: this.ariaDateFormat,
clickOpens: this.clickOpens,
dateFormat: this.dateFormat,
defaultHour: this.defaultHour,
defaultMinute: this.defaultMinute,
defaultSeconds: this.defaultSeconds,
disable: this.disable,
disableMobile: this.disableMobile,
enable: this.enable,
enableTime: this.enableTime,
enableSeconds: this.enableSeconds,
formatDate: this.formatDate,
hourIncrement: this.hourIncrement,
defaultDate: this.initialValue,
inline: this.inline,
maxDate: this.maxDate,
minDate: this.minDate,
maxTime: this.maxTime,
minTime: this.minTime,
minuteIncrement: this.minuteIncrement,
mode: this.mode,
nextArrow: this.nextArrow,
noCalendar: this.noCalendar,
now: this.now,
parseDate: this.parseDate,
prevArrow: this.prevArrow,
shorthandCurrentMonth: this.shorthandCurrentMonth,
showMonths: this.showMonths,
monthSelectorType: this.monthSelectorType,
static: this.static,
time24hr: this.time24hr,
weekNumbers: this.weekNumbers,
getWeek: this.getWeek,
wrap: this.wrap,
plugins: this.plugins,
locale: this.locale,
ignoredFocusElements: this.ignoredFocusElements,
onChange: (selectedDates, dateString, instance) => {
this.flatpickrChange.emit({ selectedDates, dateString, instance });
},
onOpen: (selectedDates, dateString, instance) => {
this.flatpickrOpen.emit({ selectedDates, dateString, instance });
},
onClose: (selectedDates, dateString, instance) => {
this.flatpickrClose.emit({ selectedDates, dateString, instance });
},
onMonthChange: (selectedDates, dateString, instance) => {
this.flatpickrMonthChange.emit({ selectedDates, dateString, instance });
},
onYearChange: (selectedDates, dateString, instance) => {
this.flatpickrYearChange.emit({ selectedDates, dateString, instance });
},
onReady: (selectedDates, dateString, instance) => {
this.flatpickrReady.emit({ selectedDates, dateString, instance });
},
onValueUpdate: (selectedDates, dateString, instance) => {
this.flatpickrValueUpdate.emit({ selectedDates, dateString, instance });
},
onDayCreate: (selectedDates, dateString, instance, dayElement) => {
this.flatpickrDayCreate.emit({
selectedDates,
dateString,
instance,
dayElement,
});
},
};
Object.keys(options).forEach((key) => {
if (typeof options[key] === 'undefined') {
if (typeof this.options[key] !== 'undefined') {
options[key] = this.options[key];
}
else {
options[key] = this.defaults[key];
}
}
});
// @ts-ignore
options.time_24hr = options.time24hr;
// workaround bug in flatpickr 4.6 where it doesn't copy the classes across
// TODO - remove once fix in https://github.com/flatpickr/flatpickr/issues/1860 is released
options.altInputClass =
(options.altInputClass || '') + ' ' + this.elm.nativeElement.className;
if (!options.enable) {
delete options.enable;
}
if (isPlatformBrowser(this.platformId)) {
this.instance = flatpickr(this.elm.nativeElement, options);
this.setDisabledState(this.isDisabled);
}
}
ngOnChanges(changes) {
if (this.instance) {
Object.keys(changes).forEach((inputKey) => {
this.instance.set(inputKey, this[inputKey]);
});
}
}
ngOnDestroy() {
if (this.instance) {
this.instance.destroy();
}
}
writeValue(value) {
let convertedValue = value;
if (this.convertModelValue && this.mode === 'range' && value) {
convertedValue = [value.from, value.to];
}
if (this.instance) {
this.instance.setDate(convertedValue);
}
else {
// flatpickr hasn't been initialised yet, store the value for later use
this.initialValue = convertedValue;
}
}
registerOnChange(fn) {
this.onChangeFn = fn;
}
registerOnTouched(fn) {
this.onTouchedFn = fn;
}
setDisabledState(isDisabled) {
this.isDisabled = isDisabled;
if (this.instance) {
if (this.isDisabled) {
this.renderer.setProperty(this.instance._input, 'disabled', 'disabled');
}
else {
this.renderer.removeAttribute(this.instance._input, 'disabled');
}
}
}
inputChanged() {
const value = this.elm.nativeElement.value;
if (this.convertModelValue && typeof value === 'string') {
switch (this.mode) {
case 'multiple':
const dates = value
.split('; ')
.map((str) => this.instance.parseDate(str, this.instance.config.dateFormat, !this.instance.config.enableTime));
this.onChangeFn(dates);
break;
case 'range':
const [from, to] = value
.split(this.instance.l10n.rangeSeparator)
.map((str) => this.instance.parseDate(str, this.instance.config.dateFormat, !this.instance.config.enableTime));
this.onChangeFn({ from, to });
break;
case 'single':
default:
this.onChangeFn(this.instance.parseDate(value, this.instance.config.dateFormat, !this.instance.config.enableTime));
}
}
else {
this.onChangeFn(value);
}
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FlatpickrDirective, deps: [{ token: i0.ElementRef }, { token: FlatpickrDefaults }, { token: i0.Renderer2 }, { token: PLATFORM_ID }], target: i0.ɵɵFactoryTarget.Directive }); }
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.12", type: FlatpickrDirective, selector: "[mwlFlatpickr]", inputs: { options: "options", altFormat: "altFormat", altInput: "altInput", altInputClass: "altInputClass", allowInput: "allowInput", allowInvalidPreload: "allowInvalidPreload", appendTo: "appendTo", ariaDateFormat: "ariaDateFormat", clickOpens: "clickOpens", dateFormat: "dateFormat", defaultHour: "defaultHour", defaultMinute: "defaultMinute", defaultSeconds: "defaultSeconds", disable: "disable", disableMobile: "disableMobile", enable: "enable", enableTime: "enableTime", enableSeconds: "enableSeconds", formatDate: "formatDate", hourIncrement: "hourIncrement", inline: "inline", maxDate: "maxDate", minDate: "minDate", maxTime: "maxTime", minTime: "minTime", minuteIncrement: "minuteIncrement", mode: "mode", nextArrow: "nextArrow", noCalendar: "noCalendar", now: "now", parseDate: "parseDate", prevArrow: "prevArrow", shorthandCurrentMonth: "shorthandCurrentMonth", showMonths: "showMonths", static: "static", time24hr: "time24hr", weekNumbers: "weekNumbers", getWeek: "getWeek", wrap: "wrap", plugins: "plugins", locale: "locale", convertModelValue: "convertModelValue", monthSelectorType: "monthSelectorType", ignoredFocusElements: "ignoredFocusElements" }, outputs: { flatpickrReady: "flatpickrReady", flatpickrChange: "flatpickrChange", flatpickrValueUpdate: "flatpickrValueUpdate", flatpickrOpen: "flatpickrOpen", flatpickrClose: "flatpickrClose", flatpickrMonthChange: "flatpickrMonthChange", flatpickrYearChange: "flatpickrYearChange", flatpickrDayCreate: "flatpickrDayCreate" }, host: { listeners: { "blur": "onTouchedFn()", "input": "inputChanged()" } }, providers: [FLATPICKR_CONTROL_VALUE_ACCESSOR], exportAs: ["mwlFlatpickr"], usesOnChanges: true, ngImport: i0 }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FlatpickrDirective, decorators: [{
type: Directive,
args: [{
selector: '[mwlFlatpickr]',
providers: [FLATPICKR_CONTROL_VALUE_ACCESSOR],
exportAs: 'mwlFlatpickr',
}]
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: FlatpickrDefaults }, { type: i0.Renderer2 }, { type: Object, decorators: [{
type: Inject,
args: [PLATFORM_ID]
}] }], propDecorators: { options: [{
type: Input
}], altFormat: [{
type: Input
}], altInput: [{
type: Input
}], altInputClass: [{
type: Input
}], allowInput: [{
type: Input
}], allowInvalidPreload: [{
type: Input
}], appendTo: [{
type: Input
}], ariaDateFormat: [{
type: Input
}], clickOpens: [{
type: Input
}], dateFormat: [{
type: Input
}], defaultHour: [{
type: Input
}], defaultMinute: [{
type: Input
}], defaultSeconds: [{
type: Input
}], disable: [{
type: Input
}], disableMobile: [{
type: Input
}], enable: [{
type: Input
}], enableTime: [{
type: Input
}], enableSeconds: [{
type: Input
}], formatDate: [{
type: Input
}], hourIncrement: [{
type: Input
}], inline: [{
type: Input
}], maxDate: [{
type: Input
}], minDate: [{
type: Input
}], maxTime: [{
type: Input
}], minTime: [{
type: Input
}], minuteIncrement: [{
type: Input
}], mode: [{
type: Input
}], nextArrow: [{
type: Input
}], noCalendar: [{
type: Input
}], now: [{
type: Input
}], parseDate: [{
type: Input
}], prevArrow: [{
type: Input
}], shorthandCurrentMonth: [{
type: Input
}], showMonths: [{
type: Input
}], static: [{
type: Input
}], time24hr: [{
type: Input
}], weekNumbers: [{
type: Input
}], getWeek: [{
type: Input
}], wrap: [{
type: Input
}], plugins: [{
type: Input
}], locale: [{
type: Input
}], convertModelValue: [{
type: Input
}], monthSelectorType: [{
type: Input
}], ignoredFocusElements: [{
type: Input
}], flatpickrReady: [{
type: Output
}], flatpickrChange: [{
type: Output
}], flatpickrValueUpdate: [{
type: Output
}], flatpickrOpen: [{
type: Output
}], flatpickrClose: [{
type: Output
}], flatpickrMonthChange: [{
type: Output
}], flatpickrYearChange: [{
type: Output
}], flatpickrDayCreate: [{
type: Output
}], onTouchedFn: [{
type: HostListener,
args: ['blur']
}], inputChanged: [{
type: HostListener,
args: ['input']
}] } });
const USER_DEFAULTS = new InjectionToken('flatpickr defaults');
function defaultsFactory(userDefaults) {
const defaults = new FlatpickrDefaults();
Object.assign(defaults, userDefaults);
return defaults;
}
class FlatpickrModule {
static forRoot(userDefaults = {}) {
return {
ngModule: FlatpickrModule,
providers: [
{
provide: USER_DEFAULTS,
useValue: userDefaults,
},
{
provide: FlatpickrDefaults,
useFactory: defaultsFactory,
deps: [USER_DEFAULTS],
},
],
};
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FlatpickrModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.12", ngImport: i0, type: FlatpickrModule, declarations: [FlatpickrDirective], exports: [FlatpickrDirective] }); }
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FlatpickrModule }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FlatpickrModule, decorators: [{
type: NgModule,
args: [{
declarations: [FlatpickrDirective],
exports: [FlatpickrDirective],
}]
}] });
/*
* Public API Surface of angularx-flatpickr
*/
/**
* Generated bundle index. Do not edit.
*/
export { FlatpickrDefaults, FlatpickrDirective, FlatpickrModule, USER_DEFAULTS, defaultsFactory };
//# sourceMappingURL=angularx-flatpickr.mjs.map
{"version":3,"file":"angularx-flatpickr.mjs","sources":["../../../projects/angularx-flatpickr/src/lib/flatpickr-defaults.service.ts","../../../projects/angularx-flatpickr/src/lib/flatpickr.directive.ts","../../../projects/angularx-flatpickr/src/lib/flatpickr.module.ts","../../../projects/angularx-flatpickr/src/public-api.ts","../../../projects/angularx-flatpickr/src/angularx-flatpickr.ts"],"sourcesContent":["import { Injectable } from '@angular/core';\n\nexport type DisableEnableDate =\n | string\n | Date\n | { from: Date | string; to: Date | string }\n | ((date: Date) => boolean);\n\nexport interface FlatpickrDefaultsInterface {\n /**\n * Exactly the same as date format, but for the altInput field.\n */\n altFormat?: string;\n\n /**\n * \tShow the user a readable date (as per altFormat), but return something totally different to the server.\n */\n altInput?: boolean;\n\n /**\n * This class will be added to the input element created by the altInput option.\n * Note that `altInput` already inherits classes from the original input.\n */\n altInputClass?: string;\n\n /**\n * Allows the user to enter a date directly input the input field. By default, direct entry is disabled.\n */\n allowInput?: boolean;\n\n /**\n * Allows the preloading of an invalid date. When disabled, the field will be cleared if the provided date is invalid\n */\n allowInvalidPreload?: boolean;\n\n /**\n * Instead of `body`, appends the calendar to the specified node instead.\n */\n appendTo?: HTMLElement;\n\n /**\n * Defines how the date will be formatted in the aria-label for calendar days, using the same tokens as dateFormat. If you change this, you should choose a value that will make sense if a screen reader reads it out loud.\n */\n ariaDateFormat?: string;\n\n /**\n * Whether clicking on the input should open the picker.\n * You could disable this if you wish to open the calendar manually `with.open()`.\n */\n clickOpens?: boolean;\n\n /**\n * A string of characters which are used to define how the date will be displayed in the input box.\n * The supported characters are defined in the table below.\n */\n dateFormat?: string;\n /**\n * Initial value of the hour element.\n */\n defaultHour?: number;\n /**\n * Initial value of the minute element.\n */\n defaultMinute?: number;\n /**\n * Initial value of the seconds element.\n */\n defaultSeconds?: number;\n\n /**\n * See <a href=\"https://chmln.github.io/flatpickr/examples/#disabling-specific-dates\">disabling dates</a>.\n */\n disable?: DisableEnableDate[];\n\n /**\n * Set disableMobile to true to always use the non-native picker.\n * By default, Flatpickr utilizes native datetime widgets unless certain options (e.g. disable) are used.\n */\n disableMobile?: boolean;\n\n /**\n * See <a href=\"https://chmln.github.io/flatpickr/examples/#disabling-all-dates-except-select-few\">enabling dates</a>.\n */\n enable?: DisableEnableDate[];\n\n /**\n * Enables time picker.\n */\n enableTime?: boolean;\n\n /**\n * Enables seconds in the time picker.\n */\n enableSeconds?: boolean;\n /**\n * Allows using a custom date formatting function instead of the built-in handling for date formats using dateFormat, altFormat, etc.\n */\n formatDate?: (value: any) => string;\n /**\n * Adjusts the step for the hour input (incl. scrolling).\n */\n hourIncrement?: number;\n\n /**\n * Displays the calendar inline.\n */\n inline?: boolean;\n\n /**\n * The maximum date that a user can pick to (inclusive).\n */\n maxDate?: string | Date;\n\n /**\n * The minimum date that a user can start picking from (inclusive).\n */\n minDate?: string | Date;\n\n /**\n * The maximum time that a user can pick to (inclusive).\n */\n maxTime?: string;\n\n /**\n * The minimum time that a user can start picking from (inclusive).\n */\n minTime?: string;\n\n /**\n * Adjusts the step for the minute input (incl. scrolling).\n */\n minuteIncrement?: number;\n\n /**\n * Select a single date, multiple dates or a date range.\n */\n mode?: 'single' | 'multiple' | 'range';\n\n /**\n * HTML for the arrow icon, used to switch months.\n */\n nextArrow?: string;\n\n /**\n * Hides the day selection in calendar. Use it along with `enableTime` to create a time picker.\n */\n noCalendar?: boolean;\n\n /**\n * Provide a date for 'today', which will be used instead of \"new Date()\"\n */\n now?: Date | string | number;\n\n /**\n * Function that expects a date string and must return a Date object.\n */\n parseDate?: (str: string) => Date;\n\n /**\n * HTML for the left arrow icon.\n */\n prevArrow?: string;\n\n /**\n * Show the month using the shorthand version (ie, Sep instead of September).\n */\n shorthandCurrentMonth?: boolean;\n\n /**\n * Position the calendar inside the wrapper and next to the input element. (Leave `false` unless you know what you're doing).\n */\n static?: boolean;\n\n /**\n * Displays time picker in 24 hour mode without AM/PM selection when enabled.\n */\n time24hr?: boolean;\n\n /**\n * When true, dates will parsed, formatted, and displayed in UTC.\n * It's recommended that date strings contain the timezone, but not necessary.\n */\n utc?: boolean;\n\n /**\n * Enables display of week numbers in calendar.\n */\n weekNumbers?: boolean;\n\n /**\n * You may override the function that extracts the week numbers from a Date by supplying a getWeek function.\n * It takes in a date as a parameter and should return a corresponding string that you want to appear left of every week.\n */\n getWeek?: (date: Date) => string;\n\n /**\n * Custom elements and input groups.\n */\n wrap?: boolean;\n\n /**\n * Array of plugin instances to use.\n */\n plugins?: any[];\n\n /**\n * The locale object or string to use for the locale.\n */\n locale?: object | string;\n\n /**\n * Auto convert the ngModel value from a string to a date / array of dates / from - to date object depending on the `mode`\n */\n convertModelValue?: boolean;\n\n /**\n * The number of months shown.\n */\n showMonths?: number;\n\n /**\n * How the month should be displayed in the header of the calendar.\n */\n monthSelectorType?: 'static' | 'dropdown';\n\n /**\n * Array of HTML elements that should not close the picker on click.\n */\n ignoredFocusElements?: HTMLElement[];\n}\n\n@Injectable()\nexport class FlatpickrDefaults implements FlatpickrDefaultsInterface {\n /**\n * Exactly the same as date format, but for the altInput field.\n */\n altFormat: string = 'F j, Y';\n\n /**\n * \tShow the user a readable date (as per altFormat), but return something totally different to the server.\n */\n altInput: boolean = false;\n\n /**\n * This class will be added to the input element created by the altInput option.\n * Note that `altInput` already inherits classes from the original input.\n */\n altInputClass: string = '';\n\n /**\n * Allows the user to enter a date directly input the input field. By default, direct entry is disabled.\n */\n allowInput: boolean = false;\n\n /**\n * Allows the preloading of an invalid date. When disabled, the field will be cleared if the provided date is invalid\n */\n allowInvalidPreload: boolean = false;\n\n /**\n * Instead of `body`, appends the calendar to the specified node instead.\n */\n appendTo: HTMLElement | undefined = undefined;\n\n /**\n * Defines how the date will be formatted in the aria-label for calendar days, using the same tokens as dateFormat. If you change this, you should choose a value that will make sense if a screen reader reads it out loud.\n */\n ariaDateFormat?: string = 'F j, Y';\n\n /**\n * Whether clicking on the input should open the picker.\n * You could disable this if you wish to open the calendar manually `with.open()`.\n */\n clickOpens: boolean = true;\n\n /**\n * A string of characters which are used to define how the date will be displayed in the input box.\n * The supported characters are defined in the table below.\n */\n dateFormat: string = 'Y-m-d';\n\n /**\n * Initial value of the hour element.\n */\n defaultHour?: number = 12;\n\n /**\n * Initial value of the minute element.\n */\n defaultMinute?: number = 0;\n\n /**\n * Initial value of the seconds element.\n */\n defaultSeconds?: number = 0;\n\n /**\n * See <a href=\"https://chmln.github.io/flatpickr/examples/#disabling-specific-dates\">disabling dates</a>.\n */\n disable: DisableEnableDate[] = [];\n\n /**\n * Set disableMobile to true to always use the non-native picker.\n * By default, Flatpickr utilizes native datetime widgets unless certain options (e.g. disable) are used.\n */\n disableMobile: boolean = false;\n\n /**\n * See <a href=\"https://chmln.github.io/flatpickr/examples/#disabling-all-dates-except-select-few\">enabling dates</a>.\n */\n enable: DisableEnableDate[];\n\n /**\n * Enables time picker.\n */\n enableTime: boolean = false;\n\n /**\n * Enables seconds in the time picker.\n */\n enableSeconds: boolean = false;\n\n /**\n * Allows using a custom date formatting function instead of the built-in handling for date formats using dateFormat, altFormat, etc.\n */\n formatDate?: (value: any) => string = undefined;\n\n /**\n * Adjusts the step for the hour input (incl. scrolling).\n */\n hourIncrement: number = 1;\n\n /**\n * Displays the calendar inline.\n */\n inline: boolean = false;\n\n /**\n * The maximum date that a user can pick to (inclusive).\n */\n maxDate: string | Date | undefined = undefined;\n\n /**\n * The minimum date that a user can start picking from (inclusive).\n */\n minDate: string | Date | undefined = undefined;\n\n /**\n * The maximum time that a user can pick to (inclusive).\n */\n maxTime: string | undefined = undefined;\n\n /**\n * The minimum time that a user can start picking from (inclusive).\n */\n minTime: string | undefined = undefined;\n\n /**\n * Adjusts the step for the minute input (incl. scrolling).\n */\n minuteIncrement: number = 5;\n\n /**\n * Select a single date, multiple dates or a date range.\n */\n mode: 'single' | 'multiple' | 'range' = 'single';\n\n /**\n * HTML for the arrow icon, used to switch months.\n */\n nextArrow: string = '>';\n\n /**\n * Hides the day selection in calendar. Use it along with `enableTime` to create a time picker.\n */\n noCalendar: boolean = false;\n\n /**\n * Default now to the current date\n */\n now: Date | string | number = new Date();\n\n /**\n * Function that expects a date string and must return a Date object.\n */\n parseDate: (str: string) => Date;\n\n /**\n * HTML for the left arrow icon.\n */\n prevArrow: string = '<';\n\n /**\n * Show the month using the shorthand version (ie, Sep instead of September).\n */\n shorthandCurrentMonth: boolean = false;\n\n /**\n * Position the calendar inside the wrapper and next to the input element. (Leave `false` unless you know what you're doing).\n */\n static: boolean = false;\n\n /**\n * Displays time picker in 24 hour mode without AM/PM selection when enabled.\n */\n time24hr: boolean = false;\n\n /**\n * When true, dates will parsed, formatted, and displayed in UTC.\n * It's recommended that date strings contain the timezone, but not necessary.\n */\n utc: boolean = false;\n\n /**\n * Enables display of week numbers in calendar.\n */\n weekNumbers: boolean = false;\n\n /**\n * You may override the function that extracts the week numbers from a Date by supplying a getWeek function.\n * It takes in a date as a parameter and should return a corresponding string that you want to appear left of every week.\n */\n getWeek: (date: Date) => string;\n\n /**\n * Custom elements and input groups.\n */\n wrap: boolean = false;\n\n /**\n * Array of plugin instances to use.\n */\n plugins: any[] = [];\n\n /**\n * The locale object or string to use for the locale.\n */\n locale: object | string = 'default';\n\n /**\n * Auto convert the ngModel value from a string to a date / array of dates / from - to date object depending on the `mode`\n */\n convertModelValue: boolean = false;\n\n /**\n * The number of months shown.\n */\n showMonths: number = 1;\n\n /**\n * How the month should be displayed in the header of the calendar.\n */\n monthSelectorType: 'static' | 'dropdown' = 'static';\n\n /**\n * Array of HTML elements that should not close the picker on click.\n */\n ignoredFocusElements: HTMLElement[] = [];\n}\n","import {\n Directive,\n ElementRef,\n AfterViewInit,\n Input,\n Output,\n EventEmitter,\n OnChanges,\n SimpleChanges,\n OnDestroy,\n forwardRef,\n HostListener,\n Renderer2,\n PLATFORM_ID,\n Inject,\n} from '@angular/core';\nimport {\n FlatpickrDefaults,\n DisableEnableDate,\n FlatpickrDefaultsInterface,\n} from './flatpickr-defaults.service';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport flatpickr from 'flatpickr';\nimport { isPlatformBrowser } from '@angular/common';\n\nexport interface FlatPickrOutputOptions {\n selectedDates: Date[];\n dateString: string;\n instance: any;\n}\n\nexport interface FlatPickrDayCreateOutputOptions\n extends FlatPickrOutputOptions {\n dayElement: HTMLElement;\n}\n\nexport const FLATPICKR_CONTROL_VALUE_ACCESSOR: any = {\n provide: NG_VALUE_ACCESSOR,\n useExisting: forwardRef(() => FlatpickrDirective),\n multi: true,\n};\n\n@Directive({\n selector: '[mwlFlatpickr]',\n providers: [FLATPICKR_CONTROL_VALUE_ACCESSOR],\n exportAs: 'mwlFlatpickr',\n})\nexport class FlatpickrDirective\n implements AfterViewInit, OnChanges, OnDestroy, ControlValueAccessor\n{\n /**\n * Object-options that can be user for multiple instances of Flatpickr.\n * Option from this object is applied only if specific option is not specified.\n * Example:\n * ```typescript\n * options: FlatpickrDefaultsInterface = {\n * altFormat: 'd/m/Y', // will be ignored since altFormat is provided via specific attribute\n * altInput: true // will be used since specific attribute is not provided\n * };\n * ```\n * ```html\n * <input\n * class=\"form-control\"\n * type=\"text\"\n * mwlFlatpickr\n * [options]=\"options\"\n * altFormat=\"d/m/Y\">\n * ```\n */\n @Input() options: FlatpickrDefaultsInterface = {};\n\n /**\n * Exactly the same as date format, but for the altInput field.\n */\n @Input() altFormat: string;\n\n /**\n * \tShow the user a readable date (as per altFormat), but return something totally different to the server.\n */\n @Input() altInput: boolean;\n\n /**\n * This class will be added to the input element created by the altInput option.\n * Note that `altInput` already inherits classes from the original input.\n */\n @Input() altInputClass: string;\n\n /**\n * Allows the user to enter a date directly input the input field. By default, direct entry is disabled.\n */\n @Input() allowInput: boolean;\n\n /**\n * Allows the preloading of an invalid date. When disabled, the field will be cleared if the provided date is invalid\n */\n @Input() allowInvalidPreload: boolean;\n\n /**\n * Instead of `body`, appends the calendar to the specified node instead.\n */\n @Input() appendTo: HTMLElement;\n\n /**\n * Defines how the date will be formatted in the aria-label for calendar days, using the same tokens as dateFormat. If you change this, you should choose a value that will make sense if a screen reader reads it out loud.\n */\n @Input() ariaDateFormat?: string;\n\n /**\n * Whether clicking on the input should open the picker.\n * You could disable this if you wish to open the calendar manually `with.open()`.\n */\n @Input() clickOpens: boolean;\n\n /**\n * A string of characters which are used to define how the date will be displayed in the input box.\n * The supported characters are defined in the table below.\n */\n @Input() dateFormat: string;\n\n /**\n * Initial value of the hour element.\n */\n @Input() defaultHour?: number;\n /**\n * Initial value of the minute element.\n */\n @Input() defaultMinute?: number;\n\n /**\n * Initial value of the seconds element.\n */\n @Input() defaultSeconds?: number;\n\n /**\n * See <a href=\"https://chmln.github.io/flatpickr/examples/#disabling-specific-dates\">disabling dates</a>.\n */\n @Input() disable: DisableEnableDate[];\n\n /**\n * Set disableMobile to true to always use the non-native picker.\n * By default, Flatpickr utilizes native datetime widgets unless certain options (e.g. disable) are used.\n */\n @Input() disableMobile: boolean;\n\n /**\n * See <a href=\"https://chmln.github.io/flatpickr/examples/#disabling-all-dates-except-select-few\">enabling dates</a>.\n */\n @Input() enable: DisableEnableDate[];\n\n /**\n * Enables time picker.\n */\n @Input() enableTime: boolean;\n\n /**\n * Enables seconds in the time picker.\n */\n @Input() enableSeconds: boolean;\n\n /**\n * Allows using a custom date formatting function instead of the built-in handling for date formats using dateFormat, altFormat, etc.\n */\n @Input() formatDate?: (value: any) => string;\n\n /**\n * Adjusts the step for the hour input (incl. scrolling).\n */\n @Input() hourIncrement: number;\n\n /**\n * Displays the calendar inline.\n */\n @Input() inline: boolean;\n\n /**\n * The maximum date that a user can pick to (inclusive).\n */\n @Input() maxDate: string | Date;\n\n /**\n * The minimum date that a user can start picking from (inclusive).\n */\n @Input() minDate: string | Date;\n\n /**\n * The maximum time that a user can pick to (inclusive).\n */\n @Input() maxTime: string;\n\n /**\n * The minimum time that a user can start picking from (inclusive).\n */\n @Input() minTime: string;\n\n /**\n * Adjusts the step for the minute input (incl. scrolling).\n */\n @Input() minuteIncrement: number;\n\n /**\n * Select a single date, multiple dates or a date range.\n */\n @Input() mode: 'single' | 'multiple' | 'range';\n\n /**\n * HTML for the arrow icon, used to switch months.\n */\n @Input() nextArrow: string;\n\n /**\n * Hides the day selection in calendar. Use it along with `enableTime` to create a time picker.\n */\n @Input() noCalendar: boolean;\n\n /**\n * Provide a date for 'today', which will be used instead of \"new Date()\"\n */\n @Input() now?: Date | string | number;\n\n /**\n * Function that expects a date string and must return a Date object.\n */\n @Input() parseDate: (str: string) => Date;\n\n /**\n * HTML for the left arrow icon.\n */\n @Input() prevArrow: string;\n\n /**\n * Show the month using the shorthand version (ie, Sep instead of September).\n */\n @Input() shorthandCurrentMonth: boolean;\n\n /**\n * The number of months shown.\n */\n @Input() showMonths: number;\n\n /**\n * Position the calendar inside the wrapper and next to the input element. (Leave `false` unless you know what you're doing).\n */\n @Input() static: boolean;\n\n /**\n * Displays time picker in 24 hour mode without AM/PM selection when enabled.\n */\n @Input() time24hr: boolean;\n\n /**\n * Enables display of week numbers in calendar.\n */\n @Input() weekNumbers: boolean;\n\n /**\n * You may override the function that extracts the week numbers from a Date by supplying a getWeek function.\n * It takes in a date as a parameter and should return a corresponding string that you want to appear left of every week.\n */\n @Input() getWeek: (date: Date) => string;\n\n /**\n * Custom elements and input groups.\n */\n @Input() wrap: boolean;\n\n /**\n * Array of plugin instances to use.\n */\n @Input() plugins: any[];\n\n /**\n * The locale object or string to use for the locale.\n */\n @Input() locale: object | string;\n\n /**\n * Auto convert the ngModel value from a string to a date / array of dates / from - to date object depending on the `mode`\n */\n @Input() convertModelValue: boolean;\n\n /**\n * How the month should be displayed in the header of the calendar.\n */\n @Input() monthSelectorType: 'static' | 'dropdown';\n\n /**\n * Array of HTML elements that should not close the picker on click.\n */\n @Input() ignoredFocusElements: HTMLElement[] = [];\n\n /**\n * Gets triggered once the calendar is in a ready state\n */\n @Output()\n flatpickrReady: EventEmitter<FlatPickrOutputOptions> = new EventEmitter();\n\n /**\n * Gets triggered when the user selects a date, or changes the time on a selected date.\n */\n @Output()\n flatpickrChange: EventEmitter<FlatPickrOutputOptions> = new EventEmitter();\n\n /**\n * Gets triggered when the input value is updated with a new date string.\n */\n @Output()\n flatpickrValueUpdate: EventEmitter<FlatPickrOutputOptions> =\n new EventEmitter();\n\n /**\n * Gets triggered when the calendar is opened.\n */\n @Output()\n flatpickrOpen: EventEmitter<FlatPickrOutputOptions> = new EventEmitter();\n\n /**\n * Gets triggered when the calendar is closed.\n */\n @Output()\n flatpickrClose: EventEmitter<FlatPickrOutputOptions> = new EventEmitter();\n\n /**\n * Gets triggered when the month is changed, either by the user or programmatically.\n */\n @Output()\n flatpickrMonthChange: EventEmitter<FlatPickrOutputOptions> =\n new EventEmitter();\n\n /**\n * Gets triggered when the year is changed, either by the user or programmatically.\n */\n @Output()\n flatpickrYearChange: EventEmitter<FlatPickrOutputOptions> =\n new EventEmitter();\n\n /**\n * Take full control of every date cell with this output\n */\n @Output()\n flatpickrDayCreate: EventEmitter<FlatPickrDayCreateOutputOptions> =\n new EventEmitter();\n\n /**\n * The flatpickr instance where you can call methods like toggle(), open(), close() etc\n */\n instance: flatpickr.Instance;\n\n private isDisabled = false;\n private initialValue: any;\n\n onChangeFn: (value: any) => void = () => {};\n\n @HostListener('blur')\n onTouchedFn = () => {};\n\n constructor(\n private elm: ElementRef,\n private defaults: FlatpickrDefaults,\n private renderer: Renderer2,\n @Inject(PLATFORM_ID) private platformId: Object,\n ) {}\n\n ngAfterViewInit(): void {\n const options: any = {\n altFormat: this.altFormat,\n altInput: this.altInput,\n altInputClass: this.altInputClass,\n allowInput: this.allowInput,\n allowInvalidPreload: this.allowInvalidPreload,\n appendTo: this.appendTo,\n ariaDateFormat: this.ariaDateFormat,\n clickOpens: this.clickOpens,\n dateFormat: this.dateFormat,\n defaultHour: this.defaultHour,\n defaultMinute: this.defaultMinute,\n defaultSeconds: this.defaultSeconds,\n disable: this.disable,\n disableMobile: this.disableMobile,\n enable: this.enable,\n enableTime: this.enableTime,\n enableSeconds: this.enableSeconds,\n formatDate: this.formatDate,\n hourIncrement: this.hourIncrement,\n defaultDate: this.initialValue,\n inline: this.inline,\n maxDate: this.maxDate,\n minDate: this.minDate,\n maxTime: this.maxTime,\n minTime: this.minTime,\n minuteIncrement: this.minuteIncrement,\n mode: this.mode,\n nextArrow: this.nextArrow,\n noCalendar: this.noCalendar,\n now: this.now,\n parseDate: this.parseDate,\n prevArrow: this.prevArrow,\n shorthandCurrentMonth: this.shorthandCurrentMonth,\n showMonths: this.showMonths,\n monthSelectorType: this.monthSelectorType,\n static: this.static,\n time24hr: this.time24hr,\n weekNumbers: this.weekNumbers,\n getWeek: this.getWeek,\n wrap: this.wrap,\n plugins: this.plugins,\n locale: this.locale,\n ignoredFocusElements: this.ignoredFocusElements,\n onChange: (selectedDates: Date[], dateString: string, instance: any) => {\n this.flatpickrChange.emit({ selectedDates, dateString, instance });\n },\n onOpen: (selectedDates: Date[], dateString: string, instance: any) => {\n this.flatpickrOpen.emit({ selectedDates, dateString, instance });\n },\n onClose: (selectedDates: Date[], dateString: string, instance: any) => {\n this.flatpickrClose.emit({ selectedDates, dateString, instance });\n },\n onMonthChange: (\n selectedDates: Date[],\n dateString: string,\n instance: any,\n ) => {\n this.flatpickrMonthChange.emit({ selectedDates, dateString, instance });\n },\n onYearChange: (\n selectedDates: Date[],\n dateString: string,\n instance: any,\n ) => {\n this.flatpickrYearChange.emit({ selectedDates, dateString, instance });\n },\n onReady: (selectedDates: Date[], dateString: string, instance: any) => {\n this.flatpickrReady.emit({ selectedDates, dateString, instance });\n },\n onValueUpdate: (\n selectedDates: Date[],\n dateString: string,\n instance: any,\n ) => {\n this.flatpickrValueUpdate.emit({ selectedDates, dateString, instance });\n },\n onDayCreate: (\n selectedDates: Date[],\n dateString: string,\n instance: any,\n dayElement: HTMLElement,\n ) => {\n this.flatpickrDayCreate.emit({\n selectedDates,\n dateString,\n instance,\n dayElement,\n });\n },\n };\n\n Object.keys(options).forEach((key) => {\n if (typeof options[key] === 'undefined') {\n if (typeof (this.options as any)[key] !== 'undefined') {\n options[key] = (this.options as any)[key];\n } else {\n options[key] = (this.defaults as any)[key];\n }\n }\n });\n\n // @ts-ignore\n options.time_24hr = options.time24hr;\n\n // workaround bug in flatpickr 4.6 where it doesn't copy the classes across\n // TODO - remove once fix in https://github.com/flatpickr/flatpickr/issues/1860 is released\n options.altInputClass =\n (options.altInputClass || '') + ' ' + this.elm.nativeElement.className;\n\n if (!options.enable) {\n delete options.enable;\n }\n\n if (isPlatformBrowser(this.platformId)) {\n this.instance = flatpickr(\n this.elm.nativeElement,\n options,\n ) as flatpickr.Instance;\n this.setDisabledState(this.isDisabled);\n }\n }\n\n ngOnChanges(changes: SimpleChanges): void {\n if (this.instance) {\n Object.keys(changes).forEach((inputKey) => {\n this.instance.set(inputKey as any, (this as any)[inputKey]);\n });\n }\n }\n\n ngOnDestroy(): void {\n if (this.instance) {\n this.instance.destroy();\n }\n }\n\n writeValue(value: any): void {\n let convertedValue: any = value;\n if (this.convertModelValue && this.mode === 'range' && value) {\n convertedValue = [value.from, value.to];\n }\n\n if (this.instance) {\n this.instance.setDate(convertedValue);\n } else {\n // flatpickr hasn't been initialised yet, store the value for later use\n this.initialValue = convertedValue;\n }\n }\n\n registerOnChange(fn: any): void {\n this.onChangeFn = fn;\n }\n\n registerOnTouched(fn: () => void): void {\n this.onTouchedFn = fn;\n }\n\n setDisabledState(isDisabled: boolean): void {\n this.isDisabled = isDisabled;\n if (this.instance) {\n if (this.isDisabled) {\n this.renderer.setProperty(this.instance._input, 'disabled', 'disabled');\n } else {\n this.renderer.removeAttribute(this.instance._input, 'disabled');\n }\n }\n }\n\n @HostListener('input')\n inputChanged(): void {\n const value: string = this.elm.nativeElement.value;\n if (this.convertModelValue && typeof value === 'string') {\n switch (this.mode) {\n case 'multiple':\n const dates: Array<Date | undefined> = value\n .split('; ')\n .map((str) =>\n this.instance.parseDate(\n str,\n this.instance.config.dateFormat,\n !this.instance.config.enableTime,\n ),\n );\n this.onChangeFn(dates);\n break;\n\n case 'range':\n const [from, to] = value\n .split(this.instance.l10n.rangeSeparator)\n .map((str) =>\n this.instance.parseDate(\n str,\n this.instance.config.dateFormat,\n !this.instance.config.enableTime,\n ),\n );\n this.onChangeFn({ from, to });\n break;\n\n case 'single':\n default:\n this.onChangeFn(\n this.instance.parseDate(\n value,\n this.instance.config.dateFormat,\n !this.instance.config.enableTime,\n ),\n );\n }\n } else {\n this.onChangeFn(value);\n }\n }\n}\n","import {\n NgModule,\n ModuleWithProviders,\n InjectionToken,\n Provider,\n} from '@angular/core';\nimport { FlatpickrDirective } from './flatpickr.directive';\nimport {\n FlatpickrDefaults,\n FlatpickrDefaultsInterface,\n} from './flatpickr-defaults.service';\n\nexport const USER_DEFAULTS = new InjectionToken('flatpickr defaults');\n\nexport function defaultsFactory(\n userDefaults: FlatpickrDefaultsInterface,\n): FlatpickrDefaults {\n const defaults: FlatpickrDefaults = new FlatpickrDefaults();\n Object.assign(defaults, userDefaults);\n return defaults;\n}\n\n@NgModule({\n declarations: [FlatpickrDirective],\n exports: [FlatpickrDirective],\n})\nexport class FlatpickrModule {\n static forRoot(\n userDefaults: FlatpickrDefaultsInterface = {},\n ): ModuleWithProviders<FlatpickrModule> {\n return {\n ngModule: FlatpickrModule,\n providers: [\n {\n provide: USER_DEFAULTS,\n useValue: userDefaults,\n },\n {\n provide: FlatpickrDefaults,\n useFactory: defaultsFactory,\n deps: [USER_DEFAULTS],\n },\n ],\n };\n }\n}\n","/*\n * Public API Surface of angularx-flatpickr\n */\n\nexport * from './lib/flatpickr.module';\nexport {\n FlatpickrDefaults,\n FlatpickrDefaultsInterface,\n} from './lib/flatpickr-defaults.service';\nexport { FlatpickrDirective } from './lib/flatpickr.directive';\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":"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"}
+15
-0

@@ -5,2 +5,17 @@ # Changelog

## [8.0.0](https://github.com/mattlewis92/angularx-flatpickr/compare/v7.3.0...v8.0.0) (2024-08-21)
### ⚠ BREAKING CHANGES
* support for angular 16 has been removed. Please use this package with angular 17 or higher
* support for angular 15 has been removed. Please use this package with angular 16 or higher
* support for angular 14 has been removed. Please use this package with angular 15 or higher
### Features
* upgrade angular v16 ([#54](https://github.com/mattlewis92/angularx-flatpickr/issues/54)) ([ece59d4](https://github.com/mattlewis92/angularx-flatpickr/commit/ece59d44bc0e07f2fe4e413e955725a4b5b4c937))
* upgrade angular v17 ([#55](https://github.com/mattlewis92/angularx-flatpickr/issues/55)) ([0ef8674](https://github.com/mattlewis92/angularx-flatpickr/commit/0ef86743567b009c1b078a4ecd798f2df693292f))
* upgrade to Angular 15 ([#53](https://github.com/mattlewis92/angularx-flatpickr/issues/53)) ([e15af4a](https://github.com/mattlewis92/angularx-flatpickr/commit/e15af4a7342365ac27c2868162ccd9490b1a8958))
## [7.3.0](https://github.com/mattlewis92/angularx-flatpickr/compare/v7.2.0...v7.3.0) (2023-04-26)

@@ -7,0 +22,0 @@

+1
-1
import * as i0 from "@angular/core";
export declare type DisableEnableDate = string | Date | {
export type DisableEnableDate = string | Date | {
from: Date | string;

@@ -4,0 +4,0 @@ to: Date | string;

@@ -19,2 +19,3 @@ import { ElementRef, AfterViewInit, EventEmitter, OnChanges, SimpleChanges, OnDestroy, Renderer2 } from '@angular/core';

private renderer;
private platformId;
/**

@@ -257,3 +258,3 @@ * Object-options that can be user for multiple instances of Flatpickr.

onTouchedFn: () => void;
constructor(elm: ElementRef, defaults: FlatpickrDefaults, renderer: Renderer2);
constructor(elm: ElementRef, defaults: FlatpickrDefaults, renderer: Renderer2, platformId: Object);
ngAfterViewInit(): void;

@@ -268,3 +269,3 @@ ngOnChanges(changes: SimpleChanges): void;

static ɵfac: i0.ɵɵFactoryDeclaration<FlatpickrDirective, never>;
static ɵdir: i0.ɵɵDirectiveDeclaration<FlatpickrDirective, "[mwlFlatpickr]", ["mwlFlatpickr"], { "options": "options"; "altFormat": "altFormat"; "altInput": "altInput"; "altInputClass": "altInputClass"; "allowInput": "allowInput"; "allowInvalidPreload": "allowInvalidPreload"; "appendTo": "appendTo"; "ariaDateFormat": "ariaDateFormat"; "clickOpens": "clickOpens"; "dateFormat": "dateFormat"; "defaultHour": "defaultHour"; "defaultMinute": "defaultMinute"; "defaultSeconds": "defaultSeconds"; "disable": "disable"; "disableMobile": "disableMobile"; "enable": "enable"; "enableTime": "enableTime"; "enableSeconds": "enableSeconds"; "formatDate": "formatDate"; "hourIncrement": "hourIncrement"; "inline": "inline"; "maxDate": "maxDate"; "minDate": "minDate"; "maxTime": "maxTime"; "minTime": "minTime"; "minuteIncrement": "minuteIncrement"; "mode": "mode"; "nextArrow": "nextArrow"; "noCalendar": "noCalendar"; "now": "now"; "parseDate": "parseDate"; "prevArrow": "prevArrow"; "shorthandCurrentMonth": "shorthandCurrentMonth"; "showMonths": "showMonths"; "static": "static"; "time24hr": "time24hr"; "weekNumbers": "weekNumbers"; "getWeek": "getWeek"; "wrap": "wrap"; "plugins": "plugins"; "locale": "locale"; "convertModelValue": "convertModelValue"; "monthSelectorType": "monthSelectorType"; "ignoredFocusElements": "ignoredFocusElements"; }, { "flatpickrReady": "flatpickrReady"; "flatpickrChange": "flatpickrChange"; "flatpickrValueUpdate": "flatpickrValueUpdate"; "flatpickrOpen": "flatpickrOpen"; "flatpickrClose": "flatpickrClose"; "flatpickrMonthChange": "flatpickrMonthChange"; "flatpickrYearChange": "flatpickrYearChange"; "flatpickrDayCreate": "flatpickrDayCreate"; }, never, never, false>;
static ɵdir: i0.ɵɵDirectiveDeclaration<FlatpickrDirective, "[mwlFlatpickr]", ["mwlFlatpickr"], { "options": { "alias": "options"; "required": false; }; "altFormat": { "alias": "altFormat"; "required": false; }; "altInput": { "alias": "altInput"; "required": false; }; "altInputClass": { "alias": "altInputClass"; "required": false; }; "allowInput": { "alias": "allowInput"; "required": false; }; "allowInvalidPreload": { "alias": "allowInvalidPreload"; "required": false; }; "appendTo": { "alias": "appendTo"; "required": false; }; "ariaDateFormat": { "alias": "ariaDateFormat"; "required": false; }; "clickOpens": { "alias": "clickOpens"; "required": false; }; "dateFormat": { "alias": "dateFormat"; "required": false; }; "defaultHour": { "alias": "defaultHour"; "required": false; }; "defaultMinute": { "alias": "defaultMinute"; "required": false; }; "defaultSeconds": { "alias": "defaultSeconds"; "required": false; }; "disable": { "alias": "disable"; "required": false; }; "disableMobile": { "alias": "disableMobile"; "required": false; }; "enable": { "alias": "enable"; "required": false; }; "enableTime": { "alias": "enableTime"; "required": false; }; "enableSeconds": { "alias": "enableSeconds"; "required": false; }; "formatDate": { "alias": "formatDate"; "required": false; }; "hourIncrement": { "alias": "hourIncrement"; "required": false; }; "inline": { "alias": "inline"; "required": false; }; "maxDate": { "alias": "maxDate"; "required": false; }; "minDate": { "alias": "minDate"; "required": false; }; "maxTime": { "alias": "maxTime"; "required": false; }; "minTime": { "alias": "minTime"; "required": false; }; "minuteIncrement": { "alias": "minuteIncrement"; "required": false; }; "mode": { "alias": "mode"; "required": false; }; "nextArrow": { "alias": "nextArrow"; "required": false; }; "noCalendar": { "alias": "noCalendar"; "required": false; }; "now": { "alias": "now"; "required": false; }; "parseDate": { "alias": "parseDate"; "required": false; }; "prevArrow": { "alias": "prevArrow"; "required": false; }; "shorthandCurrentMonth": { "alias": "shorthandCurrentMonth"; "required": false; }; "showMonths": { "alias": "showMonths"; "required": false; }; "static": { "alias": "static"; "required": false; }; "time24hr": { "alias": "time24hr"; "required": false; }; "weekNumbers": { "alias": "weekNumbers"; "required": false; }; "getWeek": { "alias": "getWeek"; "required": false; }; "wrap": { "alias": "wrap"; "required": false; }; "plugins": { "alias": "plugins"; "required": false; }; "locale": { "alias": "locale"; "required": false; }; "convertModelValue": { "alias": "convertModelValue"; "required": false; }; "monthSelectorType": { "alias": "monthSelectorType"; "required": false; }; "ignoredFocusElements": { "alias": "ignoredFocusElements"; "required": false; }; }, { "flatpickrReady": "flatpickrReady"; "flatpickrChange": "flatpickrChange"; "flatpickrValueUpdate": "flatpickrValueUpdate"; "flatpickrOpen": "flatpickrOpen"; "flatpickrClose": "flatpickrClose"; "flatpickrMonthChange": "flatpickrMonthChange"; "flatpickrYearChange": "flatpickrYearChange"; "flatpickrDayCreate": "flatpickrDayCreate"; }, never, never, false, never>;
}
{
"name": "angularx-flatpickr",
"version": "7.3.0",
"description": "An angular 14.0+ wrapper for flatpickr",
"version": "8.0.0",
"description": "An angular 17.0+ wrapper for flatpickr",
"repository": {

@@ -24,4 +24,4 @@ "type": "git",

"peerDependencies": {
"@angular/core": ">=5.0.0",
"@angular/forms": ">=5.0.0",
"@angular/core": ">=17.0.0",
"@angular/forms": ">=17.0.0",
"flatpickr": "^4.5.0"

@@ -34,8 +34,3 @@ },

},
"packageManager": "pnpm@7.30.1",
"module": "fesm2015/angularx-flatpickr.mjs",
"es2020": "fesm2020/angularx-flatpickr.mjs",
"esm2020": "esm2020/angularx-flatpickr.mjs",
"fesm2020": "fesm2020/angularx-flatpickr.mjs",
"fesm2015": "fesm2015/angularx-flatpickr.mjs",
"module": "fesm2022/angularx-flatpickr.mjs",
"typings": "index.d.ts",

@@ -48,7 +43,5 @@ "exports": {

"types": "./index.d.ts",
"esm2020": "./esm2020/angularx-flatpickr.mjs",
"es2020": "./fesm2020/angularx-flatpickr.mjs",
"es2015": "./fesm2015/angularx-flatpickr.mjs",
"node": "./fesm2015/angularx-flatpickr.mjs",
"default": "./fesm2020/angularx-flatpickr.mjs"
"esm2022": "./esm2022/angularx-flatpickr.mjs",
"esm": "./esm2022/angularx-flatpickr.mjs",
"default": "./fesm2022/angularx-flatpickr.mjs"
}

@@ -55,0 +48,0 @@ },

export * from './lib/flatpickr.module';
export { FlatpickrDefaults, FlatpickrDefaultsInterface } from './lib/flatpickr-defaults.service';
export { FlatpickrDefaults, FlatpickrDefaultsInterface, } from './lib/flatpickr-defaults.service';
export { FlatpickrDirective } from './lib/flatpickr.directive';

@@ -23,3 +23,3 @@ # angularx flatpickr

An angular 14.0+ wrapper for flatpickr
An angular 17.0+ wrapper for flatpickr

@@ -55,11 +55,3 @@ ## Installation

@Component({
template: `
<input
type="text"
mwlFlatpickr
[(ngModel)]="selectedDate"
[altInput]="true"
[convertModelValue]="true"
/>
`,
template: ` <input type="text" mwlFlatpickr [(ngModel)]="selectedDate" [altInput]="true" [convertModelValue]="true" /> `,
})

@@ -66,0 +58,0 @@ export class MyComponent {}

/**
* Generated bundle index. Do not edit.
*/
export * from './public-api';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhcngtZmxhdHBpY2tyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhcngtZmxhdHBpY2tyL3NyYy9hbmd1bGFyeC1mbGF0cGlja3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==
import { Injectable } from '@angular/core';
import * as i0 from "@angular/core";
export class FlatpickrDefaults {
constructor() {
/**
* Exactly the same as date format, but for the altInput field.
*/
this.altFormat = 'F j, Y';
/**
* Show the user a readable date (as per altFormat), but return something totally different to the server.
*/
this.altInput = false;
/**
* This class will be added to the input element created by the altInput option.
* Note that `altInput` already inherits classes from the original input.
*/
this.altInputClass = '';
/**
* Allows the user to enter a date directly input the input field. By default, direct entry is disabled.
*/
this.allowInput = false;
/**
* Allows the preloading of an invalid date. When disabled, the field will be cleared if the provided date is invalid
*/
this.allowInvalidPreload = false;
/**
* Instead of `body`, appends the calendar to the specified node instead.
*/
this.appendTo = undefined;
/**
* Defines how the date will be formatted in the aria-label for calendar days, using the same tokens as dateFormat. If you change this, you should choose a value that will make sense if a screen reader reads it out loud.
*/
this.ariaDateFormat = 'F j, Y';
/**
* Whether clicking on the input should open the picker.
* You could disable this if you wish to open the calendar manually `with.open()`.
*/
this.clickOpens = true;
/**
* A string of characters which are used to define how the date will be displayed in the input box.
* The supported characters are defined in the table below.
*/
this.dateFormat = 'Y-m-d';
/**
* Initial value of the hour element.
*/
this.defaultHour = 12;
/**
* Initial value of the minute element.
*/
this.defaultMinute = 0;
/**
* Initial value of the seconds element.
*/
this.defaultSeconds = 0;
/**
* See <a href="https://chmln.github.io/flatpickr/examples/#disabling-specific-dates">disabling dates</a>.
*/
this.disable = [];
/**
* Set disableMobile to true to always use the non-native picker.
* By default, Flatpickr utilizes native datetime widgets unless certain options (e.g. disable) are used.
*/
this.disableMobile = false;
/**
* Enables time picker.
*/
this.enableTime = false;
/**
* Enables seconds in the time picker.
*/
this.enableSeconds = false;
/**
* Allows using a custom date formatting function instead of the built-in handling for date formats using dateFormat, altFormat, etc.
*/
this.formatDate = undefined;
/**
* Adjusts the step for the hour input (incl. scrolling).
*/
this.hourIncrement = 1;
/**
* Displays the calendar inline.
*/
this.inline = false;
/**
* The maximum date that a user can pick to (inclusive).
*/
this.maxDate = undefined;
/**
* The minimum date that a user can start picking from (inclusive).
*/
this.minDate = undefined;
/**
* The maximum time that a user can pick to (inclusive).
*/
this.maxTime = undefined;
/**
* The minimum time that a user can start picking from (inclusive).
*/
this.minTime = undefined;
/**
* Adjusts the step for the minute input (incl. scrolling).
*/
this.minuteIncrement = 5;
/**
* Select a single date, multiple dates or a date range.
*/
this.mode = 'single';
/**
* HTML for the arrow icon, used to switch months.
*/
this.nextArrow = '>';
/**
* Hides the day selection in calendar. Use it along with `enableTime` to create a time picker.
*/
this.noCalendar = false;
/**
* Default now to the current date
*/
this.now = new Date();
/**
* HTML for the left arrow icon.
*/
this.prevArrow = '<';
/**
* Show the month using the shorthand version (ie, Sep instead of September).
*/
this.shorthandCurrentMonth = false;
/**
* Position the calendar inside the wrapper and next to the input element. (Leave `false` unless you know what you're doing).
*/
this.static = false;
/**
* Displays time picker in 24 hour mode without AM/PM selection when enabled.
*/
this.time24hr = false;
/**
* When true, dates will parsed, formatted, and displayed in UTC.
* It's recommended that date strings contain the timezone, but not necessary.
*/
this.utc = false;
/**
* Enables display of week numbers in calendar.
*/
this.weekNumbers = false;
/**
* Custom elements and input groups.
*/
this.wrap = false;
/**
* Array of plugin instances to use.
*/
this.plugins = [];
/**
* The locale object or string to use for the locale.
*/
this.locale = 'default';
/**
* Auto convert the ngModel value from a string to a date / array of dates / from - to date object depending on the `mode`
*/
this.convertModelValue = false;
/**
* The number of months shown.
*/
this.showMonths = 1;
/**
* How the month should be displayed in the header of the calendar.
*/
this.monthSelectorType = 'static';
/**
* Array of HTML elements that should not close the picker on click.
*/
this.ignoredFocusElements = [];
}
}
FlatpickrDefaults.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: FlatpickrDefaults, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
FlatpickrDefaults.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: FlatpickrDefaults });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: FlatpickrDefaults, decorators: [{
type: Injectable
}] });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"flatpickr-defaults.service.js","sourceRoot":"","sources":["../../../../projects/angularx-flatpickr/src/lib/flatpickr-defaults.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;;AAwO3C,MAAM,OAAO,iBAAiB;IAD9B;QAEE;;WAEG;QACH,cAAS,GAAW,QAAQ,CAAC;QAE7B;;WAEG;QACH,aAAQ,GAAY,KAAK,CAAC;QAE1B;;;WAGG;QACH,kBAAa,GAAW,EAAE,CAAC;QAE3B;;WAEG;QACH,eAAU,GAAY,KAAK,CAAC;QAE5B;;WAEG;QACH,wBAAmB,GAAY,KAAK,CAAC;QAErC;;WAEG;QACH,aAAQ,GAA4B,SAAS,CAAC;QAE9C;;WAEG;QACH,mBAAc,GAAY,QAAQ,CAAC;QAEnC;;;WAGG;QACH,eAAU,GAAY,IAAI,CAAC;QAE3B;;;WAGG;QACH,eAAU,GAAW,OAAO,CAAC;QAE7B;;WAEG;QACH,gBAAW,GAAY,EAAE,CAAC;QAE1B;;WAEG;QACH,kBAAa,GAAY,CAAC,CAAC;QAE3B;;WAEG;QACH,mBAAc,GAAY,CAAC,CAAC;QAE5B;;WAEG;QACH,YAAO,GAAwB,EAAE,CAAC;QAElC;;;WAGG;QACH,kBAAa,GAAY,KAAK,CAAC;QAO/B;;WAEG;QACH,eAAU,GAAY,KAAK,CAAC;QAE5B;;WAEG;QACH,kBAAa,GAAY,KAAK,CAAC;QAE/B;;WAEG;QACH,eAAU,GAA4B,SAAS,CAAC;QAEhD;;WAEG;QACH,kBAAa,GAAW,CAAC,CAAC;QAE1B;;WAEG;QACH,WAAM,GAAY,KAAK,CAAC;QAExB;;WAEG;QACH,YAAO,GAA8B,SAAS,CAAC;QAE/C;;WAEG;QACH,YAAO,GAA8B,SAAS,CAAC;QAE/C;;WAEG;QACH,YAAO,GAAuB,SAAS,CAAC;QAExC;;WAEG;QACH,YAAO,GAAuB,SAAS,CAAC;QAExC;;WAEG;QACH,oBAAe,GAAW,CAAC,CAAC;QAE5B;;WAEG;QACH,SAAI,GAAoC,QAAQ,CAAC;QAEjD;;WAEG;QACH,cAAS,GAAW,GAAG,CAAC;QAExB;;WAEG;QACH,eAAU,GAAY,KAAK,CAAC;QAE5B;;WAEG;QACH,QAAG,GAA2B,IAAI,IAAI,EAAE,CAAC;QAOzC;;WAEG;QACH,cAAS,GAAW,GAAG,CAAC;QAExB;;WAEG;QACH,0BAAqB,GAAY,KAAK,CAAC;QAEvC;;WAEG;QACH,WAAM,GAAY,KAAK,CAAC;QAExB;;WAEG;QACH,aAAQ,GAAY,KAAK,CAAC;QAE1B;;;WAGG;QACH,QAAG,GAAY,KAAK,CAAC;QAErB;;WAEG;QACH,gBAAW,GAAY,KAAK,CAAC;QAQ7B;;WAEG;QACH,SAAI,GAAY,KAAK,CAAC;QAEtB;;WAEG;QACH,YAAO,GAAU,EAAE,CAAC;QAEpB;;WAEG;QACH,WAAM,GAAoB,SAAS,CAAC;QAEpC;;WAEG;QACH,sBAAiB,GAAY,KAAK,CAAC;QAEnC;;WAEG;QACH,eAAU,GAAW,CAAC,CAAC;QAEvB;;WAEG;QACH,sBAAiB,GAA0B,QAAQ,CAAC;QAEpD;;WAEG;QACH,yBAAoB,GAAkB,EAAE,CAAC;KAC1C;;8GAlOY,iBAAiB;kHAAjB,iBAAiB;2FAAjB,iBAAiB;kBAD7B,UAAU","sourcesContent":["import { Injectable } from '@angular/core';\n\nexport type DisableEnableDate =\n  | string\n  | Date\n  | { from: Date | string; to: Date | string }\n  | ((date: Date) => boolean);\n\nexport interface FlatpickrDefaultsInterface {\n  /**\n   * Exactly the same as date format, but for the altInput field.\n   */\n  altFormat?: string;\n\n  /**\n   * \tShow the user a readable date (as per altFormat), but return something totally different to the server.\n   */\n  altInput?: boolean;\n\n  /**\n   * This class will be added to the input element created by the altInput option.\n   * Note that `altInput` already inherits classes from the original input.\n   */\n  altInputClass?: string;\n\n  /**\n   * Allows the user to enter a date directly input the input field. By default, direct entry is disabled.\n   */\n  allowInput?: boolean;\n\n  /**\n   * Allows the preloading of an invalid date. When disabled, the field will be cleared if the provided date is invalid\n   */\n  allowInvalidPreload?: boolean;\n\n  /**\n   * Instead of `body`, appends the calendar to the specified node instead.\n   */\n  appendTo?: HTMLElement;\n\n  /**\n   * Defines how the date will be formatted in the aria-label for calendar days, using the same tokens as dateFormat. If you change this, you should choose a value that will make sense if a screen reader reads it out loud.\n   */\n  ariaDateFormat?: string;\n\n  /**\n   * Whether clicking on the input should open the picker.\n   * You could disable this if you wish to open the calendar manually `with.open()`.\n   */\n  clickOpens?: boolean;\n\n  /**\n   * A string of characters which are used to define how the date will be displayed in the input box.\n   * The supported characters are defined in the table below.\n   */\n  dateFormat?: string;\n  /**\n   * Initial value of the hour element.\n   */\n  defaultHour?: number;\n  /**\n   * Initial value of the minute element.\n   */\n  defaultMinute?: number;\n  /**\n   * Initial value of the seconds element.\n   */\n  defaultSeconds?: number;\n\n  /**\n   * See <a href=\"https://chmln.github.io/flatpickr/examples/#disabling-specific-dates\">disabling dates</a>.\n   */\n  disable?: DisableEnableDate[];\n\n  /**\n   * Set disableMobile to true to always use the non-native picker.\n   * By default, Flatpickr utilizes native datetime widgets unless certain options (e.g. disable) are used.\n   */\n  disableMobile?: boolean;\n\n  /**\n   * See <a href=\"https://chmln.github.io/flatpickr/examples/#disabling-all-dates-except-select-few\">enabling dates</a>.\n   */\n  enable?: DisableEnableDate[];\n\n  /**\n   * Enables time picker.\n   */\n  enableTime?: boolean;\n\n  /**\n   * Enables seconds in the time picker.\n   */\n  enableSeconds?: boolean;\n  /**\n   * Allows using a custom date formatting function instead of the built-in handling for date formats using dateFormat, altFormat, etc.\n   */\n  formatDate?: (value: any) => string;\n  /**\n   * Adjusts the step for the hour input (incl. scrolling).\n   */\n  hourIncrement?: number;\n\n  /**\n   * Displays the calendar inline.\n   */\n  inline?: boolean;\n\n  /**\n   * The maximum date that a user can pick to (inclusive).\n   */\n  maxDate?: string | Date;\n\n  /**\n   * The minimum date that a user can start picking from (inclusive).\n   */\n  minDate?: string | Date;\n\n  /**\n   * The maximum time that a user can pick to (inclusive).\n   */\n  maxTime?: string;\n\n  /**\n   * The minimum time that a user can start picking from (inclusive).\n   */\n  minTime?: string;\n\n  /**\n   * Adjusts the step for the minute input (incl. scrolling).\n   */\n  minuteIncrement?: number;\n\n  /**\n   * Select a single date, multiple dates or a date range.\n   */\n  mode?: 'single' | 'multiple' | 'range';\n\n  /**\n   * HTML for the arrow icon, used to switch months.\n   */\n  nextArrow?: string;\n\n  /**\n   * Hides the day selection in calendar. Use it along with `enableTime` to create a time picker.\n   */\n  noCalendar?: boolean;\n\n  /**\n   * Provide a date for 'today', which will be used instead of \"new Date()\"\n   */\n  now?: Date | string | number;\n\n  /**\n   * Function that expects a date string and must return a Date object.\n   */\n  parseDate?: (str: string) => Date;\n\n  /**\n   * HTML for the left arrow icon.\n   */\n  prevArrow?: string;\n\n  /**\n   * Show the month using the shorthand version (ie, Sep instead of September).\n   */\n  shorthandCurrentMonth?: boolean;\n\n  /**\n   * Position the calendar inside the wrapper and next to the input element. (Leave `false` unless you know what you're doing).\n   */\n  static?: boolean;\n\n  /**\n   * Displays time picker in 24 hour mode without AM/PM selection when enabled.\n   */\n  time24hr?: boolean;\n\n  /**\n   * When true, dates will parsed, formatted, and displayed in UTC.\n   * It's recommended that date strings contain the timezone, but not necessary.\n   */\n  utc?: boolean;\n\n  /**\n   * Enables display of week numbers in calendar.\n   */\n  weekNumbers?: boolean;\n\n  /**\n   * You may override the function that extracts the week numbers from a Date by supplying a getWeek function.\n   * It takes in a date as a parameter and should return a corresponding string that you want to appear left of every week.\n   */\n  getWeek?: (date: Date) => string;\n\n  /**\n   * Custom elements and input groups.\n   */\n  wrap?: boolean;\n\n  /**\n   * Array of plugin instances to use.\n   */\n  plugins?: any[];\n\n  /**\n   * The locale object or string to use for the locale.\n   */\n  locale?: object | string;\n\n  /**\n   * Auto convert the ngModel value from a string to a date / array of dates / from - to date object depending on the `mode`\n   */\n  convertModelValue?: boolean;\n\n  /**\n   * The number of months shown.\n   */\n  showMonths?: number;\n\n  /**\n   * How the month should be displayed in the header of the calendar.\n   */\n  monthSelectorType?: 'static' | 'dropdown';\n\n  /**\n   * Array of HTML elements that should not close the picker on click.\n   */\n  ignoredFocusElements?: HTMLElement[];\n}\n\n@Injectable()\nexport class FlatpickrDefaults implements FlatpickrDefaultsInterface {\n  /**\n   * Exactly the same as date format, but for the altInput field.\n   */\n  altFormat: string = 'F j, Y';\n\n  /**\n   * \tShow the user a readable date (as per altFormat), but return something totally different to the server.\n   */\n  altInput: boolean = false;\n\n  /**\n   * This class will be added to the input element created by the altInput option.\n   * Note that `altInput` already inherits classes from the original input.\n   */\n  altInputClass: string = '';\n\n  /**\n   * Allows the user to enter a date directly input the input field. By default, direct entry is disabled.\n   */\n  allowInput: boolean = false;\n\n  /**\n   * Allows the preloading of an invalid date. When disabled, the field will be cleared if the provided date is invalid\n   */\n  allowInvalidPreload: boolean = false;\n\n  /**\n   * Instead of `body`, appends the calendar to the specified node instead.\n   */\n  appendTo: HTMLElement | undefined = undefined;\n\n  /**\n   * Defines how the date will be formatted in the aria-label for calendar days, using the same tokens as dateFormat. If you change this, you should choose a value that will make sense if a screen reader reads it out loud.\n   */\n  ariaDateFormat?: string = 'F j, Y';\n\n  /**\n   * Whether clicking on the input should open the picker.\n   * You could disable this if you wish to open the calendar manually `with.open()`.\n   */\n  clickOpens: boolean = true;\n\n  /**\n   * A string of characters which are used to define how the date will be displayed in the input box.\n   * The supported characters are defined in the table below.\n   */\n  dateFormat: string = 'Y-m-d';\n\n  /**\n   * Initial value of the hour element.\n   */\n  defaultHour?: number = 12;\n\n  /**\n   * Initial value of the minute element.\n   */\n  defaultMinute?: number = 0;\n\n  /**\n   * Initial value of the seconds element.\n   */\n  defaultSeconds?: number = 0;\n\n  /**\n   * See <a href=\"https://chmln.github.io/flatpickr/examples/#disabling-specific-dates\">disabling dates</a>.\n   */\n  disable: DisableEnableDate[] = [];\n\n  /**\n   * Set disableMobile to true to always use the non-native picker.\n   * By default, Flatpickr utilizes native datetime widgets unless certain options (e.g. disable) are used.\n   */\n  disableMobile: boolean = false;\n\n  /**\n   * See <a href=\"https://chmln.github.io/flatpickr/examples/#disabling-all-dates-except-select-few\">enabling dates</a>.\n   */\n  enable: DisableEnableDate[];\n\n  /**\n   * Enables time picker.\n   */\n  enableTime: boolean = false;\n\n  /**\n   * Enables seconds in the time picker.\n   */\n  enableSeconds: boolean = false;\n\n  /**\n   * Allows using a custom date formatting function instead of the built-in handling for date formats using dateFormat, altFormat, etc.\n   */\n  formatDate?: (value: any) => string = undefined;\n\n  /**\n   * Adjusts the step for the hour input (incl. scrolling).\n   */\n  hourIncrement: number = 1;\n\n  /**\n   * Displays the calendar inline.\n   */\n  inline: boolean = false;\n\n  /**\n   * The maximum date that a user can pick to (inclusive).\n   */\n  maxDate: string | Date | undefined = undefined;\n\n  /**\n   * The minimum date that a user can start picking from (inclusive).\n   */\n  minDate: string | Date | undefined = undefined;\n\n  /**\n   * The maximum time that a user can pick to (inclusive).\n   */\n  maxTime: string | undefined = undefined;\n\n  /**\n   * The minimum time that a user can start picking from (inclusive).\n   */\n  minTime: string | undefined = undefined;\n\n  /**\n   * Adjusts the step for the minute input (incl. scrolling).\n   */\n  minuteIncrement: number = 5;\n\n  /**\n   * Select a single date, multiple dates or a date range.\n   */\n  mode: 'single' | 'multiple' | 'range' = 'single';\n\n  /**\n   * HTML for the arrow icon, used to switch months.\n   */\n  nextArrow: string = '>';\n\n  /**\n   * Hides the day selection in calendar. Use it along with `enableTime` to create a time picker.\n   */\n  noCalendar: boolean = false;\n\n  /**\n   * Default now to the current date\n   */\n  now: Date | string | number = new Date();\n\n  /**\n   * Function that expects a date string and must return a Date object.\n   */\n  parseDate: (str: string) => Date;\n\n  /**\n   * HTML for the left arrow icon.\n   */\n  prevArrow: string = '<';\n\n  /**\n   * Show the month using the shorthand version (ie, Sep instead of September).\n   */\n  shorthandCurrentMonth: boolean = false;\n\n  /**\n   * Position the calendar inside the wrapper and next to the input element. (Leave `false` unless you know what you're doing).\n   */\n  static: boolean = false;\n\n  /**\n   * Displays time picker in 24 hour mode without AM/PM selection when enabled.\n   */\n  time24hr: boolean = false;\n\n  /**\n   * When true, dates will parsed, formatted, and displayed in UTC.\n   * It's recommended that date strings contain the timezone, but not necessary.\n   */\n  utc: boolean = false;\n\n  /**\n   * Enables display of week numbers in calendar.\n   */\n  weekNumbers: boolean = false;\n\n  /**\n   * You may override the function that extracts the week numbers from a Date by supplying a getWeek function.\n   * It takes in a date as a parameter and should return a corresponding string that you want to appear left of every week.\n   */\n  getWeek: (date: Date) => string;\n\n  /**\n   * Custom elements and input groups.\n   */\n  wrap: boolean = false;\n\n  /**\n   * Array of plugin instances to use.\n   */\n  plugins: any[] = [];\n\n  /**\n   * The locale object or string to use for the locale.\n   */\n  locale: object | string = 'default';\n\n  /**\n   * Auto convert the ngModel value from a string to a date / array of dates / from - to date object depending on the `mode`\n   */\n  convertModelValue: boolean = false;\n\n  /**\n   * The number of months shown.\n   */\n  showMonths: number = 1;\n\n  /**\n   * How the month should be displayed in the header of the calendar.\n   */\n  monthSelectorType: 'static' | 'dropdown' = 'static';\n\n  /**\n   * Array of HTML elements that should not close the picker on click.\n   */\n  ignoredFocusElements: HTMLElement[] = [];\n}\n"]}
import { Directive, Input, Output, EventEmitter, forwardRef, HostListener, } from '@angular/core';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
import flatpickr from 'flatpickr';
import * as i0 from "@angular/core";
import * as i1 from "./flatpickr-defaults.service";
export const FLATPICKR_CONTROL_VALUE_ACCESSOR = {
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(() => FlatpickrDirective),
multi: true,
};
export class FlatpickrDirective {
constructor(elm, defaults, renderer) {
this.elm = elm;
this.defaults = defaults;
this.renderer = renderer;
/**
* Object-options that can be user for multiple instances of Flatpickr.
* Option from this object is applied only if specific option is not specified.
* Example:
* ```typescript
* options: FlatpickrDefaultsInterface = {
* altFormat: 'd/m/Y', // will be ignored since altFormat is provided via specific attribute
* altInput: true // will be used since specific attribute is not provided
* };
* ```
* ```html
* <input
* class="form-control"
* type="text"
* mwlFlatpickr
* [options]="options"
* altFormat="d/m/Y">
* ```
*/
this.options = {};
/**
* Array of HTML elements that should not close the picker on click.
*/
this.ignoredFocusElements = [];
/**
* Gets triggered once the calendar is in a ready state
*/
this.flatpickrReady = new EventEmitter();
/**
* Gets triggered when the user selects a date, or changes the time on a selected date.
*/
this.flatpickrChange = new EventEmitter();
/**
* Gets triggered when the input value is updated with a new date string.
*/
this.flatpickrValueUpdate = new EventEmitter();
/**
* Gets triggered when the calendar is opened.
*/
this.flatpickrOpen = new EventEmitter();
/**
* Gets triggered when the calendar is closed.
*/
this.flatpickrClose = new EventEmitter();
/**
* Gets triggered when the month is changed, either by the user or programmatically.
*/
this.flatpickrMonthChange = new EventEmitter();
/**
* Gets triggered when the year is changed, either by the user or programmatically.
*/
this.flatpickrYearChange = new EventEmitter();
/**
* Take full control of every date cell with this output
*/
this.flatpickrDayCreate = new EventEmitter();
this.isDisabled = false;
this.onChangeFn = () => { };
this.onTouchedFn = () => { };
}
ngAfterViewInit() {
const options = {
altFormat: this.altFormat,
altInput: this.altInput,
altInputClass: this.altInputClass,
allowInput: this.allowInput,
allowInvalidPreload: this.allowInvalidPreload,
appendTo: this.appendTo,
ariaDateFormat: this.ariaDateFormat,
clickOpens: this.clickOpens,
dateFormat: this.dateFormat,
defaultHour: this.defaultHour,
defaultMinute: this.defaultMinute,
defaultSeconds: this.defaultSeconds,
disable: this.disable,
disableMobile: this.disableMobile,
enable: this.enable,
enableTime: this.enableTime,
enableSeconds: this.enableSeconds,
formatDate: this.formatDate,
hourIncrement: this.hourIncrement,
defaultDate: this.initialValue,
inline: this.inline,
maxDate: this.maxDate,
minDate: this.minDate,
maxTime: this.maxTime,
minTime: this.minTime,
minuteIncrement: this.minuteIncrement,
mode: this.mode,
nextArrow: this.nextArrow,
noCalendar: this.noCalendar,
now: this.now,
parseDate: this.parseDate,
prevArrow: this.prevArrow,
shorthandCurrentMonth: this.shorthandCurrentMonth,
showMonths: this.showMonths,
monthSelectorType: this.monthSelectorType,
static: this.static,
time24hr: this.time24hr,
weekNumbers: this.weekNumbers,
getWeek: this.getWeek,
wrap: this.wrap,
plugins: this.plugins,
locale: this.locale,
ignoredFocusElements: this.ignoredFocusElements,
onChange: (selectedDates, dateString, instance) => {
this.flatpickrChange.emit({ selectedDates, dateString, instance });
},
onOpen: (selectedDates, dateString, instance) => {
this.flatpickrOpen.emit({ selectedDates, dateString, instance });
},
onClose: (selectedDates, dateString, instance) => {
this.flatpickrClose.emit({ selectedDates, dateString, instance });
},
onMonthChange: (selectedDates, dateString, instance) => {
this.flatpickrMonthChange.emit({ selectedDates, dateString, instance });
},
onYearChange: (selectedDates, dateString, instance) => {
this.flatpickrYearChange.emit({ selectedDates, dateString, instance });
},
onReady: (selectedDates, dateString, instance) => {
this.flatpickrReady.emit({ selectedDates, dateString, instance });
},
onValueUpdate: (selectedDates, dateString, instance) => {
this.flatpickrValueUpdate.emit({ selectedDates, dateString, instance });
},
onDayCreate: (selectedDates, dateString, instance, dayElement) => {
this.flatpickrDayCreate.emit({
selectedDates,
dateString,
instance,
dayElement,
});
},
};
Object.keys(options).forEach((key) => {
if (typeof options[key] === 'undefined') {
if (typeof this.options[key] !== 'undefined') {
options[key] = this.options[key];
}
else {
options[key] = this.defaults[key];
}
}
});
// @ts-ignore
options.time_24hr = options.time24hr;
// workaround bug in flatpickr 4.6 where it doesn't copy the classes across
// TODO - remove once fix in https://github.com/flatpickr/flatpickr/issues/1860 is released
options.altInputClass =
(options.altInputClass || '') + ' ' + this.elm.nativeElement.className;
if (!options.enable) {
delete options.enable;
}
this.instance = flatpickr(this.elm.nativeElement, options);
this.setDisabledState(this.isDisabled);
}
ngOnChanges(changes) {
if (this.instance) {
Object.keys(changes).forEach((inputKey) => {
this.instance.set(inputKey, this[inputKey]);
});
}
}
ngOnDestroy() {
if (this.instance) {
this.instance.destroy();
}
}
writeValue(value) {
let convertedValue = value;
if (this.convertModelValue && this.mode === 'range' && value) {
convertedValue = [value.from, value.to];
}
if (this.instance) {
this.instance.setDate(convertedValue);
}
else {
// flatpickr hasn't been initialised yet, store the value for later use
this.initialValue = convertedValue;
}
}
registerOnChange(fn) {
this.onChangeFn = fn;
}
registerOnTouched(fn) {
this.onTouchedFn = fn;
}
setDisabledState(isDisabled) {
this.isDisabled = isDisabled;
if (this.instance) {
if (this.isDisabled) {
this.renderer.setProperty(this.instance._input, 'disabled', 'disabled');
}
else {
this.renderer.removeAttribute(this.instance._input, 'disabled');
}
}
}
inputChanged() {
const value = this.elm.nativeElement.value;
if (this.convertModelValue && typeof value === 'string') {
switch (this.mode) {
case 'multiple':
const dates = value
.split('; ')
.map((str) => this.instance.parseDate(str, this.instance.config.dateFormat, !this.instance.config.enableTime));
this.onChangeFn(dates);
break;
case 'range':
const [from, to] = value
.split(this.instance.l10n.rangeSeparator)
.map((str) => this.instance.parseDate(str, this.instance.config.dateFormat, !this.instance.config.enableTime));
this.onChangeFn({ from, to });
break;
case 'single':
default:
this.onChangeFn(this.instance.parseDate(value, this.instance.config.dateFormat, !this.instance.config.enableTime));
}
}
else {
this.onChangeFn(value);
}
}
}
FlatpickrDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: FlatpickrDirective, deps: [{ token: i0.ElementRef }, { token: i1.FlatpickrDefaults }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
FlatpickrDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.1.2", type: FlatpickrDirective, selector: "[mwlFlatpickr]", inputs: { options: "options", altFormat: "altFormat", altInput: "altInput", altInputClass: "altInputClass", allowInput: "allowInput", allowInvalidPreload: "allowInvalidPreload", appendTo: "appendTo", ariaDateFormat: "ariaDateFormat", clickOpens: "clickOpens", dateFormat: "dateFormat", defaultHour: "defaultHour", defaultMinute: "defaultMinute", defaultSeconds: "defaultSeconds", disable: "disable", disableMobile: "disableMobile", enable: "enable", enableTime: "enableTime", enableSeconds: "enableSeconds", formatDate: "formatDate", hourIncrement: "hourIncrement", inline: "inline", maxDate: "maxDate", minDate: "minDate", maxTime: "maxTime", minTime: "minTime", minuteIncrement: "minuteIncrement", mode: "mode", nextArrow: "nextArrow", noCalendar: "noCalendar", now: "now", parseDate: "parseDate", prevArrow: "prevArrow", shorthandCurrentMonth: "shorthandCurrentMonth", showMonths: "showMonths", static: "static", time24hr: "time24hr", weekNumbers: "weekNumbers", getWeek: "getWeek", wrap: "wrap", plugins: "plugins", locale: "locale", convertModelValue: "convertModelValue", monthSelectorType: "monthSelectorType", ignoredFocusElements: "ignoredFocusElements" }, outputs: { flatpickrReady: "flatpickrReady", flatpickrChange: "flatpickrChange", flatpickrValueUpdate: "flatpickrValueUpdate", flatpickrOpen: "flatpickrOpen", flatpickrClose: "flatpickrClose", flatpickrMonthChange: "flatpickrMonthChange", flatpickrYearChange: "flatpickrYearChange", flatpickrDayCreate: "flatpickrDayCreate" }, host: { listeners: { "blur": "onTouchedFn()", "input": "inputChanged()" } }, providers: [FLATPICKR_CONTROL_VALUE_ACCESSOR], exportAs: ["mwlFlatpickr"], usesOnChanges: true, ngImport: i0 });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: FlatpickrDirective, decorators: [{
type: Directive,
args: [{
selector: '[mwlFlatpickr]',
providers: [FLATPICKR_CONTROL_VALUE_ACCESSOR],
exportAs: 'mwlFlatpickr',
}]
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.FlatpickrDefaults }, { type: i0.Renderer2 }]; }, propDecorators: { options: [{
type: Input
}], altFormat: [{
type: Input
}], altInput: [{
type: Input
}], altInputClass: [{
type: Input
}], allowInput: [{
type: Input
}], allowInvalidPreload: [{
type: Input
}], appendTo: [{
type: Input
}], ariaDateFormat: [{
type: Input
}], clickOpens: [{
type: Input
}], dateFormat: [{
type: Input
}], defaultHour: [{
type: Input
}], defaultMinute: [{
type: Input
}], defaultSeconds: [{
type: Input
}], disable: [{
type: Input
}], disableMobile: [{
type: Input
}], enable: [{
type: Input
}], enableTime: [{
type: Input
}], enableSeconds: [{
type: Input
}], formatDate: [{
type: Input
}], hourIncrement: [{
type: Input
}], inline: [{
type: Input
}], maxDate: [{
type: Input
}], minDate: [{
type: Input
}], maxTime: [{
type: Input
}], minTime: [{
type: Input
}], minuteIncrement: [{
type: Input
}], mode: [{
type: Input
}], nextArrow: [{
type: Input
}], noCalendar: [{
type: Input
}], now: [{
type: Input
}], parseDate: [{
type: Input
}], prevArrow: [{
type: Input
}], shorthandCurrentMonth: [{
type: Input
}], showMonths: [{
type: Input
}], static: [{
type: Input
}], time24hr: [{
type: Input
}], weekNumbers: [{
type: Input
}], getWeek: [{
type: Input
}], wrap: [{
type: Input
}], plugins: [{
type: Input
}], locale: [{
type: Input
}], convertModelValue: [{
type: Input
}], monthSelectorType: [{
type: Input
}], ignoredFocusElements: [{
type: Input
}], flatpickrReady: [{
type: Output
}], flatpickrChange: [{
type: Output
}], flatpickrValueUpdate: [{
type: Output
}], flatpickrOpen: [{
type: Output
}], flatpickrClose: [{
type: Output
}], flatpickrMonthChange: [{
type: Output
}], flatpickrYearChange: [{
type: Output
}], flatpickrDayCreate: [{
type: Output
}], onTouchedFn: [{
type: HostListener,
args: ['blur']
}], inputChanged: [{
type: HostListener,
args: ['input']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"flatpickr.directive.js","sourceRoot":"","sources":["../../../../projects/angularx-flatpickr/src/lib/flatpickr.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  AfterViewInit,\n  Input,\n  Output,\n  EventEmitter,\n  OnChanges,\n  SimpleChanges,\n  OnDestroy,\n  forwardRef,\n  HostListener,\n  Renderer2,\n} from '@angular/core';\nimport {\n  FlatpickrDefaults,\n  DisableEnableDate,\n  FlatpickrDefaultsInterface,\n} from './flatpickr-defaults.service';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport flatpickr from 'flatpickr';\n\nexport interface FlatPickrOutputOptions {\n  selectedDates: Date[];\n  dateString: string;\n  instance: any;\n}\n\nexport interface FlatPickrDayCreateOutputOptions\n  extends FlatPickrOutputOptions {\n  dayElement: HTMLElement;\n}\n\nexport const FLATPICKR_CONTROL_VALUE_ACCESSOR: any = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => FlatpickrDirective),\n  multi: true,\n};\n\n@Directive({\n  selector: '[mwlFlatpickr]',\n  providers: [FLATPICKR_CONTROL_VALUE_ACCESSOR],\n  exportAs: 'mwlFlatpickr',\n})\nexport class FlatpickrDirective\n  implements AfterViewInit, OnChanges, OnDestroy, ControlValueAccessor\n{\n  /**\n   * Object-options that can be user for multiple instances of Flatpickr.\n   * Option from this object is applied only if specific option is not specified.\n   * Example:\n   * ```typescript\n   * options: FlatpickrDefaultsInterface = {\n   *      altFormat: 'd/m/Y',   // will be ignored since altFormat is provided via specific attribute\n   *      altInput: true        // will be used since specific attribute is not provided\n   * };\n   * ```\n   * ```html\n   * <input\n   *   class=\"form-control\"\n   *   type=\"text\"\n   *   mwlFlatpickr\n   *   [options]=\"options\"\n   *   altFormat=\"d/m/Y\">\n   * ```\n   */\n  @Input() options: FlatpickrDefaultsInterface = {};\n\n  /**\n   * Exactly the same as date format, but for the altInput field.\n   */\n  @Input() altFormat: string;\n\n  /**\n   * \tShow the user a readable date (as per altFormat), but return something totally different to the server.\n   */\n  @Input() altInput: boolean;\n\n  /**\n   * This class will be added to the input element created by the altInput option.\n   * Note that `altInput` already inherits classes from the original input.\n   */\n  @Input() altInputClass: string;\n\n  /**\n   * Allows the user to enter a date directly input the input field. By default, direct entry is disabled.\n   */\n  @Input() allowInput: boolean;\n\n\n  /**\n   * Allows the preloading of an invalid date. When disabled, the field will be cleared if the provided date is invalid\n   */\n  @Input() allowInvalidPreload: boolean;\n\n  /**\n   * Instead of `body`, appends the calendar to the specified node instead.\n   */\n  @Input() appendTo: HTMLElement;\n\n  /**\n   * Defines how the date will be formatted in the aria-label for calendar days, using the same tokens as dateFormat. If you change this, you should choose a value that will make sense if a screen reader reads it out loud.\n   */\n  @Input() ariaDateFormat?: string;\n\n  /**\n   * Whether clicking on the input should open the picker.\n   * You could disable this if you wish to open the calendar manually `with.open()`.\n   */\n  @Input() clickOpens: boolean;\n\n  /**\n   * A string of characters which are used to define how the date will be displayed in the input box.\n   * The supported characters are defined in the table below.\n   */\n  @Input() dateFormat: string;\n\n  /**\n   * Initial value of the hour element.\n   */\n  @Input() defaultHour?: number;\n  /**\n   * Initial value of the minute element.\n   */\n  @Input() defaultMinute?: number;\n\n  /**\n   * Initial value of the seconds element.\n   */\n  @Input() defaultSeconds?: number;\n\n  /**\n   * See <a href=\"https://chmln.github.io/flatpickr/examples/#disabling-specific-dates\">disabling dates</a>.\n   */\n  @Input() disable: DisableEnableDate[];\n\n  /**\n   * Set disableMobile to true to always use the non-native picker.\n   * By default, Flatpickr utilizes native datetime widgets unless certain options (e.g. disable) are used.\n   */\n  @Input() disableMobile: boolean;\n\n  /**\n   * See <a href=\"https://chmln.github.io/flatpickr/examples/#disabling-all-dates-except-select-few\">enabling dates</a>.\n   */\n  @Input() enable: DisableEnableDate[];\n\n  /**\n   * Enables time picker.\n   */\n  @Input() enableTime: boolean;\n\n  /**\n   * Enables seconds in the time picker.\n   */\n  @Input() enableSeconds: boolean;\n\n  /**\n   * Allows using a custom date formatting function instead of the built-in handling for date formats using dateFormat, altFormat, etc.\n   */\n  @Input() formatDate?: (value: any) => string;\n\n  /**\n   * Adjusts the step for the hour input (incl. scrolling).\n   */\n  @Input() hourIncrement: number;\n\n  /**\n   * Displays the calendar inline.\n   */\n  @Input() inline: boolean;\n\n  /**\n   * The maximum date that a user can pick to (inclusive).\n   */\n  @Input() maxDate: string | Date;\n\n  /**\n   * The minimum date that a user can start picking from (inclusive).\n   */\n  @Input() minDate: string | Date;\n\n  /**\n   * The maximum time that a user can pick to (inclusive).\n   */\n  @Input() maxTime: string;\n\n  /**\n   * The minimum time that a user can start picking from (inclusive).\n   */\n  @Input() minTime: string;\n\n  /**\n   * Adjusts the step for the minute input (incl. scrolling).\n   */\n  @Input() minuteIncrement: number;\n\n  /**\n   * Select a single date, multiple dates or a date range.\n   */\n  @Input() mode: 'single' | 'multiple' | 'range';\n\n  /**\n   * HTML for the arrow icon, used to switch months.\n   */\n  @Input() nextArrow: string;\n\n  /**\n   * Hides the day selection in calendar. Use it along with `enableTime` to create a time picker.\n   */\n  @Input() noCalendar: boolean;\n\n  /**\n   * Provide a date for 'today', which will be used instead of \"new Date()\"\n   */\n  @Input() now?: Date | string | number;\n\n  /**\n   * Function that expects a date string and must return a Date object.\n   */\n  @Input() parseDate: (str: string) => Date;\n\n  /**\n   * HTML for the left arrow icon.\n   */\n  @Input() prevArrow: string;\n\n  /**\n   * Show the month using the shorthand version (ie, Sep instead of September).\n   */\n  @Input() shorthandCurrentMonth: boolean;\n\n  /**\n   * The number of months shown.\n   */\n  @Input() showMonths: number;\n\n  /**\n   * Position the calendar inside the wrapper and next to the input element. (Leave `false` unless you know what you're doing).\n   */\n  @Input() static: boolean;\n\n  /**\n   * Displays time picker in 24 hour mode without AM/PM selection when enabled.\n   */\n  @Input() time24hr: boolean;\n\n  /**\n   * Enables display of week numbers in calendar.\n   */\n  @Input() weekNumbers: boolean;\n\n  /**\n   * You may override the function that extracts the week numbers from a Date by supplying a getWeek function.\n   * It takes in a date as a parameter and should return a corresponding string that you want to appear left of every week.\n   */\n  @Input() getWeek: (date: Date) => string;\n\n  /**\n   * Custom elements and input groups.\n   */\n  @Input() wrap: boolean;\n\n  /**\n   * Array of plugin instances to use.\n   */\n  @Input() plugins: any[];\n\n  /**\n   * The locale object or string to use for the locale.\n   */\n  @Input() locale: object | string;\n\n  /**\n   * Auto convert the ngModel value from a string to a date / array of dates / from - to date object depending on the `mode`\n   */\n  @Input() convertModelValue: boolean;\n\n  /**\n   * How the month should be displayed in the header of the calendar.\n   */\n  @Input() monthSelectorType: 'static' | 'dropdown';\n\n  /**\n   * Array of HTML elements that should not close the picker on click.\n   */\n  @Input() ignoredFocusElements: HTMLElement[] = [];\n\n  /**\n   * Gets triggered once the calendar is in a ready state\n   */\n  @Output()\n  flatpickrReady: EventEmitter<FlatPickrOutputOptions> = new EventEmitter();\n\n  /**\n   * Gets triggered when the user selects a date, or changes the time on a selected date.\n   */\n  @Output()\n  flatpickrChange: EventEmitter<FlatPickrOutputOptions> = new EventEmitter();\n\n  /**\n   * Gets triggered when the input value is updated with a new date string.\n   */\n  @Output()\n  flatpickrValueUpdate: EventEmitter<FlatPickrOutputOptions> =\n    new EventEmitter();\n\n  /**\n   * Gets triggered when the calendar is opened.\n   */\n  @Output()\n  flatpickrOpen: EventEmitter<FlatPickrOutputOptions> = new EventEmitter();\n\n  /**\n   * Gets triggered when the calendar is closed.\n   */\n  @Output()\n  flatpickrClose: EventEmitter<FlatPickrOutputOptions> = new EventEmitter();\n\n  /**\n   * Gets triggered when the month is changed, either by the user or programmatically.\n   */\n  @Output()\n  flatpickrMonthChange: EventEmitter<FlatPickrOutputOptions> =\n    new EventEmitter();\n\n  /**\n   * Gets triggered when the year is changed, either by the user or programmatically.\n   */\n  @Output()\n  flatpickrYearChange: EventEmitter<FlatPickrOutputOptions> =\n    new EventEmitter();\n\n  /**\n   * Take full control of every date cell with this output\n   */\n  @Output()\n  flatpickrDayCreate: EventEmitter<FlatPickrDayCreateOutputOptions> =\n    new EventEmitter();\n\n  /**\n   * The flatpickr instance where you can call methods like toggle(), open(), close() etc\n   */\n  instance: flatpickr.Instance;\n\n  private isDisabled = false;\n  private initialValue: any;\n\n  onChangeFn: (value: any) => void = () => {};\n\n  @HostListener('blur')\n  onTouchedFn = () => {};\n\n  constructor(\n    private elm: ElementRef,\n    private defaults: FlatpickrDefaults,\n    private renderer: Renderer2\n  ) {}\n\n  ngAfterViewInit(): void {\n    const options: any = {\n      altFormat: this.altFormat,\n      altInput: this.altInput,\n      altInputClass: this.altInputClass,\n      allowInput: this.allowInput,\n      allowInvalidPreload: this.allowInvalidPreload,\n      appendTo: this.appendTo,\n      ariaDateFormat: this.ariaDateFormat,\n      clickOpens: this.clickOpens,\n      dateFormat: this.dateFormat,\n      defaultHour: this.defaultHour,\n      defaultMinute: this.defaultMinute,\n      defaultSeconds: this.defaultSeconds,\n      disable: this.disable,\n      disableMobile: this.disableMobile,\n      enable: this.enable,\n      enableTime: this.enableTime,\n      enableSeconds: this.enableSeconds,\n      formatDate: this.formatDate,\n      hourIncrement: this.hourIncrement,\n      defaultDate: this.initialValue,\n      inline: this.inline,\n      maxDate: this.maxDate,\n      minDate: this.minDate,\n      maxTime: this.maxTime,\n      minTime: this.minTime,\n      minuteIncrement: this.minuteIncrement,\n      mode: this.mode,\n      nextArrow: this.nextArrow,\n      noCalendar: this.noCalendar,\n      now: this.now,\n      parseDate: this.parseDate,\n      prevArrow: this.prevArrow,\n      shorthandCurrentMonth: this.shorthandCurrentMonth,\n      showMonths: this.showMonths,\n      monthSelectorType: this.monthSelectorType,\n      static: this.static,\n      time24hr: this.time24hr,\n      weekNumbers: this.weekNumbers,\n      getWeek: this.getWeek,\n      wrap: this.wrap,\n      plugins: this.plugins,\n      locale: this.locale,\n      ignoredFocusElements: this.ignoredFocusElements,\n      onChange: (selectedDates: Date[], dateString: string, instance: any) => {\n        this.flatpickrChange.emit({ selectedDates, dateString, instance });\n      },\n      onOpen: (selectedDates: Date[], dateString: string, instance: any) => {\n        this.flatpickrOpen.emit({ selectedDates, dateString, instance });\n      },\n      onClose: (selectedDates: Date[], dateString: string, instance: any) => {\n        this.flatpickrClose.emit({ selectedDates, dateString, instance });\n      },\n      onMonthChange: (\n        selectedDates: Date[],\n        dateString: string,\n        instance: any\n      ) => {\n        this.flatpickrMonthChange.emit({ selectedDates, dateString, instance });\n      },\n      onYearChange: (\n        selectedDates: Date[],\n        dateString: string,\n        instance: any\n      ) => {\n        this.flatpickrYearChange.emit({ selectedDates, dateString, instance });\n      },\n      onReady: (selectedDates: Date[], dateString: string, instance: any) => {\n        this.flatpickrReady.emit({ selectedDates, dateString, instance });\n      },\n      onValueUpdate: (\n        selectedDates: Date[],\n        dateString: string,\n        instance: any\n      ) => {\n        this.flatpickrValueUpdate.emit({ selectedDates, dateString, instance });\n      },\n      onDayCreate: (\n        selectedDates: Date[],\n        dateString: string,\n        instance: any,\n        dayElement: HTMLElement\n      ) => {\n        this.flatpickrDayCreate.emit({\n          selectedDates,\n          dateString,\n          instance,\n          dayElement,\n        });\n      },\n    };\n\n    Object.keys(options).forEach((key) => {\n      if (typeof options[key] === 'undefined') {\n        if (typeof (this.options as any)[key] !== 'undefined') {\n          options[key] = (this.options as any)[key];\n        } else {\n          options[key] = (this.defaults as any)[key];\n        }\n      }\n    });\n\n    // @ts-ignore\n    options.time_24hr = options.time24hr;\n\n    // workaround bug in flatpickr 4.6 where it doesn't copy the classes across\n    // TODO - remove once fix in https://github.com/flatpickr/flatpickr/issues/1860 is released\n    options.altInputClass =\n      (options.altInputClass || '') + ' ' + this.elm.nativeElement.className;\n\n    if (!options.enable) {\n      delete options.enable;\n    }\n\n    this.instance = flatpickr(\n      this.elm.nativeElement,\n      options\n    ) as flatpickr.Instance;\n    this.setDisabledState(this.isDisabled);\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (this.instance) {\n      Object.keys(changes).forEach((inputKey) => {\n        this.instance.set(inputKey as any, (this as any)[inputKey]);\n      });\n    }\n  }\n\n  ngOnDestroy(): void {\n    if (this.instance) {\n      this.instance.destroy();\n    }\n  }\n\n  writeValue(value: any): void {\n    let convertedValue: any = value;\n    if (this.convertModelValue && this.mode === 'range' && value) {\n      convertedValue = [value.from, value.to];\n    }\n\n    if (this.instance) {\n      this.instance.setDate(convertedValue);\n    } else {\n      // flatpickr hasn't been initialised yet, store the value for later use\n      this.initialValue = convertedValue;\n    }\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChangeFn = fn;\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.onTouchedFn = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.isDisabled = isDisabled;\n    if (this.instance) {\n      if (this.isDisabled) {\n        this.renderer.setProperty(this.instance._input, 'disabled', 'disabled');\n      } else {\n        this.renderer.removeAttribute(this.instance._input, 'disabled');\n      }\n    }\n  }\n\n  @HostListener('input')\n  inputChanged(): void {\n    const value: string = this.elm.nativeElement.value;\n    if (this.convertModelValue && typeof value === 'string') {\n      switch (this.mode) {\n        case 'multiple':\n          const dates: Array<Date | undefined> = value\n            .split('; ')\n            .map((str) =>\n              this.instance.parseDate(\n                str,\n                this.instance.config.dateFormat,\n                !this.instance.config.enableTime\n              )\n            );\n          this.onChangeFn(dates);\n          break;\n\n        case 'range':\n          const [from, to] = value\n            .split(this.instance.l10n.rangeSeparator)\n            .map((str) =>\n              this.instance.parseDate(\n                str,\n                this.instance.config.dateFormat,\n                !this.instance.config.enableTime\n              )\n            );\n          this.onChangeFn({ from, to });\n          break;\n\n        case 'single':\n        default:\n          this.onChangeFn(\n            this.instance.parseDate(\n              value,\n              this.instance.config.dateFormat,\n              !this.instance.config.enableTime\n            )\n          );\n      }\n    } else {\n      this.onChangeFn(value);\n    }\n  }\n}\n"]}
import { NgModule, InjectionToken } from '@angular/core';
import { FlatpickrDirective } from './flatpickr.directive';
import { FlatpickrDefaults } from './flatpickr-defaults.service';
import * as i0 from "@angular/core";
export const USER_DEFAULTS = new InjectionToken('flatpickr defaults');
export function defaultsFactory(userDefaults) {
const defaults = new FlatpickrDefaults();
Object.assign(defaults, userDefaults);
return defaults;
}
export class FlatpickrModule {
static forRoot(userDefaults = {}) {
return {
ngModule: FlatpickrModule,
providers: [
{
provide: USER_DEFAULTS,
useValue: userDefaults
},
{
provide: FlatpickrDefaults,
useFactory: defaultsFactory,
deps: [USER_DEFAULTS]
}
]
};
}
}
FlatpickrModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: FlatpickrModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
FlatpickrModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.1.2", ngImport: i0, type: FlatpickrModule, declarations: [FlatpickrDirective], exports: [FlatpickrDirective] });
FlatpickrModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: FlatpickrModule });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: FlatpickrModule, decorators: [{
type: NgModule,
args: [{
declarations: [FlatpickrDirective],
exports: [FlatpickrDirective]
}]
}] });
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmxhdHBpY2tyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXJ4LWZsYXRwaWNrci9zcmMvbGliL2ZsYXRwaWNrci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLFFBQVEsRUFFUixjQUFjLEVBRWYsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDM0QsT0FBTyxFQUNMLGlCQUFpQixFQUVsQixNQUFNLDhCQUE4QixDQUFDOztBQUV0QyxNQUFNLENBQUMsTUFBTSxhQUFhLEdBQUcsSUFBSSxjQUFjLENBQUMsb0JBQW9CLENBQUMsQ0FBQztBQUV0RSxNQUFNLFVBQVUsZUFBZSxDQUM3QixZQUF3QztJQUV4QyxNQUFNLFFBQVEsR0FBc0IsSUFBSSxpQkFBaUIsRUFBRSxDQUFDO0lBQzVELE1BQU0sQ0FBQyxNQUFNLENBQUMsUUFBUSxFQUFFLFlBQVksQ0FBQyxDQUFDO0lBQ3RDLE9BQU8sUUFBUSxDQUFDO0FBQ2xCLENBQUM7QUFNRCxNQUFNLE9BQU8sZUFBZTtJQUMxQixNQUFNLENBQUMsT0FBTyxDQUNaLGVBQTJDLEVBQUU7UUFFN0MsT0FBTztZQUNMLFFBQVEsRUFBRSxlQUFlO1lBQ3pCLFNBQVMsRUFBRTtnQkFDVDtvQkFDRSxPQUFPLEVBQUUsYUFBYTtvQkFDdEIsUUFBUSxFQUFFLFlBQVk7aUJBQ3ZCO2dCQUNEO29CQUNFLE9BQU8sRUFBRSxpQkFBaUI7b0JBQzFCLFVBQVUsRUFBRSxlQUFlO29CQUMzQixJQUFJLEVBQUUsQ0FBQyxhQUFhLENBQUM7aUJBQ3RCO2FBQ0Y7U0FDRixDQUFDO0lBQ0osQ0FBQzs7NEdBbEJVLGVBQWU7NkdBQWYsZUFBZSxpQkFIWCxrQkFBa0IsYUFDdkIsa0JBQWtCOzZHQUVqQixlQUFlOzJGQUFmLGVBQWU7a0JBSjNCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMsa0JBQWtCLENBQUM7b0JBQ2xDLE9BQU8sRUFBRSxDQUFDLGtCQUFrQixDQUFDO2lCQUM5QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIE5nTW9kdWxlLFxuICBNb2R1bGVXaXRoUHJvdmlkZXJzLFxuICBJbmplY3Rpb25Ub2tlbixcbiAgUHJvdmlkZXJcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBGbGF0cGlja3JEaXJlY3RpdmUgfSBmcm9tICcuL2ZsYXRwaWNrci5kaXJlY3RpdmUnO1xuaW1wb3J0IHtcbiAgRmxhdHBpY2tyRGVmYXVsdHMsXG4gIEZsYXRwaWNrckRlZmF1bHRzSW50ZXJmYWNlXG59IGZyb20gJy4vZmxhdHBpY2tyLWRlZmF1bHRzLnNlcnZpY2UnO1xuXG5leHBvcnQgY29uc3QgVVNFUl9ERUZBVUxUUyA9IG5ldyBJbmplY3Rpb25Ub2tlbignZmxhdHBpY2tyIGRlZmF1bHRzJyk7XG5cbmV4cG9ydCBmdW5jdGlvbiBkZWZhdWx0c0ZhY3RvcnkoXG4gIHVzZXJEZWZhdWx0czogRmxhdHBpY2tyRGVmYXVsdHNJbnRlcmZhY2Vcbik6IEZsYXRwaWNrckRlZmF1bHRzIHtcbiAgY29uc3QgZGVmYXVsdHM6IEZsYXRwaWNrckRlZmF1bHRzID0gbmV3IEZsYXRwaWNrckRlZmF1bHRzKCk7XG4gIE9iamVjdC5hc3NpZ24oZGVmYXVsdHMsIHVzZXJEZWZhdWx0cyk7XG4gIHJldHVybiBkZWZhdWx0cztcbn1cblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbRmxhdHBpY2tyRGlyZWN0aXZlXSxcbiAgZXhwb3J0czogW0ZsYXRwaWNrckRpcmVjdGl2ZV1cbn0pXG5leHBvcnQgY2xhc3MgRmxhdHBpY2tyTW9kdWxlIHtcbiAgc3RhdGljIGZvclJvb3QoXG4gICAgdXNlckRlZmF1bHRzOiBGbGF0cGlja3JEZWZhdWx0c0ludGVyZmFjZSA9IHt9XG4gICk6IE1vZHVsZVdpdGhQcm92aWRlcnM8RmxhdHBpY2tyTW9kdWxlPiB7XG4gICAgcmV0dXJuIHtcbiAgICAgIG5nTW9kdWxlOiBGbGF0cGlja3JNb2R1bGUsXG4gICAgICBwcm92aWRlcnM6IFtcbiAgICAgICAge1xuICAgICAgICAgIHByb3ZpZGU6IFVTRVJfREVGQVVMVFMsXG4gICAgICAgICAgdXNlVmFsdWU6IHVzZXJEZWZhdWx0c1xuICAgICAgICB9LFxuICAgICAgICB7XG4gICAgICAgICAgcHJvdmlkZTogRmxhdHBpY2tyRGVmYXVsdHMsXG4gICAgICAgICAgdXNlRmFjdG9yeTogZGVmYXVsdHNGYWN0b3J5LFxuICAgICAgICAgIGRlcHM6IFtVU0VSX0RFRkFVTFRTXVxuICAgICAgICB9XG4gICAgICBdXG4gICAgfTtcbiAgfVxufVxuIl19
/*
* Public API Surface of angularx-flatpickr
*/
export * from './lib/flatpickr.module';
export { FlatpickrDefaults } from './lib/flatpickr-defaults.service';
export { FlatpickrDirective } from './lib/flatpickr.directive';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXJ4LWZsYXRwaWNrci9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsT0FBTyxFQUFFLGlCQUFpQixFQUE4QixNQUFNLGtDQUFrQyxDQUFDO0FBQ2pHLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBhbmd1bGFyeC1mbGF0cGlja3JcbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9mbGF0cGlja3IubW9kdWxlJztcbmV4cG9ydCB7IEZsYXRwaWNrckRlZmF1bHRzLCBGbGF0cGlja3JEZWZhdWx0c0ludGVyZmFjZSB9IGZyb20gJy4vbGliL2ZsYXRwaWNrci1kZWZhdWx0cy5zZXJ2aWNlJztcbmV4cG9ydCB7IEZsYXRwaWNrckRpcmVjdGl2ZSB9IGZyb20gJy4vbGliL2ZsYXRwaWNrci5kaXJlY3RpdmUnO1xuIl19
import * as i0 from '@angular/core';
import { Injectable, forwardRef, EventEmitter, Directive, Input, Output, HostListener, InjectionToken, NgModule } from '@angular/core';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
import flatpickr from 'flatpickr';
class FlatpickrDefaults {
constructor() {
/**
* Exactly the same as date format, but for the altInput field.
*/
this.altFormat = 'F j, Y';
/**
* Show the user a readable date (as per altFormat), but return something totally different to the server.
*/
this.altInput = false;
/**
* This class will be added to the input element created by the altInput option.
* Note that `altInput` already inherits classes from the original input.
*/
this.altInputClass = '';
/**
* Allows the user to enter a date directly input the input field. By default, direct entry is disabled.
*/
this.allowInput = false;
/**
* Allows the preloading of an invalid date. When disabled, the field will be cleared if the provided date is invalid
*/
this.allowInvalidPreload = false;
/**
* Instead of `body`, appends the calendar to the specified node instead.
*/
this.appendTo = undefined;
/**
* Defines how the date will be formatted in the aria-label for calendar days, using the same tokens as dateFormat. If you change this, you should choose a value that will make sense if a screen reader reads it out loud.
*/
this.ariaDateFormat = 'F j, Y';
/**
* Whether clicking on the input should open the picker.
* You could disable this if you wish to open the calendar manually `with.open()`.
*/
this.clickOpens = true;
/**
* A string of characters which are used to define how the date will be displayed in the input box.
* The supported characters are defined in the table below.
*/
this.dateFormat = 'Y-m-d';
/**
* Initial value of the hour element.
*/
this.defaultHour = 12;
/**
* Initial value of the minute element.
*/
this.defaultMinute = 0;
/**
* Initial value of the seconds element.
*/
this.defaultSeconds = 0;
/**
* See <a href="https://chmln.github.io/flatpickr/examples/#disabling-specific-dates">disabling dates</a>.
*/
this.disable = [];
/**
* Set disableMobile to true to always use the non-native picker.
* By default, Flatpickr utilizes native datetime widgets unless certain options (e.g. disable) are used.
*/
this.disableMobile = false;
/**
* Enables time picker.
*/
this.enableTime = false;
/**
* Enables seconds in the time picker.
*/
this.enableSeconds = false;
/**
* Allows using a custom date formatting function instead of the built-in handling for date formats using dateFormat, altFormat, etc.
*/
this.formatDate = undefined;
/**
* Adjusts the step for the hour input (incl. scrolling).
*/
this.hourIncrement = 1;
/**
* Displays the calendar inline.
*/
this.inline = false;
/**
* The maximum date that a user can pick to (inclusive).
*/
this.maxDate = undefined;
/**
* The minimum date that a user can start picking from (inclusive).
*/
this.minDate = undefined;
/**
* The maximum time that a user can pick to (inclusive).
*/
this.maxTime = undefined;
/**
* The minimum time that a user can start picking from (inclusive).
*/
this.minTime = undefined;
/**
* Adjusts the step for the minute input (incl. scrolling).
*/
this.minuteIncrement = 5;
/**
* Select a single date, multiple dates or a date range.
*/
this.mode = 'single';
/**
* HTML for the arrow icon, used to switch months.
*/
this.nextArrow = '>';
/**
* Hides the day selection in calendar. Use it along with `enableTime` to create a time picker.
*/
this.noCalendar = false;
/**
* Default now to the current date
*/
this.now = new Date();
/**
* HTML for the left arrow icon.
*/
this.prevArrow = '<';
/**
* Show the month using the shorthand version (ie, Sep instead of September).
*/
this.shorthandCurrentMonth = false;
/**
* Position the calendar inside the wrapper and next to the input element. (Leave `false` unless you know what you're doing).
*/
this.static = false;
/**
* Displays time picker in 24 hour mode without AM/PM selection when enabled.
*/
this.time24hr = false;
/**
* When true, dates will parsed, formatted, and displayed in UTC.
* It's recommended that date strings contain the timezone, but not necessary.
*/
this.utc = false;
/**
* Enables display of week numbers in calendar.
*/
this.weekNumbers = false;
/**
* Custom elements and input groups.
*/
this.wrap = false;
/**
* Array of plugin instances to use.
*/
this.plugins = [];
/**
* The locale object or string to use for the locale.
*/
this.locale = 'default';
/**
* Auto convert the ngModel value from a string to a date / array of dates / from - to date object depending on the `mode`
*/
this.convertModelValue = false;
/**
* The number of months shown.
*/
this.showMonths = 1;
/**
* How the month should be displayed in the header of the calendar.
*/
this.monthSelectorType = 'static';
/**
* Array of HTML elements that should not close the picker on click.
*/
this.ignoredFocusElements = [];
}
}
FlatpickrDefaults.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: FlatpickrDefaults, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
FlatpickrDefaults.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: FlatpickrDefaults });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: FlatpickrDefaults, decorators: [{
type: Injectable
}] });
const FLATPICKR_CONTROL_VALUE_ACCESSOR = {
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(() => FlatpickrDirective),
multi: true,
};
class FlatpickrDirective {
constructor(elm, defaults, renderer) {
this.elm = elm;
this.defaults = defaults;
this.renderer = renderer;
/**
* Object-options that can be user for multiple instances of Flatpickr.
* Option from this object is applied only if specific option is not specified.
* Example:
* ```typescript
* options: FlatpickrDefaultsInterface = {
* altFormat: 'd/m/Y', // will be ignored since altFormat is provided via specific attribute
* altInput: true // will be used since specific attribute is not provided
* };
* ```
* ```html
* <input
* class="form-control"
* type="text"
* mwlFlatpickr
* [options]="options"
* altFormat="d/m/Y">
* ```
*/
this.options = {};
/**
* Array of HTML elements that should not close the picker on click.
*/
this.ignoredFocusElements = [];
/**
* Gets triggered once the calendar is in a ready state
*/
this.flatpickrReady = new EventEmitter();
/**
* Gets triggered when the user selects a date, or changes the time on a selected date.
*/
this.flatpickrChange = new EventEmitter();
/**
* Gets triggered when the input value is updated with a new date string.
*/
this.flatpickrValueUpdate = new EventEmitter();
/**
* Gets triggered when the calendar is opened.
*/
this.flatpickrOpen = new EventEmitter();
/**
* Gets triggered when the calendar is closed.
*/
this.flatpickrClose = new EventEmitter();
/**
* Gets triggered when the month is changed, either by the user or programmatically.
*/
this.flatpickrMonthChange = new EventEmitter();
/**
* Gets triggered when the year is changed, either by the user or programmatically.
*/
this.flatpickrYearChange = new EventEmitter();
/**
* Take full control of every date cell with this output
*/
this.flatpickrDayCreate = new EventEmitter();
this.isDisabled = false;
this.onChangeFn = () => { };
this.onTouchedFn = () => { };
}
ngAfterViewInit() {
const options = {
altFormat: this.altFormat,
altInput: this.altInput,
altInputClass: this.altInputClass,
allowInput: this.allowInput,
allowInvalidPreload: this.allowInvalidPreload,
appendTo: this.appendTo,
ariaDateFormat: this.ariaDateFormat,
clickOpens: this.clickOpens,
dateFormat: this.dateFormat,
defaultHour: this.defaultHour,
defaultMinute: this.defaultMinute,
defaultSeconds: this.defaultSeconds,
disable: this.disable,
disableMobile: this.disableMobile,
enable: this.enable,
enableTime: this.enableTime,
enableSeconds: this.enableSeconds,
formatDate: this.formatDate,
hourIncrement: this.hourIncrement,
defaultDate: this.initialValue,
inline: this.inline,
maxDate: this.maxDate,
minDate: this.minDate,
maxTime: this.maxTime,
minTime: this.minTime,
minuteIncrement: this.minuteIncrement,
mode: this.mode,
nextArrow: this.nextArrow,
noCalendar: this.noCalendar,
now: this.now,
parseDate: this.parseDate,
prevArrow: this.prevArrow,
shorthandCurrentMonth: this.shorthandCurrentMonth,
showMonths: this.showMonths,
monthSelectorType: this.monthSelectorType,
static: this.static,
time24hr: this.time24hr,
weekNumbers: this.weekNumbers,
getWeek: this.getWeek,
wrap: this.wrap,
plugins: this.plugins,
locale: this.locale,
ignoredFocusElements: this.ignoredFocusElements,
onChange: (selectedDates, dateString, instance) => {
this.flatpickrChange.emit({ selectedDates, dateString, instance });
},
onOpen: (selectedDates, dateString, instance) => {
this.flatpickrOpen.emit({ selectedDates, dateString, instance });
},
onClose: (selectedDates, dateString, instance) => {
this.flatpickrClose.emit({ selectedDates, dateString, instance });
},
onMonthChange: (selectedDates, dateString, instance) => {
this.flatpickrMonthChange.emit({ selectedDates, dateString, instance });
},
onYearChange: (selectedDates, dateString, instance) => {
this.flatpickrYearChange.emit({ selectedDates, dateString, instance });
},
onReady: (selectedDates, dateString, instance) => {
this.flatpickrReady.emit({ selectedDates, dateString, instance });
},
onValueUpdate: (selectedDates, dateString, instance) => {
this.flatpickrValueUpdate.emit({ selectedDates, dateString, instance });
},
onDayCreate: (selectedDates, dateString, instance, dayElement) => {
this.flatpickrDayCreate.emit({
selectedDates,
dateString,
instance,
dayElement,
});
},
};
Object.keys(options).forEach((key) => {
if (typeof options[key] === 'undefined') {
if (typeof this.options[key] !== 'undefined') {
options[key] = this.options[key];
}
else {
options[key] = this.defaults[key];
}
}
});
// @ts-ignore
options.time_24hr = options.time24hr;
// workaround bug in flatpickr 4.6 where it doesn't copy the classes across
// TODO - remove once fix in https://github.com/flatpickr/flatpickr/issues/1860 is released
options.altInputClass =
(options.altInputClass || '') + ' ' + this.elm.nativeElement.className;
if (!options.enable) {
delete options.enable;
}
this.instance = flatpickr(this.elm.nativeElement, options);
this.setDisabledState(this.isDisabled);
}
ngOnChanges(changes) {
if (this.instance) {
Object.keys(changes).forEach((inputKey) => {
this.instance.set(inputKey, this[inputKey]);
});
}
}
ngOnDestroy() {
if (this.instance) {
this.instance.destroy();
}
}
writeValue(value) {
let convertedValue = value;
if (this.convertModelValue && this.mode === 'range' && value) {
convertedValue = [value.from, value.to];
}
if (this.instance) {
this.instance.setDate(convertedValue);
}
else {
// flatpickr hasn't been initialised yet, store the value for later use
this.initialValue = convertedValue;
}
}
registerOnChange(fn) {
this.onChangeFn = fn;
}
registerOnTouched(fn) {
this.onTouchedFn = fn;
}
setDisabledState(isDisabled) {
this.isDisabled = isDisabled;
if (this.instance) {
if (this.isDisabled) {
this.renderer.setProperty(this.instance._input, 'disabled', 'disabled');
}
else {
this.renderer.removeAttribute(this.instance._input, 'disabled');
}
}
}
inputChanged() {
const value = this.elm.nativeElement.value;
if (this.convertModelValue && typeof value === 'string') {
switch (this.mode) {
case 'multiple':
const dates = value
.split('; ')
.map((str) => this.instance.parseDate(str, this.instance.config.dateFormat, !this.instance.config.enableTime));
this.onChangeFn(dates);
break;
case 'range':
const [from, to] = value
.split(this.instance.l10n.rangeSeparator)
.map((str) => this.instance.parseDate(str, this.instance.config.dateFormat, !this.instance.config.enableTime));
this.onChangeFn({ from, to });
break;
case 'single':
default:
this.onChangeFn(this.instance.parseDate(value, this.instance.config.dateFormat, !this.instance.config.enableTime));
}
}
else {
this.onChangeFn(value);
}
}
}
FlatpickrDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: FlatpickrDirective, deps: [{ token: i0.ElementRef }, { token: FlatpickrDefaults }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
FlatpickrDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.1.2", type: FlatpickrDirective, selector: "[mwlFlatpickr]", inputs: { options: "options", altFormat: "altFormat", altInput: "altInput", altInputClass: "altInputClass", allowInput: "allowInput", allowInvalidPreload: "allowInvalidPreload", appendTo: "appendTo", ariaDateFormat: "ariaDateFormat", clickOpens: "clickOpens", dateFormat: "dateFormat", defaultHour: "defaultHour", defaultMinute: "defaultMinute", defaultSeconds: "defaultSeconds", disable: "disable", disableMobile: "disableMobile", enable: "enable", enableTime: "enableTime", enableSeconds: "enableSeconds", formatDate: "formatDate", hourIncrement: "hourIncrement", inline: "inline", maxDate: "maxDate", minDate: "minDate", maxTime: "maxTime", minTime: "minTime", minuteIncrement: "minuteIncrement", mode: "mode", nextArrow: "nextArrow", noCalendar: "noCalendar", now: "now", parseDate: "parseDate", prevArrow: "prevArrow", shorthandCurrentMonth: "shorthandCurrentMonth", showMonths: "showMonths", static: "static", time24hr: "time24hr", weekNumbers: "weekNumbers", getWeek: "getWeek", wrap: "wrap", plugins: "plugins", locale: "locale", convertModelValue: "convertModelValue", monthSelectorType: "monthSelectorType", ignoredFocusElements: "ignoredFocusElements" }, outputs: { flatpickrReady: "flatpickrReady", flatpickrChange: "flatpickrChange", flatpickrValueUpdate: "flatpickrValueUpdate", flatpickrOpen: "flatpickrOpen", flatpickrClose: "flatpickrClose", flatpickrMonthChange: "flatpickrMonthChange", flatpickrYearChange: "flatpickrYearChange", flatpickrDayCreate: "flatpickrDayCreate" }, host: { listeners: { "blur": "onTouchedFn()", "input": "inputChanged()" } }, providers: [FLATPICKR_CONTROL_VALUE_ACCESSOR], exportAs: ["mwlFlatpickr"], usesOnChanges: true, ngImport: i0 });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: FlatpickrDirective, decorators: [{
type: Directive,
args: [{
selector: '[mwlFlatpickr]',
providers: [FLATPICKR_CONTROL_VALUE_ACCESSOR],
exportAs: 'mwlFlatpickr',
}]
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: FlatpickrDefaults }, { type: i0.Renderer2 }]; }, propDecorators: { options: [{
type: Input
}], altFormat: [{
type: Input
}], altInput: [{
type: Input
}], altInputClass: [{
type: Input
}], allowInput: [{
type: Input
}], allowInvalidPreload: [{
type: Input
}], appendTo: [{
type: Input
}], ariaDateFormat: [{
type: Input
}], clickOpens: [{
type: Input
}], dateFormat: [{
type: Input
}], defaultHour: [{
type: Input
}], defaultMinute: [{
type: Input
}], defaultSeconds: [{
type: Input
}], disable: [{
type: Input
}], disableMobile: [{
type: Input
}], enable: [{
type: Input
}], enableTime: [{
type: Input
}], enableSeconds: [{
type: Input
}], formatDate: [{
type: Input
}], hourIncrement: [{
type: Input
}], inline: [{
type: Input
}], maxDate: [{
type: Input
}], minDate: [{
type: Input
}], maxTime: [{
type: Input
}], minTime: [{
type: Input
}], minuteIncrement: [{
type: Input
}], mode: [{
type: Input
}], nextArrow: [{
type: Input
}], noCalendar: [{
type: Input
}], now: [{
type: Input
}], parseDate: [{
type: Input
}], prevArrow: [{
type: Input
}], shorthandCurrentMonth: [{
type: Input
}], showMonths: [{
type: Input
}], static: [{
type: Input
}], time24hr: [{
type: Input
}], weekNumbers: [{
type: Input
}], getWeek: [{
type: Input
}], wrap: [{
type: Input
}], plugins: [{
type: Input
}], locale: [{
type: Input
}], convertModelValue: [{
type: Input
}], monthSelectorType: [{
type: Input
}], ignoredFocusElements: [{
type: Input
}], flatpickrReady: [{
type: Output
}], flatpickrChange: [{
type: Output
}], flatpickrValueUpdate: [{
type: Output
}], flatpickrOpen: [{
type: Output
}], flatpickrClose: [{
type: Output
}], flatpickrMonthChange: [{
type: Output
}], flatpickrYearChange: [{
type: Output
}], flatpickrDayCreate: [{
type: Output
}], onTouchedFn: [{
type: HostListener,
args: ['blur']
}], inputChanged: [{
type: HostListener,
args: ['input']
}] } });
const USER_DEFAULTS = new InjectionToken('flatpickr defaults');
function defaultsFactory(userDefaults) {
const defaults = new FlatpickrDefaults();
Object.assign(defaults, userDefaults);
return defaults;
}
class FlatpickrModule {
static forRoot(userDefaults = {}) {
return {
ngModule: FlatpickrModule,
providers: [
{
provide: USER_DEFAULTS,
useValue: userDefaults
},
{
provide: FlatpickrDefaults,
useFactory: defaultsFactory,
deps: [USER_DEFAULTS]
}
]
};
}
}
FlatpickrModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: FlatpickrModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
FlatpickrModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.1.2", ngImport: i0, type: FlatpickrModule, declarations: [FlatpickrDirective], exports: [FlatpickrDirective] });
FlatpickrModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: FlatpickrModule });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: FlatpickrModule, decorators: [{
type: NgModule,
args: [{
declarations: [FlatpickrDirective],
exports: [FlatpickrDirective]
}]
}] });
/*
* Public API Surface of angularx-flatpickr
*/
/**
* Generated bundle index. Do not edit.
*/
export { FlatpickrDefaults, FlatpickrDirective, FlatpickrModule, USER_DEFAULTS, defaultsFactory };
//# sourceMappingURL=angularx-flatpickr.mjs.map
{"version":3,"file":"angularx-flatpickr.mjs","sources":["../../../projects/angularx-flatpickr/src/lib/flatpickr-defaults.service.ts","../../../projects/angularx-flatpickr/src/lib/flatpickr.directive.ts","../../../projects/angularx-flatpickr/src/lib/flatpickr.module.ts","../../../projects/angularx-flatpickr/src/public-api.ts","../../../projects/angularx-flatpickr/src/angularx-flatpickr.ts"],"sourcesContent":["import { Injectable } from '@angular/core';\n\nexport type DisableEnableDate =\n | string\n | Date\n | { from: Date | string; to: Date | string }\n | ((date: Date) => boolean);\n\nexport interface FlatpickrDefaultsInterface {\n /**\n * Exactly the same as date format, but for the altInput field.\n */\n altFormat?: string;\n\n /**\n * \tShow the user a readable date (as per altFormat), but return something totally different to the server.\n */\n altInput?: boolean;\n\n /**\n * This class will be added to the input element created by the altInput option.\n * Note that `altInput` already inherits classes from the original input.\n */\n altInputClass?: string;\n\n /**\n * Allows the user to enter a date directly input the input field. By default, direct entry is disabled.\n */\n allowInput?: boolean;\n\n /**\n * Allows the preloading of an invalid date. When disabled, the field will be cleared if the provided date is invalid\n */\n allowInvalidPreload?: boolean;\n\n /**\n * Instead of `body`, appends the calendar to the specified node instead.\n */\n appendTo?: HTMLElement;\n\n /**\n * Defines how the date will be formatted in the aria-label for calendar days, using the same tokens as dateFormat. If you change this, you should choose a value that will make sense if a screen reader reads it out loud.\n */\n ariaDateFormat?: string;\n\n /**\n * Whether clicking on the input should open the picker.\n * You could disable this if you wish to open the calendar manually `with.open()`.\n */\n clickOpens?: boolean;\n\n /**\n * A string of characters which are used to define how the date will be displayed in the input box.\n * The supported characters are defined in the table below.\n */\n dateFormat?: string;\n /**\n * Initial value of the hour element.\n */\n defaultHour?: number;\n /**\n * Initial value of the minute element.\n */\n defaultMinute?: number;\n /**\n * Initial value of the seconds element.\n */\n defaultSeconds?: number;\n\n /**\n * See <a href=\"https://chmln.github.io/flatpickr/examples/#disabling-specific-dates\">disabling dates</a>.\n */\n disable?: DisableEnableDate[];\n\n /**\n * Set disableMobile to true to always use the non-native picker.\n * By default, Flatpickr utilizes native datetime widgets unless certain options (e.g. disable) are used.\n */\n disableMobile?: boolean;\n\n /**\n * See <a href=\"https://chmln.github.io/flatpickr/examples/#disabling-all-dates-except-select-few\">enabling dates</a>.\n */\n enable?: DisableEnableDate[];\n\n /**\n * Enables time picker.\n */\n enableTime?: boolean;\n\n /**\n * Enables seconds in the time picker.\n */\n enableSeconds?: boolean;\n /**\n * Allows using a custom date formatting function instead of the built-in handling for date formats using dateFormat, altFormat, etc.\n */\n formatDate?: (value: any) => string;\n /**\n * Adjusts the step for the hour input (incl. scrolling).\n */\n hourIncrement?: number;\n\n /**\n * Displays the calendar inline.\n */\n inline?: boolean;\n\n /**\n * The maximum date that a user can pick to (inclusive).\n */\n maxDate?: string | Date;\n\n /**\n * The minimum date that a user can start picking from (inclusive).\n */\n minDate?: string | Date;\n\n /**\n * The maximum time that a user can pick to (inclusive).\n */\n maxTime?: string;\n\n /**\n * The minimum time that a user can start picking from (inclusive).\n */\n minTime?: string;\n\n /**\n * Adjusts the step for the minute input (incl. scrolling).\n */\n minuteIncrement?: number;\n\n /**\n * Select a single date, multiple dates or a date range.\n */\n mode?: 'single' | 'multiple' | 'range';\n\n /**\n * HTML for the arrow icon, used to switch months.\n */\n nextArrow?: string;\n\n /**\n * Hides the day selection in calendar. Use it along with `enableTime` to create a time picker.\n */\n noCalendar?: boolean;\n\n /**\n * Provide a date for 'today', which will be used instead of \"new Date()\"\n */\n now?: Date | string | number;\n\n /**\n * Function that expects a date string and must return a Date object.\n */\n parseDate?: (str: string) => Date;\n\n /**\n * HTML for the left arrow icon.\n */\n prevArrow?: string;\n\n /**\n * Show the month using the shorthand version (ie, Sep instead of September).\n */\n shorthandCurrentMonth?: boolean;\n\n /**\n * Position the calendar inside the wrapper and next to the input element. (Leave `false` unless you know what you're doing).\n */\n static?: boolean;\n\n /**\n * Displays time picker in 24 hour mode without AM/PM selection when enabled.\n */\n time24hr?: boolean;\n\n /**\n * When true, dates will parsed, formatted, and displayed in UTC.\n * It's recommended that date strings contain the timezone, but not necessary.\n */\n utc?: boolean;\n\n /**\n * Enables display of week numbers in calendar.\n */\n weekNumbers?: boolean;\n\n /**\n * You may override the function that extracts the week numbers from a Date by supplying a getWeek function.\n * It takes in a date as a parameter and should return a corresponding string that you want to appear left of every week.\n */\n getWeek?: (date: Date) => string;\n\n /**\n * Custom elements and input groups.\n */\n wrap?: boolean;\n\n /**\n * Array of plugin instances to use.\n */\n plugins?: any[];\n\n /**\n * The locale object or string to use for the locale.\n */\n locale?: object | string;\n\n /**\n * Auto convert the ngModel value from a string to a date / array of dates / from - to date object depending on the `mode`\n */\n convertModelValue?: boolean;\n\n /**\n * The number of months shown.\n */\n showMonths?: number;\n\n /**\n * How the month should be displayed in the header of the calendar.\n */\n monthSelectorType?: 'static' | 'dropdown';\n\n /**\n * Array of HTML elements that should not close the picker on click.\n */\n ignoredFocusElements?: HTMLElement[];\n}\n\n@Injectable()\nexport class FlatpickrDefaults implements FlatpickrDefaultsInterface {\n /**\n * Exactly the same as date format, but for the altInput field.\n */\n altFormat: string = 'F j, Y';\n\n /**\n * \tShow the user a readable date (as per altFormat), but return something totally different to the server.\n */\n altInput: boolean = false;\n\n /**\n * This class will be added to the input element created by the altInput option.\n * Note that `altInput` already inherits classes from the original input.\n */\n altInputClass: string = '';\n\n /**\n * Allows the user to enter a date directly input the input field. By default, direct entry is disabled.\n */\n allowInput: boolean = false;\n\n /**\n * Allows the preloading of an invalid date. When disabled, the field will be cleared if the provided date is invalid\n */\n allowInvalidPreload: boolean = false;\n\n /**\n * Instead of `body`, appends the calendar to the specified node instead.\n */\n appendTo: HTMLElement | undefined = undefined;\n\n /**\n * Defines how the date will be formatted in the aria-label for calendar days, using the same tokens as dateFormat. If you change this, you should choose a value that will make sense if a screen reader reads it out loud.\n */\n ariaDateFormat?: string = 'F j, Y';\n\n /**\n * Whether clicking on the input should open the picker.\n * You could disable this if you wish to open the calendar manually `with.open()`.\n */\n clickOpens: boolean = true;\n\n /**\n * A string of characters which are used to define how the date will be displayed in the input box.\n * The supported characters are defined in the table below.\n */\n dateFormat: string = 'Y-m-d';\n\n /**\n * Initial value of the hour element.\n */\n defaultHour?: number = 12;\n\n /**\n * Initial value of the minute element.\n */\n defaultMinute?: number = 0;\n\n /**\n * Initial value of the seconds element.\n */\n defaultSeconds?: number = 0;\n\n /**\n * See <a href=\"https://chmln.github.io/flatpickr/examples/#disabling-specific-dates\">disabling dates</a>.\n */\n disable: DisableEnableDate[] = [];\n\n /**\n * Set disableMobile to true to always use the non-native picker.\n * By default, Flatpickr utilizes native datetime widgets unless certain options (e.g. disable) are used.\n */\n disableMobile: boolean = false;\n\n /**\n * See <a href=\"https://chmln.github.io/flatpickr/examples/#disabling-all-dates-except-select-few\">enabling dates</a>.\n */\n enable: DisableEnableDate[];\n\n /**\n * Enables time picker.\n */\n enableTime: boolean = false;\n\n /**\n * Enables seconds in the time picker.\n */\n enableSeconds: boolean = false;\n\n /**\n * Allows using a custom date formatting function instead of the built-in handling for date formats using dateFormat, altFormat, etc.\n */\n formatDate?: (value: any) => string = undefined;\n\n /**\n * Adjusts the step for the hour input (incl. scrolling).\n */\n hourIncrement: number = 1;\n\n /**\n * Displays the calendar inline.\n */\n inline: boolean = false;\n\n /**\n * The maximum date that a user can pick to (inclusive).\n */\n maxDate: string | Date | undefined = undefined;\n\n /**\n * The minimum date that a user can start picking from (inclusive).\n */\n minDate: string | Date | undefined = undefined;\n\n /**\n * The maximum time that a user can pick to (inclusive).\n */\n maxTime: string | undefined = undefined;\n\n /**\n * The minimum time that a user can start picking from (inclusive).\n */\n minTime: string | undefined = undefined;\n\n /**\n * Adjusts the step for the minute input (incl. scrolling).\n */\n minuteIncrement: number = 5;\n\n /**\n * Select a single date, multiple dates or a date range.\n */\n mode: 'single' | 'multiple' | 'range' = 'single';\n\n /**\n * HTML for the arrow icon, used to switch months.\n */\n nextArrow: string = '>';\n\n /**\n * Hides the day selection in calendar. Use it along with `enableTime` to create a time picker.\n */\n noCalendar: boolean = false;\n\n /**\n * Default now to the current date\n */\n now: Date | string | number = new Date();\n\n /**\n * Function that expects a date string and must return a Date object.\n */\n parseDate: (str: string) => Date;\n\n /**\n * HTML for the left arrow icon.\n */\n prevArrow: string = '<';\n\n /**\n * Show the month using the shorthand version (ie, Sep instead of September).\n */\n shorthandCurrentMonth: boolean = false;\n\n /**\n * Position the calendar inside the wrapper and next to the input element. (Leave `false` unless you know what you're doing).\n */\n static: boolean = false;\n\n /**\n * Displays time picker in 24 hour mode without AM/PM selection when enabled.\n */\n time24hr: boolean = false;\n\n /**\n * When true, dates will parsed, formatted, and displayed in UTC.\n * It's recommended that date strings contain the timezone, but not necessary.\n */\n utc: boolean = false;\n\n /**\n * Enables display of week numbers in calendar.\n */\n weekNumbers: boolean = false;\n\n /**\n * You may override the function that extracts the week numbers from a Date by supplying a getWeek function.\n * It takes in a date as a parameter and should return a corresponding string that you want to appear left of every week.\n */\n getWeek: (date: Date) => string;\n\n /**\n * Custom elements and input groups.\n */\n wrap: boolean = false;\n\n /**\n * Array of plugin instances to use.\n */\n plugins: any[] = [];\n\n /**\n * The locale object or string to use for the locale.\n */\n locale: object | string = 'default';\n\n /**\n * Auto convert the ngModel value from a string to a date / array of dates / from - to date object depending on the `mode`\n */\n convertModelValue: boolean = false;\n\n /**\n * The number of months shown.\n */\n showMonths: number = 1;\n\n /**\n * How the month should be displayed in the header of the calendar.\n */\n monthSelectorType: 'static' | 'dropdown' = 'static';\n\n /**\n * Array of HTML elements that should not close the picker on click.\n */\n ignoredFocusElements: HTMLElement[] = [];\n}\n","import {\n Directive,\n ElementRef,\n AfterViewInit,\n Input,\n Output,\n EventEmitter,\n OnChanges,\n SimpleChanges,\n OnDestroy,\n forwardRef,\n HostListener,\n Renderer2,\n} from '@angular/core';\nimport {\n FlatpickrDefaults,\n DisableEnableDate,\n FlatpickrDefaultsInterface,\n} from './flatpickr-defaults.service';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport flatpickr from 'flatpickr';\n\nexport interface FlatPickrOutputOptions {\n selectedDates: Date[];\n dateString: string;\n instance: any;\n}\n\nexport interface FlatPickrDayCreateOutputOptions\n extends FlatPickrOutputOptions {\n dayElement: HTMLElement;\n}\n\nexport const FLATPICKR_CONTROL_VALUE_ACCESSOR: any = {\n provide: NG_VALUE_ACCESSOR,\n useExisting: forwardRef(() => FlatpickrDirective),\n multi: true,\n};\n\n@Directive({\n selector: '[mwlFlatpickr]',\n providers: [FLATPICKR_CONTROL_VALUE_ACCESSOR],\n exportAs: 'mwlFlatpickr',\n})\nexport class FlatpickrDirective\n implements AfterViewInit, OnChanges, OnDestroy, ControlValueAccessor\n{\n /**\n * Object-options that can be user for multiple instances of Flatpickr.\n * Option from this object is applied only if specific option is not specified.\n * Example:\n * ```typescript\n * options: FlatpickrDefaultsInterface = {\n * altFormat: 'd/m/Y', // will be ignored since altFormat is provided via specific attribute\n * altInput: true // will be used since specific attribute is not provided\n * };\n * ```\n * ```html\n * <input\n * class=\"form-control\"\n * type=\"text\"\n * mwlFlatpickr\n * [options]=\"options\"\n * altFormat=\"d/m/Y\">\n * ```\n */\n @Input() options: FlatpickrDefaultsInterface = {};\n\n /**\n * Exactly the same as date format, but for the altInput field.\n */\n @Input() altFormat: string;\n\n /**\n * \tShow the user a readable date (as per altFormat), but return something totally different to the server.\n */\n @Input() altInput: boolean;\n\n /**\n * This class will be added to the input element created by the altInput option.\n * Note that `altInput` already inherits classes from the original input.\n */\n @Input() altInputClass: string;\n\n /**\n * Allows the user to enter a date directly input the input field. By default, direct entry is disabled.\n */\n @Input() allowInput: boolean;\n\n\n /**\n * Allows the preloading of an invalid date. When disabled, the field will be cleared if the provided date is invalid\n */\n @Input() allowInvalidPreload: boolean;\n\n /**\n * Instead of `body`, appends the calendar to the specified node instead.\n */\n @Input() appendTo: HTMLElement;\n\n /**\n * Defines how the date will be formatted in the aria-label for calendar days, using the same tokens as dateFormat. If you change this, you should choose a value that will make sense if a screen reader reads it out loud.\n */\n @Input() ariaDateFormat?: string;\n\n /**\n * Whether clicking on the input should open the picker.\n * You could disable this if you wish to open the calendar manually `with.open()`.\n */\n @Input() clickOpens: boolean;\n\n /**\n * A string of characters which are used to define how the date will be displayed in the input box.\n * The supported characters are defined in the table below.\n */\n @Input() dateFormat: string;\n\n /**\n * Initial value of the hour element.\n */\n @Input() defaultHour?: number;\n /**\n * Initial value of the minute element.\n */\n @Input() defaultMinute?: number;\n\n /**\n * Initial value of the seconds element.\n */\n @Input() defaultSeconds?: number;\n\n /**\n * See <a href=\"https://chmln.github.io/flatpickr/examples/#disabling-specific-dates\">disabling dates</a>.\n */\n @Input() disable: DisableEnableDate[];\n\n /**\n * Set disableMobile to true to always use the non-native picker.\n * By default, Flatpickr utilizes native datetime widgets unless certain options (e.g. disable) are used.\n */\n @Input() disableMobile: boolean;\n\n /**\n * See <a href=\"https://chmln.github.io/flatpickr/examples/#disabling-all-dates-except-select-few\">enabling dates</a>.\n */\n @Input() enable: DisableEnableDate[];\n\n /**\n * Enables time picker.\n */\n @Input() enableTime: boolean;\n\n /**\n * Enables seconds in the time picker.\n */\n @Input() enableSeconds: boolean;\n\n /**\n * Allows using a custom date formatting function instead of the built-in handling for date formats using dateFormat, altFormat, etc.\n */\n @Input() formatDate?: (value: any) => string;\n\n /**\n * Adjusts the step for the hour input (incl. scrolling).\n */\n @Input() hourIncrement: number;\n\n /**\n * Displays the calendar inline.\n */\n @Input() inline: boolean;\n\n /**\n * The maximum date that a user can pick to (inclusive).\n */\n @Input() maxDate: string | Date;\n\n /**\n * The minimum date that a user can start picking from (inclusive).\n */\n @Input() minDate: string | Date;\n\n /**\n * The maximum time that a user can pick to (inclusive).\n */\n @Input() maxTime: string;\n\n /**\n * The minimum time that a user can start picking from (inclusive).\n */\n @Input() minTime: string;\n\n /**\n * Adjusts the step for the minute input (incl. scrolling).\n */\n @Input() minuteIncrement: number;\n\n /**\n * Select a single date, multiple dates or a date range.\n */\n @Input() mode: 'single' | 'multiple' | 'range';\n\n /**\n * HTML for the arrow icon, used to switch months.\n */\n @Input() nextArrow: string;\n\n /**\n * Hides the day selection in calendar. Use it along with `enableTime` to create a time picker.\n */\n @Input() noCalendar: boolean;\n\n /**\n * Provide a date for 'today', which will be used instead of \"new Date()\"\n */\n @Input() now?: Date | string | number;\n\n /**\n * Function that expects a date string and must return a Date object.\n */\n @Input() parseDate: (str: string) => Date;\n\n /**\n * HTML for the left arrow icon.\n */\n @Input() prevArrow: string;\n\n /**\n * Show the month using the shorthand version (ie, Sep instead of September).\n */\n @Input() shorthandCurrentMonth: boolean;\n\n /**\n * The number of months shown.\n */\n @Input() showMonths: number;\n\n /**\n * Position the calendar inside the wrapper and next to the input element. (Leave `false` unless you know what you're doing).\n */\n @Input() static: boolean;\n\n /**\n * Displays time picker in 24 hour mode without AM/PM selection when enabled.\n */\n @Input() time24hr: boolean;\n\n /**\n * Enables display of week numbers in calendar.\n */\n @Input() weekNumbers: boolean;\n\n /**\n * You may override the function that extracts the week numbers from a Date by supplying a getWeek function.\n * It takes in a date as a parameter and should return a corresponding string that you want to appear left of every week.\n */\n @Input() getWeek: (date: Date) => string;\n\n /**\n * Custom elements and input groups.\n */\n @Input() wrap: boolean;\n\n /**\n * Array of plugin instances to use.\n */\n @Input() plugins: any[];\n\n /**\n * The locale object or string to use for the locale.\n */\n @Input() locale: object | string;\n\n /**\n * Auto convert the ngModel value from a string to a date / array of dates / from - to date object depending on the `mode`\n */\n @Input() convertModelValue: boolean;\n\n /**\n * How the month should be displayed in the header of the calendar.\n */\n @Input() monthSelectorType: 'static' | 'dropdown';\n\n /**\n * Array of HTML elements that should not close the picker on click.\n */\n @Input() ignoredFocusElements: HTMLElement[] = [];\n\n /**\n * Gets triggered once the calendar is in a ready state\n */\n @Output()\n flatpickrReady: EventEmitter<FlatPickrOutputOptions> = new EventEmitter();\n\n /**\n * Gets triggered when the user selects a date, or changes the time on a selected date.\n */\n @Output()\n flatpickrChange: EventEmitter<FlatPickrOutputOptions> = new EventEmitter();\n\n /**\n * Gets triggered when the input value is updated with a new date string.\n */\n @Output()\n flatpickrValueUpdate: EventEmitter<FlatPickrOutputOptions> =\n new EventEmitter();\n\n /**\n * Gets triggered when the calendar is opened.\n */\n @Output()\n flatpickrOpen: EventEmitter<FlatPickrOutputOptions> = new EventEmitter();\n\n /**\n * Gets triggered when the calendar is closed.\n */\n @Output()\n flatpickrClose: EventEmitter<FlatPickrOutputOptions> = new EventEmitter();\n\n /**\n * Gets triggered when the month is changed, either by the user or programmatically.\n */\n @Output()\n flatpickrMonthChange: EventEmitter<FlatPickrOutputOptions> =\n new EventEmitter();\n\n /**\n * Gets triggered when the year is changed, either by the user or programmatically.\n */\n @Output()\n flatpickrYearChange: EventEmitter<FlatPickrOutputOptions> =\n new EventEmitter();\n\n /**\n * Take full control of every date cell with this output\n */\n @Output()\n flatpickrDayCreate: EventEmitter<FlatPickrDayCreateOutputOptions> =\n new EventEmitter();\n\n /**\n * The flatpickr instance where you can call methods like toggle(), open(), close() etc\n */\n instance: flatpickr.Instance;\n\n private isDisabled = false;\n private initialValue: any;\n\n onChangeFn: (value: any) => void = () => {};\n\n @HostListener('blur')\n onTouchedFn = () => {};\n\n constructor(\n private elm: ElementRef,\n private defaults: FlatpickrDefaults,\n private renderer: Renderer2\n ) {}\n\n ngAfterViewInit(): void {\n const options: any = {\n altFormat: this.altFormat,\n altInput: this.altInput,\n altInputClass: this.altInputClass,\n allowInput: this.allowInput,\n allowInvalidPreload: this.allowInvalidPreload,\n appendTo: this.appendTo,\n ariaDateFormat: this.ariaDateFormat,\n clickOpens: this.clickOpens,\n dateFormat: this.dateFormat,\n defaultHour: this.defaultHour,\n defaultMinute: this.defaultMinute,\n defaultSeconds: this.defaultSeconds,\n disable: this.disable,\n disableMobile: this.disableMobile,\n enable: this.enable,\n enableTime: this.enableTime,\n enableSeconds: this.enableSeconds,\n formatDate: this.formatDate,\n hourIncrement: this.hourIncrement,\n defaultDate: this.initialValue,\n inline: this.inline,\n maxDate: this.maxDate,\n minDate: this.minDate,\n maxTime: this.maxTime,\n minTime: this.minTime,\n minuteIncrement: this.minuteIncrement,\n mode: this.mode,\n nextArrow: this.nextArrow,\n noCalendar: this.noCalendar,\n now: this.now,\n parseDate: this.parseDate,\n prevArrow: this.prevArrow,\n shorthandCurrentMonth: this.shorthandCurrentMonth,\n showMonths: this.showMonths,\n monthSelectorType: this.monthSelectorType,\n static: this.static,\n time24hr: this.time24hr,\n weekNumbers: this.weekNumbers,\n getWeek: this.getWeek,\n wrap: this.wrap,\n plugins: this.plugins,\n locale: this.locale,\n ignoredFocusElements: this.ignoredFocusElements,\n onChange: (selectedDates: Date[], dateString: string, instance: any) => {\n this.flatpickrChange.emit({ selectedDates, dateString, instance });\n },\n onOpen: (selectedDates: Date[], dateString: string, instance: any) => {\n this.flatpickrOpen.emit({ selectedDates, dateString, instance });\n },\n onClose: (selectedDates: Date[], dateString: string, instance: any) => {\n this.flatpickrClose.emit({ selectedDates, dateString, instance });\n },\n onMonthChange: (\n selectedDates: Date[],\n dateString: string,\n instance: any\n ) => {\n this.flatpickrMonthChange.emit({ selectedDates, dateString, instance });\n },\n onYearChange: (\n selectedDates: Date[],\n dateString: string,\n instance: any\n ) => {\n this.flatpickrYearChange.emit({ selectedDates, dateString, instance });\n },\n onReady: (selectedDates: Date[], dateString: string, instance: any) => {\n this.flatpickrReady.emit({ selectedDates, dateString, instance });\n },\n onValueUpdate: (\n selectedDates: Date[],\n dateString: string,\n instance: any\n ) => {\n this.flatpickrValueUpdate.emit({ selectedDates, dateString, instance });\n },\n onDayCreate: (\n selectedDates: Date[],\n dateString: string,\n instance: any,\n dayElement: HTMLElement\n ) => {\n this.flatpickrDayCreate.emit({\n selectedDates,\n dateString,\n instance,\n dayElement,\n });\n },\n };\n\n Object.keys(options).forEach((key) => {\n if (typeof options[key] === 'undefined') {\n if (typeof (this.options as any)[key] !== 'undefined') {\n options[key] = (this.options as any)[key];\n } else {\n options[key] = (this.defaults as any)[key];\n }\n }\n });\n\n // @ts-ignore\n options.time_24hr = options.time24hr;\n\n // workaround bug in flatpickr 4.6 where it doesn't copy the classes across\n // TODO - remove once fix in https://github.com/flatpickr/flatpickr/issues/1860 is released\n options.altInputClass =\n (options.altInputClass || '') + ' ' + this.elm.nativeElement.className;\n\n if (!options.enable) {\n delete options.enable;\n }\n\n this.instance = flatpickr(\n this.elm.nativeElement,\n options\n ) as flatpickr.Instance;\n this.setDisabledState(this.isDisabled);\n }\n\n ngOnChanges(changes: SimpleChanges): void {\n if (this.instance) {\n Object.keys(changes).forEach((inputKey) => {\n this.instance.set(inputKey as any, (this as any)[inputKey]);\n });\n }\n }\n\n ngOnDestroy(): void {\n if (this.instance) {\n this.instance.destroy();\n }\n }\n\n writeValue(value: any): void {\n let convertedValue: any = value;\n if (this.convertModelValue && this.mode === 'range' && value) {\n convertedValue = [value.from, value.to];\n }\n\n if (this.instance) {\n this.instance.setDate(convertedValue);\n } else {\n // flatpickr hasn't been initialised yet, store the value for later use\n this.initialValue = convertedValue;\n }\n }\n\n registerOnChange(fn: any): void {\n this.onChangeFn = fn;\n }\n\n registerOnTouched(fn: () => void): void {\n this.onTouchedFn = fn;\n }\n\n setDisabledState(isDisabled: boolean): void {\n this.isDisabled = isDisabled;\n if (this.instance) {\n if (this.isDisabled) {\n this.renderer.setProperty(this.instance._input, 'disabled', 'disabled');\n } else {\n this.renderer.removeAttribute(this.instance._input, 'disabled');\n }\n }\n }\n\n @HostListener('input')\n inputChanged(): void {\n const value: string = this.elm.nativeElement.value;\n if (this.convertModelValue && typeof value === 'string') {\n switch (this.mode) {\n case 'multiple':\n const dates: Array<Date | undefined> = value\n .split('; ')\n .map((str) =>\n this.instance.parseDate(\n str,\n this.instance.config.dateFormat,\n !this.instance.config.enableTime\n )\n );\n this.onChangeFn(dates);\n break;\n\n case 'range':\n const [from, to] = value\n .split(this.instance.l10n.rangeSeparator)\n .map((str) =>\n this.instance.parseDate(\n str,\n this.instance.config.dateFormat,\n !this.instance.config.enableTime\n )\n );\n this.onChangeFn({ from, to });\n break;\n\n case 'single':\n default:\n this.onChangeFn(\n this.instance.parseDate(\n value,\n this.instance.config.dateFormat,\n !this.instance.config.enableTime\n )\n );\n }\n } else {\n this.onChangeFn(value);\n }\n }\n}\n","import {\n NgModule,\n ModuleWithProviders,\n InjectionToken,\n Provider\n} from '@angular/core';\nimport { FlatpickrDirective } from './flatpickr.directive';\nimport {\n FlatpickrDefaults,\n FlatpickrDefaultsInterface\n} from './flatpickr-defaults.service';\n\nexport const USER_DEFAULTS = new InjectionToken('flatpickr defaults');\n\nexport function defaultsFactory(\n userDefaults: FlatpickrDefaultsInterface\n): FlatpickrDefaults {\n const defaults: FlatpickrDefaults = new FlatpickrDefaults();\n Object.assign(defaults, userDefaults);\n return defaults;\n}\n\n@NgModule({\n declarations: [FlatpickrDirective],\n exports: [FlatpickrDirective]\n})\nexport class FlatpickrModule {\n static forRoot(\n userDefaults: FlatpickrDefaultsInterface = {}\n ): ModuleWithProviders<FlatpickrModule> {\n return {\n ngModule: FlatpickrModule,\n providers: [\n {\n provide: USER_DEFAULTS,\n useValue: userDefaults\n },\n {\n provide: FlatpickrDefaults,\n useFactory: defaultsFactory,\n deps: [USER_DEFAULTS]\n }\n ]\n };\n }\n}\n","/*\n * Public API Surface of angularx-flatpickr\n */\n\nexport * from './lib/flatpickr.module';\nexport { FlatpickrDefaults, FlatpickrDefaultsInterface } from './lib/flatpickr-defaults.service';\nexport { FlatpickrDirective } from './lib/flatpickr.directive';\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":["i1.FlatpickrDefaults"],"mappings":"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"}
import * as i0 from '@angular/core';
import { Injectable, forwardRef, EventEmitter, Directive, Input, Output, HostListener, InjectionToken, NgModule } from '@angular/core';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
import flatpickr from 'flatpickr';
class FlatpickrDefaults {
constructor() {
/**
* Exactly the same as date format, but for the altInput field.
*/
this.altFormat = 'F j, Y';
/**
* Show the user a readable date (as per altFormat), but return something totally different to the server.
*/
this.altInput = false;
/**
* This class will be added to the input element created by the altInput option.
* Note that `altInput` already inherits classes from the original input.
*/
this.altInputClass = '';
/**
* Allows the user to enter a date directly input the input field. By default, direct entry is disabled.
*/
this.allowInput = false;
/**
* Allows the preloading of an invalid date. When disabled, the field will be cleared if the provided date is invalid
*/
this.allowInvalidPreload = false;
/**
* Instead of `body`, appends the calendar to the specified node instead.
*/
this.appendTo = undefined;
/**
* Defines how the date will be formatted in the aria-label for calendar days, using the same tokens as dateFormat. If you change this, you should choose a value that will make sense if a screen reader reads it out loud.
*/
this.ariaDateFormat = 'F j, Y';
/**
* Whether clicking on the input should open the picker.
* You could disable this if you wish to open the calendar manually `with.open()`.
*/
this.clickOpens = true;
/**
* A string of characters which are used to define how the date will be displayed in the input box.
* The supported characters are defined in the table below.
*/
this.dateFormat = 'Y-m-d';
/**
* Initial value of the hour element.
*/
this.defaultHour = 12;
/**
* Initial value of the minute element.
*/
this.defaultMinute = 0;
/**
* Initial value of the seconds element.
*/
this.defaultSeconds = 0;
/**
* See <a href="https://chmln.github.io/flatpickr/examples/#disabling-specific-dates">disabling dates</a>.
*/
this.disable = [];
/**
* Set disableMobile to true to always use the non-native picker.
* By default, Flatpickr utilizes native datetime widgets unless certain options (e.g. disable) are used.
*/
this.disableMobile = false;
/**
* Enables time picker.
*/
this.enableTime = false;
/**
* Enables seconds in the time picker.
*/
this.enableSeconds = false;
/**
* Allows using a custom date formatting function instead of the built-in handling for date formats using dateFormat, altFormat, etc.
*/
this.formatDate = undefined;
/**
* Adjusts the step for the hour input (incl. scrolling).
*/
this.hourIncrement = 1;
/**
* Displays the calendar inline.
*/
this.inline = false;
/**
* The maximum date that a user can pick to (inclusive).
*/
this.maxDate = undefined;
/**
* The minimum date that a user can start picking from (inclusive).
*/
this.minDate = undefined;
/**
* The maximum time that a user can pick to (inclusive).
*/
this.maxTime = undefined;
/**
* The minimum time that a user can start picking from (inclusive).
*/
this.minTime = undefined;
/**
* Adjusts the step for the minute input (incl. scrolling).
*/
this.minuteIncrement = 5;
/**
* Select a single date, multiple dates or a date range.
*/
this.mode = 'single';
/**
* HTML for the arrow icon, used to switch months.
*/
this.nextArrow = '>';
/**
* Hides the day selection in calendar. Use it along with `enableTime` to create a time picker.
*/
this.noCalendar = false;
/**
* Default now to the current date
*/
this.now = new Date();
/**
* HTML for the left arrow icon.
*/
this.prevArrow = '<';
/**
* Show the month using the shorthand version (ie, Sep instead of September).
*/
this.shorthandCurrentMonth = false;
/**
* Position the calendar inside the wrapper and next to the input element. (Leave `false` unless you know what you're doing).
*/
this.static = false;
/**
* Displays time picker in 24 hour mode without AM/PM selection when enabled.
*/
this.time24hr = false;
/**
* When true, dates will parsed, formatted, and displayed in UTC.
* It's recommended that date strings contain the timezone, but not necessary.
*/
this.utc = false;
/**
* Enables display of week numbers in calendar.
*/
this.weekNumbers = false;
/**
* Custom elements and input groups.
*/
this.wrap = false;
/**
* Array of plugin instances to use.
*/
this.plugins = [];
/**
* The locale object or string to use for the locale.
*/
this.locale = 'default';
/**
* Auto convert the ngModel value from a string to a date / array of dates / from - to date object depending on the `mode`
*/
this.convertModelValue = false;
/**
* The number of months shown.
*/
this.showMonths = 1;
/**
* How the month should be displayed in the header of the calendar.
*/
this.monthSelectorType = 'static';
/**
* Array of HTML elements that should not close the picker on click.
*/
this.ignoredFocusElements = [];
}
}
FlatpickrDefaults.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: FlatpickrDefaults, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
FlatpickrDefaults.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: FlatpickrDefaults });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: FlatpickrDefaults, decorators: [{
type: Injectable
}] });
const FLATPICKR_CONTROL_VALUE_ACCESSOR = {
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(() => FlatpickrDirective),
multi: true,
};
class FlatpickrDirective {
constructor(elm, defaults, renderer) {
this.elm = elm;
this.defaults = defaults;
this.renderer = renderer;
/**
* Object-options that can be user for multiple instances of Flatpickr.
* Option from this object is applied only if specific option is not specified.
* Example:
* ```typescript
* options: FlatpickrDefaultsInterface = {
* altFormat: 'd/m/Y', // will be ignored since altFormat is provided via specific attribute
* altInput: true // will be used since specific attribute is not provided
* };
* ```
* ```html
* <input
* class="form-control"
* type="text"
* mwlFlatpickr
* [options]="options"
* altFormat="d/m/Y">
* ```
*/
this.options = {};
/**
* Array of HTML elements that should not close the picker on click.
*/
this.ignoredFocusElements = [];
/**
* Gets triggered once the calendar is in a ready state
*/
this.flatpickrReady = new EventEmitter();
/**
* Gets triggered when the user selects a date, or changes the time on a selected date.
*/
this.flatpickrChange = new EventEmitter();
/**
* Gets triggered when the input value is updated with a new date string.
*/
this.flatpickrValueUpdate = new EventEmitter();
/**
* Gets triggered when the calendar is opened.
*/
this.flatpickrOpen = new EventEmitter();
/**
* Gets triggered when the calendar is closed.
*/
this.flatpickrClose = new EventEmitter();
/**
* Gets triggered when the month is changed, either by the user or programmatically.
*/
this.flatpickrMonthChange = new EventEmitter();
/**
* Gets triggered when the year is changed, either by the user or programmatically.
*/
this.flatpickrYearChange = new EventEmitter();
/**
* Take full control of every date cell with this output
*/
this.flatpickrDayCreate = new EventEmitter();
this.isDisabled = false;
this.onChangeFn = () => { };
this.onTouchedFn = () => { };
}
ngAfterViewInit() {
const options = {
altFormat: this.altFormat,
altInput: this.altInput,
altInputClass: this.altInputClass,
allowInput: this.allowInput,
allowInvalidPreload: this.allowInvalidPreload,
appendTo: this.appendTo,
ariaDateFormat: this.ariaDateFormat,
clickOpens: this.clickOpens,
dateFormat: this.dateFormat,
defaultHour: this.defaultHour,
defaultMinute: this.defaultMinute,
defaultSeconds: this.defaultSeconds,
disable: this.disable,
disableMobile: this.disableMobile,
enable: this.enable,
enableTime: this.enableTime,
enableSeconds: this.enableSeconds,
formatDate: this.formatDate,
hourIncrement: this.hourIncrement,
defaultDate: this.initialValue,
inline: this.inline,
maxDate: this.maxDate,
minDate: this.minDate,
maxTime: this.maxTime,
minTime: this.minTime,
minuteIncrement: this.minuteIncrement,
mode: this.mode,
nextArrow: this.nextArrow,
noCalendar: this.noCalendar,
now: this.now,
parseDate: this.parseDate,
prevArrow: this.prevArrow,
shorthandCurrentMonth: this.shorthandCurrentMonth,
showMonths: this.showMonths,
monthSelectorType: this.monthSelectorType,
static: this.static,
time24hr: this.time24hr,
weekNumbers: this.weekNumbers,
getWeek: this.getWeek,
wrap: this.wrap,
plugins: this.plugins,
locale: this.locale,
ignoredFocusElements: this.ignoredFocusElements,
onChange: (selectedDates, dateString, instance) => {
this.flatpickrChange.emit({ selectedDates, dateString, instance });
},
onOpen: (selectedDates, dateString, instance) => {
this.flatpickrOpen.emit({ selectedDates, dateString, instance });
},
onClose: (selectedDates, dateString, instance) => {
this.flatpickrClose.emit({ selectedDates, dateString, instance });
},
onMonthChange: (selectedDates, dateString, instance) => {
this.flatpickrMonthChange.emit({ selectedDates, dateString, instance });
},
onYearChange: (selectedDates, dateString, instance) => {
this.flatpickrYearChange.emit({ selectedDates, dateString, instance });
},
onReady: (selectedDates, dateString, instance) => {
this.flatpickrReady.emit({ selectedDates, dateString, instance });
},
onValueUpdate: (selectedDates, dateString, instance) => {
this.flatpickrValueUpdate.emit({ selectedDates, dateString, instance });
},
onDayCreate: (selectedDates, dateString, instance, dayElement) => {
this.flatpickrDayCreate.emit({
selectedDates,
dateString,
instance,
dayElement,
});
},
};
Object.keys(options).forEach((key) => {
if (typeof options[key] === 'undefined') {
if (typeof this.options[key] !== 'undefined') {
options[key] = this.options[key];
}
else {
options[key] = this.defaults[key];
}
}
});
// @ts-ignore
options.time_24hr = options.time24hr;
// workaround bug in flatpickr 4.6 where it doesn't copy the classes across
// TODO - remove once fix in https://github.com/flatpickr/flatpickr/issues/1860 is released
options.altInputClass =
(options.altInputClass || '') + ' ' + this.elm.nativeElement.className;
if (!options.enable) {
delete options.enable;
}
this.instance = flatpickr(this.elm.nativeElement, options);
this.setDisabledState(this.isDisabled);
}
ngOnChanges(changes) {
if (this.instance) {
Object.keys(changes).forEach((inputKey) => {
this.instance.set(inputKey, this[inputKey]);
});
}
}
ngOnDestroy() {
if (this.instance) {
this.instance.destroy();
}
}
writeValue(value) {
let convertedValue = value;
if (this.convertModelValue && this.mode === 'range' && value) {
convertedValue = [value.from, value.to];
}
if (this.instance) {
this.instance.setDate(convertedValue);
}
else {
// flatpickr hasn't been initialised yet, store the value for later use
this.initialValue = convertedValue;
}
}
registerOnChange(fn) {
this.onChangeFn = fn;
}
registerOnTouched(fn) {
this.onTouchedFn = fn;
}
setDisabledState(isDisabled) {
this.isDisabled = isDisabled;
if (this.instance) {
if (this.isDisabled) {
this.renderer.setProperty(this.instance._input, 'disabled', 'disabled');
}
else {
this.renderer.removeAttribute(this.instance._input, 'disabled');
}
}
}
inputChanged() {
const value = this.elm.nativeElement.value;
if (this.convertModelValue && typeof value === 'string') {
switch (this.mode) {
case 'multiple':
const dates = value
.split('; ')
.map((str) => this.instance.parseDate(str, this.instance.config.dateFormat, !this.instance.config.enableTime));
this.onChangeFn(dates);
break;
case 'range':
const [from, to] = value
.split(this.instance.l10n.rangeSeparator)
.map((str) => this.instance.parseDate(str, this.instance.config.dateFormat, !this.instance.config.enableTime));
this.onChangeFn({ from, to });
break;
case 'single':
default:
this.onChangeFn(this.instance.parseDate(value, this.instance.config.dateFormat, !this.instance.config.enableTime));
}
}
else {
this.onChangeFn(value);
}
}
}
FlatpickrDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: FlatpickrDirective, deps: [{ token: i0.ElementRef }, { token: FlatpickrDefaults }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
FlatpickrDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.1.2", type: FlatpickrDirective, selector: "[mwlFlatpickr]", inputs: { options: "options", altFormat: "altFormat", altInput: "altInput", altInputClass: "altInputClass", allowInput: "allowInput", allowInvalidPreload: "allowInvalidPreload", appendTo: "appendTo", ariaDateFormat: "ariaDateFormat", clickOpens: "clickOpens", dateFormat: "dateFormat", defaultHour: "defaultHour", defaultMinute: "defaultMinute", defaultSeconds: "defaultSeconds", disable: "disable", disableMobile: "disableMobile", enable: "enable", enableTime: "enableTime", enableSeconds: "enableSeconds", formatDate: "formatDate", hourIncrement: "hourIncrement", inline: "inline", maxDate: "maxDate", minDate: "minDate", maxTime: "maxTime", minTime: "minTime", minuteIncrement: "minuteIncrement", mode: "mode", nextArrow: "nextArrow", noCalendar: "noCalendar", now: "now", parseDate: "parseDate", prevArrow: "prevArrow", shorthandCurrentMonth: "shorthandCurrentMonth", showMonths: "showMonths", static: "static", time24hr: "time24hr", weekNumbers: "weekNumbers", getWeek: "getWeek", wrap: "wrap", plugins: "plugins", locale: "locale", convertModelValue: "convertModelValue", monthSelectorType: "monthSelectorType", ignoredFocusElements: "ignoredFocusElements" }, outputs: { flatpickrReady: "flatpickrReady", flatpickrChange: "flatpickrChange", flatpickrValueUpdate: "flatpickrValueUpdate", flatpickrOpen: "flatpickrOpen", flatpickrClose: "flatpickrClose", flatpickrMonthChange: "flatpickrMonthChange", flatpickrYearChange: "flatpickrYearChange", flatpickrDayCreate: "flatpickrDayCreate" }, host: { listeners: { "blur": "onTouchedFn()", "input": "inputChanged()" } }, providers: [FLATPICKR_CONTROL_VALUE_ACCESSOR], exportAs: ["mwlFlatpickr"], usesOnChanges: true, ngImport: i0 });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: FlatpickrDirective, decorators: [{
type: Directive,
args: [{
selector: '[mwlFlatpickr]',
providers: [FLATPICKR_CONTROL_VALUE_ACCESSOR],
exportAs: 'mwlFlatpickr',
}]
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: FlatpickrDefaults }, { type: i0.Renderer2 }]; }, propDecorators: { options: [{
type: Input
}], altFormat: [{
type: Input
}], altInput: [{
type: Input
}], altInputClass: [{
type: Input
}], allowInput: [{
type: Input
}], allowInvalidPreload: [{
type: Input
}], appendTo: [{
type: Input
}], ariaDateFormat: [{
type: Input
}], clickOpens: [{
type: Input
}], dateFormat: [{
type: Input
}], defaultHour: [{
type: Input
}], defaultMinute: [{
type: Input
}], defaultSeconds: [{
type: Input
}], disable: [{
type: Input
}], disableMobile: [{
type: Input
}], enable: [{
type: Input
}], enableTime: [{
type: Input
}], enableSeconds: [{
type: Input
}], formatDate: [{
type: Input
}], hourIncrement: [{
type: Input
}], inline: [{
type: Input
}], maxDate: [{
type: Input
}], minDate: [{
type: Input
}], maxTime: [{
type: Input
}], minTime: [{
type: Input
}], minuteIncrement: [{
type: Input
}], mode: [{
type: Input
}], nextArrow: [{
type: Input
}], noCalendar: [{
type: Input
}], now: [{
type: Input
}], parseDate: [{
type: Input
}], prevArrow: [{
type: Input
}], shorthandCurrentMonth: [{
type: Input
}], showMonths: [{
type: Input
}], static: [{
type: Input
}], time24hr: [{
type: Input
}], weekNumbers: [{
type: Input
}], getWeek: [{
type: Input
}], wrap: [{
type: Input
}], plugins: [{
type: Input
}], locale: [{
type: Input
}], convertModelValue: [{
type: Input
}], monthSelectorType: [{
type: Input
}], ignoredFocusElements: [{
type: Input
}], flatpickrReady: [{
type: Output
}], flatpickrChange: [{
type: Output
}], flatpickrValueUpdate: [{
type: Output
}], flatpickrOpen: [{
type: Output
}], flatpickrClose: [{
type: Output
}], flatpickrMonthChange: [{
type: Output
}], flatpickrYearChange: [{
type: Output
}], flatpickrDayCreate: [{
type: Output
}], onTouchedFn: [{
type: HostListener,
args: ['blur']
}], inputChanged: [{
type: HostListener,
args: ['input']
}] } });
const USER_DEFAULTS = new InjectionToken('flatpickr defaults');
function defaultsFactory(userDefaults) {
const defaults = new FlatpickrDefaults();
Object.assign(defaults, userDefaults);
return defaults;
}
class FlatpickrModule {
static forRoot(userDefaults = {}) {
return {
ngModule: FlatpickrModule,
providers: [
{
provide: USER_DEFAULTS,
useValue: userDefaults
},
{
provide: FlatpickrDefaults,
useFactory: defaultsFactory,
deps: [USER_DEFAULTS]
}
]
};
}
}
FlatpickrModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: FlatpickrModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
FlatpickrModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.1.2", ngImport: i0, type: FlatpickrModule, declarations: [FlatpickrDirective], exports: [FlatpickrDirective] });
FlatpickrModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: FlatpickrModule });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: FlatpickrModule, decorators: [{
type: NgModule,
args: [{
declarations: [FlatpickrDirective],
exports: [FlatpickrDirective]
}]
}] });
/*
* Public API Surface of angularx-flatpickr
*/
/**
* Generated bundle index. Do not edit.
*/
export { FlatpickrDefaults, FlatpickrDirective, FlatpickrModule, USER_DEFAULTS, defaultsFactory };
//# sourceMappingURL=angularx-flatpickr.mjs.map
{"version":3,"file":"angularx-flatpickr.mjs","sources":["../../../projects/angularx-flatpickr/src/lib/flatpickr-defaults.service.ts","../../../projects/angularx-flatpickr/src/lib/flatpickr.directive.ts","../../../projects/angularx-flatpickr/src/lib/flatpickr.module.ts","../../../projects/angularx-flatpickr/src/public-api.ts","../../../projects/angularx-flatpickr/src/angularx-flatpickr.ts"],"sourcesContent":["import { Injectable } from '@angular/core';\n\nexport type DisableEnableDate =\n | string\n | Date\n | { from: Date | string; to: Date | string }\n | ((date: Date) => boolean);\n\nexport interface FlatpickrDefaultsInterface {\n /**\n * Exactly the same as date format, but for the altInput field.\n */\n altFormat?: string;\n\n /**\n * \tShow the user a readable date (as per altFormat), but return something totally different to the server.\n */\n altInput?: boolean;\n\n /**\n * This class will be added to the input element created by the altInput option.\n * Note that `altInput` already inherits classes from the original input.\n */\n altInputClass?: string;\n\n /**\n * Allows the user to enter a date directly input the input field. By default, direct entry is disabled.\n */\n allowInput?: boolean;\n\n /**\n * Allows the preloading of an invalid date. When disabled, the field will be cleared if the provided date is invalid\n */\n allowInvalidPreload?: boolean;\n\n /**\n * Instead of `body`, appends the calendar to the specified node instead.\n */\n appendTo?: HTMLElement;\n\n /**\n * Defines how the date will be formatted in the aria-label for calendar days, using the same tokens as dateFormat. If you change this, you should choose a value that will make sense if a screen reader reads it out loud.\n */\n ariaDateFormat?: string;\n\n /**\n * Whether clicking on the input should open the picker.\n * You could disable this if you wish to open the calendar manually `with.open()`.\n */\n clickOpens?: boolean;\n\n /**\n * A string of characters which are used to define how the date will be displayed in the input box.\n * The supported characters are defined in the table below.\n */\n dateFormat?: string;\n /**\n * Initial value of the hour element.\n */\n defaultHour?: number;\n /**\n * Initial value of the minute element.\n */\n defaultMinute?: number;\n /**\n * Initial value of the seconds element.\n */\n defaultSeconds?: number;\n\n /**\n * See <a href=\"https://chmln.github.io/flatpickr/examples/#disabling-specific-dates\">disabling dates</a>.\n */\n disable?: DisableEnableDate[];\n\n /**\n * Set disableMobile to true to always use the non-native picker.\n * By default, Flatpickr utilizes native datetime widgets unless certain options (e.g. disable) are used.\n */\n disableMobile?: boolean;\n\n /**\n * See <a href=\"https://chmln.github.io/flatpickr/examples/#disabling-all-dates-except-select-few\">enabling dates</a>.\n */\n enable?: DisableEnableDate[];\n\n /**\n * Enables time picker.\n */\n enableTime?: boolean;\n\n /**\n * Enables seconds in the time picker.\n */\n enableSeconds?: boolean;\n /**\n * Allows using a custom date formatting function instead of the built-in handling for date formats using dateFormat, altFormat, etc.\n */\n formatDate?: (value: any) => string;\n /**\n * Adjusts the step for the hour input (incl. scrolling).\n */\n hourIncrement?: number;\n\n /**\n * Displays the calendar inline.\n */\n inline?: boolean;\n\n /**\n * The maximum date that a user can pick to (inclusive).\n */\n maxDate?: string | Date;\n\n /**\n * The minimum date that a user can start picking from (inclusive).\n */\n minDate?: string | Date;\n\n /**\n * The maximum time that a user can pick to (inclusive).\n */\n maxTime?: string;\n\n /**\n * The minimum time that a user can start picking from (inclusive).\n */\n minTime?: string;\n\n /**\n * Adjusts the step for the minute input (incl. scrolling).\n */\n minuteIncrement?: number;\n\n /**\n * Select a single date, multiple dates or a date range.\n */\n mode?: 'single' | 'multiple' | 'range';\n\n /**\n * HTML for the arrow icon, used to switch months.\n */\n nextArrow?: string;\n\n /**\n * Hides the day selection in calendar. Use it along with `enableTime` to create a time picker.\n */\n noCalendar?: boolean;\n\n /**\n * Provide a date for 'today', which will be used instead of \"new Date()\"\n */\n now?: Date | string | number;\n\n /**\n * Function that expects a date string and must return a Date object.\n */\n parseDate?: (str: string) => Date;\n\n /**\n * HTML for the left arrow icon.\n */\n prevArrow?: string;\n\n /**\n * Show the month using the shorthand version (ie, Sep instead of September).\n */\n shorthandCurrentMonth?: boolean;\n\n /**\n * Position the calendar inside the wrapper and next to the input element. (Leave `false` unless you know what you're doing).\n */\n static?: boolean;\n\n /**\n * Displays time picker in 24 hour mode without AM/PM selection when enabled.\n */\n time24hr?: boolean;\n\n /**\n * When true, dates will parsed, formatted, and displayed in UTC.\n * It's recommended that date strings contain the timezone, but not necessary.\n */\n utc?: boolean;\n\n /**\n * Enables display of week numbers in calendar.\n */\n weekNumbers?: boolean;\n\n /**\n * You may override the function that extracts the week numbers from a Date by supplying a getWeek function.\n * It takes in a date as a parameter and should return a corresponding string that you want to appear left of every week.\n */\n getWeek?: (date: Date) => string;\n\n /**\n * Custom elements and input groups.\n */\n wrap?: boolean;\n\n /**\n * Array of plugin instances to use.\n */\n plugins?: any[];\n\n /**\n * The locale object or string to use for the locale.\n */\n locale?: object | string;\n\n /**\n * Auto convert the ngModel value from a string to a date / array of dates / from - to date object depending on the `mode`\n */\n convertModelValue?: boolean;\n\n /**\n * The number of months shown.\n */\n showMonths?: number;\n\n /**\n * How the month should be displayed in the header of the calendar.\n */\n monthSelectorType?: 'static' | 'dropdown';\n\n /**\n * Array of HTML elements that should not close the picker on click.\n */\n ignoredFocusElements?: HTMLElement[];\n}\n\n@Injectable()\nexport class FlatpickrDefaults implements FlatpickrDefaultsInterface {\n /**\n * Exactly the same as date format, but for the altInput field.\n */\n altFormat: string = 'F j, Y';\n\n /**\n * \tShow the user a readable date (as per altFormat), but return something totally different to the server.\n */\n altInput: boolean = false;\n\n /**\n * This class will be added to the input element created by the altInput option.\n * Note that `altInput` already inherits classes from the original input.\n */\n altInputClass: string = '';\n\n /**\n * Allows the user to enter a date directly input the input field. By default, direct entry is disabled.\n */\n allowInput: boolean = false;\n\n /**\n * Allows the preloading of an invalid date. When disabled, the field will be cleared if the provided date is invalid\n */\n allowInvalidPreload: boolean = false;\n\n /**\n * Instead of `body`, appends the calendar to the specified node instead.\n */\n appendTo: HTMLElement | undefined = undefined;\n\n /**\n * Defines how the date will be formatted in the aria-label for calendar days, using the same tokens as dateFormat. If you change this, you should choose a value that will make sense if a screen reader reads it out loud.\n */\n ariaDateFormat?: string = 'F j, Y';\n\n /**\n * Whether clicking on the input should open the picker.\n * You could disable this if you wish to open the calendar manually `with.open()`.\n */\n clickOpens: boolean = true;\n\n /**\n * A string of characters which are used to define how the date will be displayed in the input box.\n * The supported characters are defined in the table below.\n */\n dateFormat: string = 'Y-m-d';\n\n /**\n * Initial value of the hour element.\n */\n defaultHour?: number = 12;\n\n /**\n * Initial value of the minute element.\n */\n defaultMinute?: number = 0;\n\n /**\n * Initial value of the seconds element.\n */\n defaultSeconds?: number = 0;\n\n /**\n * See <a href=\"https://chmln.github.io/flatpickr/examples/#disabling-specific-dates\">disabling dates</a>.\n */\n disable: DisableEnableDate[] = [];\n\n /**\n * Set disableMobile to true to always use the non-native picker.\n * By default, Flatpickr utilizes native datetime widgets unless certain options (e.g. disable) are used.\n */\n disableMobile: boolean = false;\n\n /**\n * See <a href=\"https://chmln.github.io/flatpickr/examples/#disabling-all-dates-except-select-few\">enabling dates</a>.\n */\n enable: DisableEnableDate[];\n\n /**\n * Enables time picker.\n */\n enableTime: boolean = false;\n\n /**\n * Enables seconds in the time picker.\n */\n enableSeconds: boolean = false;\n\n /**\n * Allows using a custom date formatting function instead of the built-in handling for date formats using dateFormat, altFormat, etc.\n */\n formatDate?: (value: any) => string = undefined;\n\n /**\n * Adjusts the step for the hour input (incl. scrolling).\n */\n hourIncrement: number = 1;\n\n /**\n * Displays the calendar inline.\n */\n inline: boolean = false;\n\n /**\n * The maximum date that a user can pick to (inclusive).\n */\n maxDate: string | Date | undefined = undefined;\n\n /**\n * The minimum date that a user can start picking from (inclusive).\n */\n minDate: string | Date | undefined = undefined;\n\n /**\n * The maximum time that a user can pick to (inclusive).\n */\n maxTime: string | undefined = undefined;\n\n /**\n * The minimum time that a user can start picking from (inclusive).\n */\n minTime: string | undefined = undefined;\n\n /**\n * Adjusts the step for the minute input (incl. scrolling).\n */\n minuteIncrement: number = 5;\n\n /**\n * Select a single date, multiple dates or a date range.\n */\n mode: 'single' | 'multiple' | 'range' = 'single';\n\n /**\n * HTML for the arrow icon, used to switch months.\n */\n nextArrow: string = '>';\n\n /**\n * Hides the day selection in calendar. Use it along with `enableTime` to create a time picker.\n */\n noCalendar: boolean = false;\n\n /**\n * Default now to the current date\n */\n now: Date | string | number = new Date();\n\n /**\n * Function that expects a date string and must return a Date object.\n */\n parseDate: (str: string) => Date;\n\n /**\n * HTML for the left arrow icon.\n */\n prevArrow: string = '<';\n\n /**\n * Show the month using the shorthand version (ie, Sep instead of September).\n */\n shorthandCurrentMonth: boolean = false;\n\n /**\n * Position the calendar inside the wrapper and next to the input element. (Leave `false` unless you know what you're doing).\n */\n static: boolean = false;\n\n /**\n * Displays time picker in 24 hour mode without AM/PM selection when enabled.\n */\n time24hr: boolean = false;\n\n /**\n * When true, dates will parsed, formatted, and displayed in UTC.\n * It's recommended that date strings contain the timezone, but not necessary.\n */\n utc: boolean = false;\n\n /**\n * Enables display of week numbers in calendar.\n */\n weekNumbers: boolean = false;\n\n /**\n * You may override the function that extracts the week numbers from a Date by supplying a getWeek function.\n * It takes in a date as a parameter and should return a corresponding string that you want to appear left of every week.\n */\n getWeek: (date: Date) => string;\n\n /**\n * Custom elements and input groups.\n */\n wrap: boolean = false;\n\n /**\n * Array of plugin instances to use.\n */\n plugins: any[] = [];\n\n /**\n * The locale object or string to use for the locale.\n */\n locale: object | string = 'default';\n\n /**\n * Auto convert the ngModel value from a string to a date / array of dates / from - to date object depending on the `mode`\n */\n convertModelValue: boolean = false;\n\n /**\n * The number of months shown.\n */\n showMonths: number = 1;\n\n /**\n * How the month should be displayed in the header of the calendar.\n */\n monthSelectorType: 'static' | 'dropdown' = 'static';\n\n /**\n * Array of HTML elements that should not close the picker on click.\n */\n ignoredFocusElements: HTMLElement[] = [];\n}\n","import {\n Directive,\n ElementRef,\n AfterViewInit,\n Input,\n Output,\n EventEmitter,\n OnChanges,\n SimpleChanges,\n OnDestroy,\n forwardRef,\n HostListener,\n Renderer2,\n} from '@angular/core';\nimport {\n FlatpickrDefaults,\n DisableEnableDate,\n FlatpickrDefaultsInterface,\n} from './flatpickr-defaults.service';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport flatpickr from 'flatpickr';\n\nexport interface FlatPickrOutputOptions {\n selectedDates: Date[];\n dateString: string;\n instance: any;\n}\n\nexport interface FlatPickrDayCreateOutputOptions\n extends FlatPickrOutputOptions {\n dayElement: HTMLElement;\n}\n\nexport const FLATPICKR_CONTROL_VALUE_ACCESSOR: any = {\n provide: NG_VALUE_ACCESSOR,\n useExisting: forwardRef(() => FlatpickrDirective),\n multi: true,\n};\n\n@Directive({\n selector: '[mwlFlatpickr]',\n providers: [FLATPICKR_CONTROL_VALUE_ACCESSOR],\n exportAs: 'mwlFlatpickr',\n})\nexport class FlatpickrDirective\n implements AfterViewInit, OnChanges, OnDestroy, ControlValueAccessor\n{\n /**\n * Object-options that can be user for multiple instances of Flatpickr.\n * Option from this object is applied only if specific option is not specified.\n * Example:\n * ```typescript\n * options: FlatpickrDefaultsInterface = {\n * altFormat: 'd/m/Y', // will be ignored since altFormat is provided via specific attribute\n * altInput: true // will be used since specific attribute is not provided\n * };\n * ```\n * ```html\n * <input\n * class=\"form-control\"\n * type=\"text\"\n * mwlFlatpickr\n * [options]=\"options\"\n * altFormat=\"d/m/Y\">\n * ```\n */\n @Input() options: FlatpickrDefaultsInterface = {};\n\n /**\n * Exactly the same as date format, but for the altInput field.\n */\n @Input() altFormat: string;\n\n /**\n * \tShow the user a readable date (as per altFormat), but return something totally different to the server.\n */\n @Input() altInput: boolean;\n\n /**\n * This class will be added to the input element created by the altInput option.\n * Note that `altInput` already inherits classes from the original input.\n */\n @Input() altInputClass: string;\n\n /**\n * Allows the user to enter a date directly input the input field. By default, direct entry is disabled.\n */\n @Input() allowInput: boolean;\n\n\n /**\n * Allows the preloading of an invalid date. When disabled, the field will be cleared if the provided date is invalid\n */\n @Input() allowInvalidPreload: boolean;\n\n /**\n * Instead of `body`, appends the calendar to the specified node instead.\n */\n @Input() appendTo: HTMLElement;\n\n /**\n * Defines how the date will be formatted in the aria-label for calendar days, using the same tokens as dateFormat. If you change this, you should choose a value that will make sense if a screen reader reads it out loud.\n */\n @Input() ariaDateFormat?: string;\n\n /**\n * Whether clicking on the input should open the picker.\n * You could disable this if you wish to open the calendar manually `with.open()`.\n */\n @Input() clickOpens: boolean;\n\n /**\n * A string of characters which are used to define how the date will be displayed in the input box.\n * The supported characters are defined in the table below.\n */\n @Input() dateFormat: string;\n\n /**\n * Initial value of the hour element.\n */\n @Input() defaultHour?: number;\n /**\n * Initial value of the minute element.\n */\n @Input() defaultMinute?: number;\n\n /**\n * Initial value of the seconds element.\n */\n @Input() defaultSeconds?: number;\n\n /**\n * See <a href=\"https://chmln.github.io/flatpickr/examples/#disabling-specific-dates\">disabling dates</a>.\n */\n @Input() disable: DisableEnableDate[];\n\n /**\n * Set disableMobile to true to always use the non-native picker.\n * By default, Flatpickr utilizes native datetime widgets unless certain options (e.g. disable) are used.\n */\n @Input() disableMobile: boolean;\n\n /**\n * See <a href=\"https://chmln.github.io/flatpickr/examples/#disabling-all-dates-except-select-few\">enabling dates</a>.\n */\n @Input() enable: DisableEnableDate[];\n\n /**\n * Enables time picker.\n */\n @Input() enableTime: boolean;\n\n /**\n * Enables seconds in the time picker.\n */\n @Input() enableSeconds: boolean;\n\n /**\n * Allows using a custom date formatting function instead of the built-in handling for date formats using dateFormat, altFormat, etc.\n */\n @Input() formatDate?: (value: any) => string;\n\n /**\n * Adjusts the step for the hour input (incl. scrolling).\n */\n @Input() hourIncrement: number;\n\n /**\n * Displays the calendar inline.\n */\n @Input() inline: boolean;\n\n /**\n * The maximum date that a user can pick to (inclusive).\n */\n @Input() maxDate: string | Date;\n\n /**\n * The minimum date that a user can start picking from (inclusive).\n */\n @Input() minDate: string | Date;\n\n /**\n * The maximum time that a user can pick to (inclusive).\n */\n @Input() maxTime: string;\n\n /**\n * The minimum time that a user can start picking from (inclusive).\n */\n @Input() minTime: string;\n\n /**\n * Adjusts the step for the minute input (incl. scrolling).\n */\n @Input() minuteIncrement: number;\n\n /**\n * Select a single date, multiple dates or a date range.\n */\n @Input() mode: 'single' | 'multiple' | 'range';\n\n /**\n * HTML for the arrow icon, used to switch months.\n */\n @Input() nextArrow: string;\n\n /**\n * Hides the day selection in calendar. Use it along with `enableTime` to create a time picker.\n */\n @Input() noCalendar: boolean;\n\n /**\n * Provide a date for 'today', which will be used instead of \"new Date()\"\n */\n @Input() now?: Date | string | number;\n\n /**\n * Function that expects a date string and must return a Date object.\n */\n @Input() parseDate: (str: string) => Date;\n\n /**\n * HTML for the left arrow icon.\n */\n @Input() prevArrow: string;\n\n /**\n * Show the month using the shorthand version (ie, Sep instead of September).\n */\n @Input() shorthandCurrentMonth: boolean;\n\n /**\n * The number of months shown.\n */\n @Input() showMonths: number;\n\n /**\n * Position the calendar inside the wrapper and next to the input element. (Leave `false` unless you know what you're doing).\n */\n @Input() static: boolean;\n\n /**\n * Displays time picker in 24 hour mode without AM/PM selection when enabled.\n */\n @Input() time24hr: boolean;\n\n /**\n * Enables display of week numbers in calendar.\n */\n @Input() weekNumbers: boolean;\n\n /**\n * You may override the function that extracts the week numbers from a Date by supplying a getWeek function.\n * It takes in a date as a parameter and should return a corresponding string that you want to appear left of every week.\n */\n @Input() getWeek: (date: Date) => string;\n\n /**\n * Custom elements and input groups.\n */\n @Input() wrap: boolean;\n\n /**\n * Array of plugin instances to use.\n */\n @Input() plugins: any[];\n\n /**\n * The locale object or string to use for the locale.\n */\n @Input() locale: object | string;\n\n /**\n * Auto convert the ngModel value from a string to a date / array of dates / from - to date object depending on the `mode`\n */\n @Input() convertModelValue: boolean;\n\n /**\n * How the month should be displayed in the header of the calendar.\n */\n @Input() monthSelectorType: 'static' | 'dropdown';\n\n /**\n * Array of HTML elements that should not close the picker on click.\n */\n @Input() ignoredFocusElements: HTMLElement[] = [];\n\n /**\n * Gets triggered once the calendar is in a ready state\n */\n @Output()\n flatpickrReady: EventEmitter<FlatPickrOutputOptions> = new EventEmitter();\n\n /**\n * Gets triggered when the user selects a date, or changes the time on a selected date.\n */\n @Output()\n flatpickrChange: EventEmitter<FlatPickrOutputOptions> = new EventEmitter();\n\n /**\n * Gets triggered when the input value is updated with a new date string.\n */\n @Output()\n flatpickrValueUpdate: EventEmitter<FlatPickrOutputOptions> =\n new EventEmitter();\n\n /**\n * Gets triggered when the calendar is opened.\n */\n @Output()\n flatpickrOpen: EventEmitter<FlatPickrOutputOptions> = new EventEmitter();\n\n /**\n * Gets triggered when the calendar is closed.\n */\n @Output()\n flatpickrClose: EventEmitter<FlatPickrOutputOptions> = new EventEmitter();\n\n /**\n * Gets triggered when the month is changed, either by the user or programmatically.\n */\n @Output()\n flatpickrMonthChange: EventEmitter<FlatPickrOutputOptions> =\n new EventEmitter();\n\n /**\n * Gets triggered when the year is changed, either by the user or programmatically.\n */\n @Output()\n flatpickrYearChange: EventEmitter<FlatPickrOutputOptions> =\n new EventEmitter();\n\n /**\n * Take full control of every date cell with this output\n */\n @Output()\n flatpickrDayCreate: EventEmitter<FlatPickrDayCreateOutputOptions> =\n new EventEmitter();\n\n /**\n * The flatpickr instance where you can call methods like toggle(), open(), close() etc\n */\n instance: flatpickr.Instance;\n\n private isDisabled = false;\n private initialValue: any;\n\n onChangeFn: (value: any) => void = () => {};\n\n @HostListener('blur')\n onTouchedFn = () => {};\n\n constructor(\n private elm: ElementRef,\n private defaults: FlatpickrDefaults,\n private renderer: Renderer2\n ) {}\n\n ngAfterViewInit(): void {\n const options: any = {\n altFormat: this.altFormat,\n altInput: this.altInput,\n altInputClass: this.altInputClass,\n allowInput: this.allowInput,\n allowInvalidPreload: this.allowInvalidPreload,\n appendTo: this.appendTo,\n ariaDateFormat: this.ariaDateFormat,\n clickOpens: this.clickOpens,\n dateFormat: this.dateFormat,\n defaultHour: this.defaultHour,\n defaultMinute: this.defaultMinute,\n defaultSeconds: this.defaultSeconds,\n disable: this.disable,\n disableMobile: this.disableMobile,\n enable: this.enable,\n enableTime: this.enableTime,\n enableSeconds: this.enableSeconds,\n formatDate: this.formatDate,\n hourIncrement: this.hourIncrement,\n defaultDate: this.initialValue,\n inline: this.inline,\n maxDate: this.maxDate,\n minDate: this.minDate,\n maxTime: this.maxTime,\n minTime: this.minTime,\n minuteIncrement: this.minuteIncrement,\n mode: this.mode,\n nextArrow: this.nextArrow,\n noCalendar: this.noCalendar,\n now: this.now,\n parseDate: this.parseDate,\n prevArrow: this.prevArrow,\n shorthandCurrentMonth: this.shorthandCurrentMonth,\n showMonths: this.showMonths,\n monthSelectorType: this.monthSelectorType,\n static: this.static,\n time24hr: this.time24hr,\n weekNumbers: this.weekNumbers,\n getWeek: this.getWeek,\n wrap: this.wrap,\n plugins: this.plugins,\n locale: this.locale,\n ignoredFocusElements: this.ignoredFocusElements,\n onChange: (selectedDates: Date[], dateString: string, instance: any) => {\n this.flatpickrChange.emit({ selectedDates, dateString, instance });\n },\n onOpen: (selectedDates: Date[], dateString: string, instance: any) => {\n this.flatpickrOpen.emit({ selectedDates, dateString, instance });\n },\n onClose: (selectedDates: Date[], dateString: string, instance: any) => {\n this.flatpickrClose.emit({ selectedDates, dateString, instance });\n },\n onMonthChange: (\n selectedDates: Date[],\n dateString: string,\n instance: any\n ) => {\n this.flatpickrMonthChange.emit({ selectedDates, dateString, instance });\n },\n onYearChange: (\n selectedDates: Date[],\n dateString: string,\n instance: any\n ) => {\n this.flatpickrYearChange.emit({ selectedDates, dateString, instance });\n },\n onReady: (selectedDates: Date[], dateString: string, instance: any) => {\n this.flatpickrReady.emit({ selectedDates, dateString, instance });\n },\n onValueUpdate: (\n selectedDates: Date[],\n dateString: string,\n instance: any\n ) => {\n this.flatpickrValueUpdate.emit({ selectedDates, dateString, instance });\n },\n onDayCreate: (\n selectedDates: Date[],\n dateString: string,\n instance: any,\n dayElement: HTMLElement\n ) => {\n this.flatpickrDayCreate.emit({\n selectedDates,\n dateString,\n instance,\n dayElement,\n });\n },\n };\n\n Object.keys(options).forEach((key) => {\n if (typeof options[key] === 'undefined') {\n if (typeof (this.options as any)[key] !== 'undefined') {\n options[key] = (this.options as any)[key];\n } else {\n options[key] = (this.defaults as any)[key];\n }\n }\n });\n\n // @ts-ignore\n options.time_24hr = options.time24hr;\n\n // workaround bug in flatpickr 4.6 where it doesn't copy the classes across\n // TODO - remove once fix in https://github.com/flatpickr/flatpickr/issues/1860 is released\n options.altInputClass =\n (options.altInputClass || '') + ' ' + this.elm.nativeElement.className;\n\n if (!options.enable) {\n delete options.enable;\n }\n\n this.instance = flatpickr(\n this.elm.nativeElement,\n options\n ) as flatpickr.Instance;\n this.setDisabledState(this.isDisabled);\n }\n\n ngOnChanges(changes: SimpleChanges): void {\n if (this.instance) {\n Object.keys(changes).forEach((inputKey) => {\n this.instance.set(inputKey as any, (this as any)[inputKey]);\n });\n }\n }\n\n ngOnDestroy(): void {\n if (this.instance) {\n this.instance.destroy();\n }\n }\n\n writeValue(value: any): void {\n let convertedValue: any = value;\n if (this.convertModelValue && this.mode === 'range' && value) {\n convertedValue = [value.from, value.to];\n }\n\n if (this.instance) {\n this.instance.setDate(convertedValue);\n } else {\n // flatpickr hasn't been initialised yet, store the value for later use\n this.initialValue = convertedValue;\n }\n }\n\n registerOnChange(fn: any): void {\n this.onChangeFn = fn;\n }\n\n registerOnTouched(fn: () => void): void {\n this.onTouchedFn = fn;\n }\n\n setDisabledState(isDisabled: boolean): void {\n this.isDisabled = isDisabled;\n if (this.instance) {\n if (this.isDisabled) {\n this.renderer.setProperty(this.instance._input, 'disabled', 'disabled');\n } else {\n this.renderer.removeAttribute(this.instance._input, 'disabled');\n }\n }\n }\n\n @HostListener('input')\n inputChanged(): void {\n const value: string = this.elm.nativeElement.value;\n if (this.convertModelValue && typeof value === 'string') {\n switch (this.mode) {\n case 'multiple':\n const dates: Array<Date | undefined> = value\n .split('; ')\n .map((str) =>\n this.instance.parseDate(\n str,\n this.instance.config.dateFormat,\n !this.instance.config.enableTime\n )\n );\n this.onChangeFn(dates);\n break;\n\n case 'range':\n const [from, to] = value\n .split(this.instance.l10n.rangeSeparator)\n .map((str) =>\n this.instance.parseDate(\n str,\n this.instance.config.dateFormat,\n !this.instance.config.enableTime\n )\n );\n this.onChangeFn({ from, to });\n break;\n\n case 'single':\n default:\n this.onChangeFn(\n this.instance.parseDate(\n value,\n this.instance.config.dateFormat,\n !this.instance.config.enableTime\n )\n );\n }\n } else {\n this.onChangeFn(value);\n }\n }\n}\n","import {\n NgModule,\n ModuleWithProviders,\n InjectionToken,\n Provider\n} from '@angular/core';\nimport { FlatpickrDirective } from './flatpickr.directive';\nimport {\n FlatpickrDefaults,\n FlatpickrDefaultsInterface\n} from './flatpickr-defaults.service';\n\nexport const USER_DEFAULTS = new InjectionToken('flatpickr defaults');\n\nexport function defaultsFactory(\n userDefaults: FlatpickrDefaultsInterface\n): FlatpickrDefaults {\n const defaults: FlatpickrDefaults = new FlatpickrDefaults();\n Object.assign(defaults, userDefaults);\n return defaults;\n}\n\n@NgModule({\n declarations: [FlatpickrDirective],\n exports: [FlatpickrDirective]\n})\nexport class FlatpickrModule {\n static forRoot(\n userDefaults: FlatpickrDefaultsInterface = {}\n ): ModuleWithProviders<FlatpickrModule> {\n return {\n ngModule: FlatpickrModule,\n providers: [\n {\n provide: USER_DEFAULTS,\n useValue: userDefaults\n },\n {\n provide: FlatpickrDefaults,\n useFactory: defaultsFactory,\n deps: [USER_DEFAULTS]\n }\n ]\n };\n }\n}\n","/*\n * Public API Surface of angularx-flatpickr\n */\n\nexport * from './lib/flatpickr.module';\nexport { FlatpickrDefaults, FlatpickrDefaultsInterface } from './lib/flatpickr-defaults.service';\nexport { FlatpickrDirective } from './lib/flatpickr.directive';\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":["i1.FlatpickrDefaults"],"mappings":"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"}