ng-moment-picker
v0.8.2
Published
Angular Moment Picker is a fork of Indri's AngularJS directive
Downloads
3
Maintainers
Readme
Angular Moment Picker
Check out the homepage at http://indrimuska.github.io/angular-moment-picker/.
Angular Moment Picker is a native AngularJS directive for date and time picker that uses Moment.js and does not require jQuery.
Installation
Get Angular Moment Picker from npm, bower or git:
npm install angular-moment-picker
bower install moment-picker
git clone https://github.com/indrimuska/angular-moment-picker.git
Include style and script in your page:
<script src="//ajax.googleapis.com/ajax/libs/angularjs/1.4.4/angular.min.js"></script>
<script src="//cdnjs.cloudflare.com/ajax/libs/moment.js/2.10.6/moment-with-locales.js"></script>
<script src="//cdn.rawgit.com/indrimuska/angular-moment-picker/master/dist/angular-moment-picker.min.js"></script>
<link href="//cdn.rawgit.com/indrimuska/angular-moment-picker/master/dist/angular-moment-picker.min.css" rel="stylesheet">
Add moment-picker dependency to your module:
var myApp = angular.module('myApp', ['moment-picker']);
Provide the attribute to your element:
<div moment-picker="myDate"> {{ myDate }} </div>
Demo
Check out the demo page at http://indrimuska.github.io/angular-moment-picker/.
The views
Decade view | Year view | Month view :---:|:---:|:---: | | Day view | Hour view | Minute view | |
Options
To configure Angular Moment Picker you have to append to your block or your input the attribute options you want to set.
<div moment-picker="ctrl.birthday" locale="fr" format="LL">
Mon anniversaire est le {{ ctrl.birthday }}
</div>
<input moment-picker="ctrl.dateFormatted" ng-model="ctrl.momentDate" format="DD/MM/YYYY">
Property | Default | Description
---|---|---
moment-picker | | Two-way bindable property as datetime string value.
ng-model | | Two-way bindable property as Moment.js object.
locale | "en"
| Locale code. 1
format | "L LTS"
| Format of the output value and min/max date. 1
min-view | "decade"
| Minimum navigable view.
max-view | "minute"
| Maximum navigable view.
start-view | "year"
| Initial view when the picker is open.
min-date | | Two-way bindable property representing the minimum selectable date (as String in the same format of the value, or as a Moment.js object).
max-date | | Two-way bindable property representing the maximum selectable date (as String in the same format of the value, or as a Moment.js object).
disable | false
| Disables the picker if truly.
autoclose | true
| Closes the picker after selecting a date.
today | false
| Highlights the current day.
keyboard | false
| Allows using the keyboard to navigate the picker.
additions | { top: undefined, bottom: undefined }
| Template url for custom contents above and below each picker views (inside the dialog).
Methods
Append your method to your element and define its behavior in the controller.
<div moment-picker="ctrl.exhibition" format="dddd D MMMM" selectable="ctrl.isSelectable(date, type)">
Next exhibition is on {{ ctrl.exhibition }}.
</div>
ctrl.isSelectable = function (date, type) {
// disable all Sundays in the Month View
return type != 'day' || date.format('dddd') != 'Sunday';
};
Method | Parameters | Description
---|---|---
selectable | date
, type
| Return true
if the given date can be selected in the current view. Please note that this method is called for every date in the view, every time a view is rendered, so be careful, it may affect performances.
Events
As for methods, to bind an event you only need to attach the right property to your picker.
<div moment-picker="ctrl.meeting" format="HH:mm A" change="ctrl.onChange(newValue, oldValue)">
The meeting starts at {{ ctrl.meeting }}.
</div>
ctrl.onChange = function (newValue, oldValue) {
$log.log('Meeting changed from ' + oldValue + ' to ' + newValue);
};
Event | Parameters | Description
---|---|---
change | newValue
, oldValue
| Function fired upon change in picker value.
momentPickerProvider
Angular Moment Picker comes out with its own provider, in order to define your own configuration for all the pickers in your app.
angular
.module('myApp', ['moment-picker'])
.config(['momentPickerProvider', function (momentPickerProvider) {
momentPickerProvider.options({
/* ... */
});
}]);
Property | Default | Description
---|---|---
locale | "en"
| Locale code. 1
format | "L LTS"
| Format of the output value and min/max date. 1
min-view | "decade"
| Minimum navigable view.
max-view | "minute"
| Maximum navigable view.
start-view | "year"
| Initial view after picker opening.
autoclose | true
| Closes the picker after selecting a date.
today | false
| Highlights the current day.
keyboard | false
| Allows using the keyboard to navigate the picker.
show-header | true
| Shows the header in the view.
left-arrow | "←"
| Left arrow string (HTML allowed).
right-arrow | "→"
| Right arrow string (HTML allowed).
additions | { top: undefined, bottom: undefined }
| Template url for custom contents above and below each picker views (inside the dialog).
years-format | "YYYY"
| Years format in decade
view.
months-format | "MMM"
| Months format in year
view.
days-format | "D"
| Days format in month
view.
hours-format | "HH:[00]"
| Hours format in day
view.
hours-start | 0
| First rendered hour in day
view (24h format).
hours-end | 23
| Last rendered hour in day
view (24h format).
minutes-format | 2 | Minutes format in hour
view.
minutes-step | 5
| Step between each visible minute in hour
view.
minutes-start | 0
| First rendered minute in hour
view.
minutes-end | 59
| Last rendered minute in hour
view.
seconds-format | "ss"
| Seconds format in minute
view.
seconds-step | 1
| Step between each visible second in minute
view.
seconds-start | 0
| First rendered second in minute
view.
seconds-end | 59
| Last rendered second in minute
view.
Notes
- Locale codes and format tokens are available at http://momentjs.com/.
- Locale format
LT
without meridiem part (AM/PM, am/pm).
Builder
Try the online Angular Moment Picker Builder:
http://indrimuska.github.io/angular-moment-picker/#builder.
License
Copyright (c) 2015 Indri Muska. Licensed under the MIT license.