A single and dual date picker, written for angular 2+ projects.
Setup
import { DatePickerUtil, DatePickerConfig } from 'ct-ngx-datepicker';
...
class MyDatePickerConfig extends DatePickerConfig {
}
...
DatePickerUtil.forRoot(new MyDatePickerConfig())
Config is optional, more details to come on what options are configurable.
Usage Example
<ct-date-picker [(date)]="date1" zIndex="100" formControlName="singlePicker">
<input #date class="form-control" />
</ct-date-picker>
<ct-dual-picker [(dateFrom)]="date2" [(dateTo)]="date3" zIndex="100" formControlName="dualPicker">
<input #dateFrom class="form-control" />
<input #dateTo class="form-control" />
</ct-dual-picker>
npm install --save ct-ngx-datepicker
<ct-date-picker [(date)]="date1" zIndex="100" formControlName="singlePicker">
<input #date class="form-control" />
</ct-date-picker>
Wrap a input field in the element. Mark the input field with #date
- date - date model
- dateChange - Event emitter for notification of date changes
- zIndex - Allows specification of a custom z-index for the picker.
- minDate - Minimum allowed date.
- maxDate - Maximum allowed date.
match - Optional regex for properly parsing typed in dates, e.g. mm/dd/yyyyRemoved in version 4.0.0- globalMode - Sets the starting mode for selecting a date, e.g. Calendar, Year. If no value is specified, Calendar mode is implied.
- displayFormat - Sets the date format to display the date in the date picker. e.g. MM/DD/YYYY. If set, when focus is lost the date picker will display the date value in this format, inside the datepicker.
<ct-dual-picker [(dateFrom)]="date2" [(dateTo)]="date3" zIndex="100" formControlName="dualPicker">
<input #dateFrom class="form-control" />
<input #dateTo class="form-control" />
</ct-dual-picker>
Wrap two input fields in the element. Mark each input #dateFrom and #dateTo respectively.
- dateFrom - date model
- dateTo - date model
- dateFromChange - Event emitter for notification of date changes
- dateToChange - Event emitter for notification of date changes
- zIndex - Allows specification of a custom z-index for the picker.
- minDate - Minimum allowed date.
- maxDate - Maximum allowed date.
match - Optional regex for properly parsing typed in dates, e.g. mm/dd/yyyyRemoved in version 4.0.0- globalMode - Sets the starting mode for selecting a date, e.g. Calendar, Year. If no value is specified, Calendar mode is implied.
- displayFormat - Sets the date format to display the date in the date picker. e.g. MM/DD/YYYY. If set, when focus is lost the date picker will display the date value in this format, inside the datepicker.
- Angular 2+ (common, core, forms)
- jQuery 3+ (see note below)
- moment 2
I have already implemented the datepicker using the renderer class to support Angular Universal Apps, and avoid needing jQuery. However at this time renderer is experimental. When it is no longer experimental the code will be updated.
Because the datepicker returns a moment date, not a string.
- 5.1.0 - Added DisplayFormat parameter. Fixed a bug where clearing out text of a DatePicker didn't set the date to null, and added a shim so that if a two digit year is entered in IE, then it will pick the correct century (previously if you entered 10/3/15 it would choose 10/3/1915)
- 5.0.1 - Fix a bug where the month and year selection was not displaying properly.
- 5.0.0 -- Angular 4+ is the future!
- 4.3.0 - 4.4.0 -- The last of the Angular 2 days.
- 4.2.4 - Fix bug where setting a from date, then clicking to date (dualpicker) without selecting a date and then clicking back into the from date causes an exception because dateTo is undefined.
- 4.2.3 - Fix bug where dual picker is hidden when clicking on the to input.
- 4.2.2 - Make jquery typings a dependency, remove unneded styling.
- 4.2.0 - Date picker is now positioned fixed so it can overflow outside of containers with overflow: hidden/auto.
- 4.1.0 - Modify positioning on input element to correct location of above positioned date picker.
- 4.0.5 - Prevent date correction on dual picker from happening till focus is lost on the input.
- 4.0.4 - This version cannot be found.
- 4.0.2 - 4.0.3 -- Update the calendar when the minDate / maxDate changes.
- 4.0.1 -- Include a UMD, because forgetting it breaks the whole thing.
- 4.0.0 -- Bug fixes for: Positioning of the picker and the min/max windowing if today is outside. Removed the match regex option.
- 3.2.1 - 3.2.2 -- Remove DatePickerConfig for now, until it's ready for prime time.
- 3.0.0 - 3.2.0 -- Merge fix for changeDate being called more than once. Merge fix for the date getter using the minDate if no date value is supplied.
- 2.5.3 -- Update ViewChild syntax. Also fix extra padding, which moved the picker off the input box.
- 2.5.0 -- Ability to specify a minDate without a maxDate for validation
- 2.4.0 -- Add ability to specify calendar default mode (globalMode), e.g. month/year.
- 2.2.3 -- Remove sourcemap from dist build.
- 2.2.2 -- Fixed bug where dates weren't invalid when cleared
- 2.2.1 -- Fixed bug with validation on dual date picker.
- 2.2.0 -- Added regex matching for date validation
- 2.1.0 -- Added ability to validate dates on range, and moment.isValid
- 2.0.0 -- Removed unused api parameters. Added basic validation for reactive forms.
- 1.0.2 -- Notice about new repo.
- 1.0.1 -- Unspecified bug fixes (sorry, just starting to do this right)
- 1.0.0 -- Initial Release
- From 1.x to 2.x ..* Remove references to ctDisabled and inputClass from the datepickers. Instead apply those directly to the transcluded input.
- From 2.x to 3.x ..* We attempted an overhaul of the config, but then aborted. No migration needed if on > 3.2.0
- From 3.x to 4.x ..* Remove the match binding (if used).
- When using an ISO date (yyyy-mm-dd), the day selected on the calendar picker ends uup being localized for your timezone.