- Fixed calendar close clicking issues. It's harder than you might think
- Microsoft Edge compatibility updates
- Mostly just a few key PR inclusions
- Few small tweaks and minor bug fixes
- Third party library updates
- Typos and code formatting. Because I'm paranoid
- Better iOS support. The date inputs are no longer editable. Having a keyboard popup for editing dates was a lot slower then just tapping stuff. So we cut it. Thanks azaytsev-csr!
- Minor tweaks and outlier bug fixes Thanks Paul Ryan!
- More consistent moment usage. Cleaned up the code base quite a bit. Thanks Theodore Brown!
- Fire callback on single calendar when value is deleted
- Don't automatically include the "This month" preset in with custom presets (sorry guys)
- If required is set to
false
for a date range but you've included acurrent_date
value the input will pre-fill with that date rather then defaulting to the placeholder
- Pulled in a couple pull requests to fix some locale issues
- Couple small bug fixes and performance improvements
Originally the compiled CSS file had both my demo app CSS and the calendar CSS all mashed together. Apparently some folks found that to be annoying. (Hint: It was me) This is no longer the case.
Custom presets!!
- presets
[boolean] or [object]
- If you don't want to show the preset link just set this to
false
otherwise the default is true which will just give you a basic preset of.. yep.. presets. BOOM! - Otherwise, if you want to customize it up you can include an array of preset objects. Something like:
presets: [{ label: 'Last month', start: moment().subtract(1, 'month').startOf('month'), end: moment().subtract(1, 'month').endOf('month') },{ label: 'Last year', start: moment().subtract(1, 'year').startOf('year'), end: moment().subtract(1, 'year').endOf('year') }]
- If you don't want to show the preset link just set this to
We also added custom formatting for the placeholder text on the single date picker if the date is not required.
- placeholder
[string]
- Set placeholder text (note this will only apply if the required key is set to
false
)
- Set placeholder text (note this will only apply if the required key is set to
Last but not least we also added support for locale based first day of the week.
Version 1.0.5 sees two major improvements.
The first is you can now add a required
key for the single date picker if you'd like to break the default and generate a picker with a placeholder rather then a predated input.
new Calendar({
element: $('.daterange--single'),
current_date: 'June 15, 2015',
format: {input: 'M/D/YYYY'},
required: false
});
Note the input format will be the placeholder. Cool huh?
The second is that finally the picker's callback function will only fire if the dates have actually changed. Before the function would fire regardless of what dates were chosen. So dumb. We're smarter now.
- Formats! You can now format all the output dates via the format object in the
new Calendar
call (Thanks Derk-Jan Karrenbeld)
new Calendar({
...
format = {
input: 'MMMM D, YYYY', // Format for the input fields
preset: 'll', // Format for the preset dates
jump_month: 'MMMM', // Format for the month switcher
jump_year: 'YYYY' // Format for the year switcher
}
...
}
});
- Days array. You can now include your own days array if you'd like to change the values at the top of the calendar
new Calendar({
...
days_array: ['Su','Mo','Tu','We','Th','Fr','Sa']
...
}
});
- Added support for manual date entry outside the range.. will now clamp back/forward to latest/earliest dates rather then just resetting. Yay!
- On the double calendar, callbacks now submit on a click event outside the calendar if a valid date has been chosen for the first date. No need to pick the same second date just to submit the changes!
- A few more minor bug fixes and improvements
- Added basic shorthand keyword support
now
ortoday
to set date to today's dateearliest
orlatest
to set date to the preset earliest or latest dates respectively[number] [interval] [ago/ahead]
to advance or regress the date based off the currently selected date (i.e.1 month ago
on a date of August 1 would result in a date of July 1)
- You may now use plain date strings in the Calendar object
- Fixed a bug where auto selecting a week range after or before the current selection was getting suppressed and reset to the previous dates
- Added support for selecting a range of single day with the
same_day_range
boolean in the double calendar call - Cleaned and dried out a couple verbose functions
- Added license and repo info to the package.json
- Removed underscore dependency
- Added the github page publisher function to the gulpfile
- Added a switch statement for keycode checking (Thanks again Theodore Brown)
- Added the
'use strict'
label to the Calendar.js file - Cleaned out some unused gulp functions
- Compressed the Sass folder to a single level
- Removed global CSS reset file
- Fixed issue with presets not respecting earliest date
- Registered the package with Bower
bower install BaremetricsCalendar
(Thanks Agustin Diaz) - Shifted code base to support UMD support (Thanks Derrick Reimer)
- Added up/down keyboard support
- day = keystroke up/down
- week = hold shift + keystroke up/down
- month = hold meta + keystroke up/down
- Fixed a couple minor typos hither and thither