angularx-flatpickr
Version:
An angular 17.0+ wrapper for flatpickr
181 lines • 25.7 kB
JavaScript
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"]}