import { ChangeDetectorRef, ElementRef, InjectionToken, OnDestroy, Type } from '@angular/core'; import { ControlValueAccessor, ValidationErrors, Validator, ValidatorFn } from '@angular/forms'; import { Observable, Subject, Subscription } from 'rxjs'; import { NbDateService } from '../calendar-kit/services/date.service'; import * as i0 from "@angular/core"; /** * The `NbDatepickerAdapter` instances provide way how to parse, format and validate * different date types. * */ export declare abstract class NbDatepickerAdapter { /** * Picker component class. * */ abstract picker: Type; /** * Parse date string according to the format. * */ abstract parse(value: string, format: string): D; /** * Format date according to the format. * */ abstract format(value: D, format: string): string; /** * Validates date string according to the passed format. * */ abstract isValid(value: string, format: string): boolean; } /** * Validators config that will be used by form control to perform proper validation. * */ export interface NbPickerValidatorConfig { /** * Minimum date available in picker. * */ min: D; /** * Maximum date available in picker. * */ max: D; /** * Predicate that determines is value available for picking. * */ filter: (D: any) => boolean; } /** * Datepicker is an control that can pick any values anyway. * It has to be bound to the datepicker directive through nbDatepicker input. * */ export declare abstract class NbDatepicker { /** * HTML input element date format. * */ abstract format: string; abstract get value(): T; abstract set value(value: T); abstract get valueChange(): Observable; abstract get init(): Observable; /** * Attaches datepicker to the native input element. * */ abstract attach(hostRef: ElementRef): any; /** * Returns validator configuration based on the input properties. * */ abstract getValidatorConfig(): NbPickerValidatorConfig; abstract show(): any; abstract hide(): any; abstract shouldHide(): boolean; abstract get isShown(): boolean; abstract get blur(): Observable; abstract get formatChanged$(): Observable; } export declare const NB_DATE_ADAPTER: InjectionToken>; export declare const NB_DATE_SERVICE_OPTIONS: InjectionToken; /** * The `NbDatepickerDirective` is form control that gives you ability to select dates and ranges. The datepicker * is shown when input receives a `focus` event. * * ```html * * * ``` * * @stacked-example(Showcase, datepicker/datepicker-showcase.component) * * ### Installation * * Import `NbDatepickerModule.forRoot()` to your root module. * ```ts * @NgModule({ * imports: [ * // ... * NbDatepickerModule.forRoot(), * ], * }) * export class AppModule { } * ``` * And `NbDatepickerModule` to your feature module. * ```ts * @NgModule({ * imports: [ * // ... * NbDatepickerModule, * ], * }) * * export class PageModule { } * ``` * ### Usage * * If you want to use range selection, you have to use `NbRangepickerComponent` instead: * * ```html * * * ``` * * Both range and date pickers support all parameters as calendar, so, check `NbCalendarComponent` for additional * info. * * @stacked-example(Range showcase, datepicker/rangepicker-showcase.component) * * Datepicker is the form control so it can be bound with angular forms through ngModel and form controls. * * @stacked-example(Forms, datepicker/datepicker-forms.component) * * `NbDatepickerDirective` may be validated using `min` and `max` dates passed to the datepicker. * * @stacked-example(Validation, datepicker/datepicker-validation.component) * * Also `NbDatepickerDirective` may be filtered using `filter` predicate * that receives date object and has to return a boolean value. * * @stacked-example(Filter, datepicker/datepicker-filter.component) * * If you need to pick a time along with the date, you can use nb-date-timepicker * * ```html * * * ``` * @stacked-example(Date timepicker, datepicker/date-timepicker-showcase.component) * * A single column picker with options value as time and minute, so users won’t be able to pick * hours and minutes individually. * * @stacked-example(Date timepicker single column, datepicker/date-timepicker-single-column.component) * The `NbDatepickerComponent` supports date formatting: * * ```html * * * ``` * * ## Formatting Issue * * By default, datepicker uses angulars `LOCALE_ID` token for localization and `DatePipe` for dates formatting. * And native `Date.parse(...)` for dates parsing. But native `Date.parse` function doesn't support formats. * To provide custom formatting you have to use one of the following packages: * * - `@nebular/moment` - provides moment date adapter that uses moment for date objects. This means datepicker than * will operate only moment date objects. If you want to use it you have to install it: `npm i @nebular/moment`, and * import `NbMomentDateModule` from this package. * * - `@nebular/date-fns` - adapter for popular date-fns library. This way is preferred if you need only date formatting. * Because date-fns is treeshakable, tiny and operates native date objects. If you want to use it you have to * install it: `npm i @nebular/date-fns`, and import `NbDateFnsDateModule` from this package. * * ### NbDateFnsDateModule * * Format is required when using `NbDateFnsDateModule`. You can set it via `format` input on datepicker component: * ```html * * ``` * Also format can be set globally with `NbDateFnsDateModule.forRoot({ format: 'dd.MM.yyyy' })` and * `NbDateFnsDateModule.forChild({ format: 'dd.MM.yyyy' })` methods. * * Please note to use some of the formatting tokens you also need to pass * `{ useAdditionalWeekYearTokens: true, useAdditionalDayOfYearTokens: true }` to date-fns parse and format functions. * You can configure options passed this functions by setting `formatOptions` and * `parseOptions` of options object passed to `NbDateFnsDateModule.forRoot` and `NbDateFnsDateModule.forChild` methods. * ```ts * NbDateFnsDateModule.forRoot({ * parseOptions: { useAdditionalWeekYearTokens: true, useAdditionalDayOfYearTokens: true }, * formatOptions: { useAdditionalWeekYearTokens: true, useAdditionalDayOfYearTokens: true }, * }) * ``` * Further info on `date-fns` formatting tokens could be found at * [date-fns docs](https://date-fns.org/v2.0.0-alpha.27/docs/Unicode-Tokens). * * You can also use `parseOptions` and `formatOptions` to provide locale. * ```ts * import { eo } from 'date-fns/locale'; * * @NgModule({ * imports: [ * NbDateFnsDateModule.forRoot({ * parseOptions: { locale: eo }, * formatOptions: { locale: eo }, * }), * ], * }) * ``` * * @styles * * datepicker-background-color: * datepicker-border-color: * datepicker-border-style: * datepicker-border-width: * datepicker-border-radius: * datepicker-shadow: * */ export declare class NbDatepickerDirective implements OnDestroy, ControlValueAccessor, Validator { protected document: any; protected datepickerAdapters: NbDatepickerAdapter[]; protected hostRef: ElementRef; protected dateService: NbDateService; protected changeDetector: ChangeDetectorRef; /** * Provides datepicker component. * */ set setPicker(picker: NbDatepicker); protected pickerInputsChangedSubscription: Subscription | undefined; /** * Datepicker adapter. * */ protected datepickerAdapter: NbDatepickerAdapter; /** * Datepicker instance. * */ protected picker: NbDatepicker; protected destroy$: Subject; protected isDatepickerReady: boolean; protected queue: D | undefined; protected onChange: (D: any) => void; protected onTouched: () => void; /** * Form control validators will be called in validators context, so, we need to bind them. * */ protected validator: ValidatorFn; constructor(document: any, datepickerAdapters: NbDatepickerAdapter[], hostRef: ElementRef, dateService: NbDateService, changeDetector: ChangeDetectorRef); /** * Returns html input element. * */ get input(): HTMLInputElement; /** * Returns host input value. * */ get inputValue(): string; ngOnDestroy(): void; /** * Writes value in picker and html input element. * */ writeValue(value: D): void; registerOnChange(fn: any): void; registerOnTouched(fn: any): void; setDisabledState(isDisabled: boolean): void; /** * Form control validation based on picker validator config. * */ validate(): ValidationErrors | null; /** * Hides picker, focuses the input */ protected hidePicker(): void; /** * Validates that we can parse value correctly. * */ protected parseValidator(): ValidationErrors | null; /** * Validates passed value is greater than min. * */ protected minValidator(): ValidationErrors | null; /** * Validates passed value is smaller than max. * */ protected maxValidator(): ValidationErrors | null; /** * Validates passed value satisfy the filter. * */ protected filterValidator(): ValidationErrors | null; /** * Chooses datepicker adapter based on passed picker component. * */ protected chooseDatepickerAdapter(): void; /** * Attaches picker to the host input element and subscribes on value changes. * */ protected setupPicker(): void; protected writePicker(value: D): void; protected writeInput(value: D): void; /** * Validates if no datepicker adapter provided. * */ protected noDatepickerAdapterProvided(): boolean; protected subscribeOnInputChange(): void; /** * Parses input value and write if it isn't null. * */ protected handleInputChange(value: string): void; protected parseInputValue(value: any): D | null; static ɵfac: i0.ɵɵFactoryDeclaration, never>; static ɵdir: i0.ɵɵDirectiveDeclaration, "input[nbDatepicker]", never, { "setPicker": { "alias": "nbDatepicker"; "required": false; }; }, {}, never, never, false, never>; }