Skip to content

AngularJs directive to allow use of the bootstrap UI date/time pickers in a single dropdown

Notifications You must be signed in to change notification settings

AlexFess/bootstrap-ui-datetime-picker

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

49 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Bootstrap-UI/datetime-picker

AngularJs directive to use a date and/or time picker as a dropdown from an input.

Demo

Installation

To use the directive you must have the following angular-ui bootstrap directives included already

  • DatePicker
  • TimePicker

You should already have the ui.bootstrap dependancy included in your app.js file like below, You then need to add ui.bootstrap.datetimepicker, as so

angular.module('app', ['ui.bootstrap', 'ui.bootstrap.datetimepicker']);

Download the source from dist/datetime-picker.min.js file and include it in your project.

Or use bower (thank you krico for setup)

bower install bootstrap-ui-datetime-picker -S

and link with bower_components/bootstrap-ui-datetime-picker/dist/datetime-picker.min.js

Usage

You have the following properties available to use with the directive. All are optional unless stated otherwise

  • ngModel (required) - Your date object
  • isOpen - (true/false)
  • closeOnDateSelection (true/false)
  • enableDate (true/false)
  • enableTime (true/false)
  • todayText (string)
  • nowText (string)
  • dateText (string)
  • timeText (string)
  • clearText (string)
  • closeText (string)
  • dateDisabled
  • datepickerOptions (object)
  • timepickerOptions (object)
isOpen

Whether the popup/dropdown is visible or not. Defaults to false

closeOnDateSelection

Close popup once a date has been chosen. TimePicker will stay open until user closes.

enableDate

Whether you would like the user to be able to select a date. Defaults to true

enableTime

Whether you would like the user to be able to select a time. Defaults to true

todayText

The text for the button that allows the user to select today when the date picker is visible

nowText

The text for the button that allows the user to select the current time when the time picker is visible. If the date is already populated this will only change the time of the existing date.

dateText

The text for the button that allows the user to change to the date picker while the time picker is visible.

timeText

The text for the button that allows the user to change to the time picker while the date picker is visible.

clearText

The text for the button that allows the user to clear the currently selected date / time

closeText

The text for the button that closes the date / time popup/dropdown

dateDisabled

From angularUI site -> An optional expression to disable visible options based on passing date and current mode (day|month|year).

datepickerOptions

Object to configure settings for the datepicker (can be found on angularUI site)

timepickerOptions

Object to configure settings for the timepicker (can be found on angularUI site)

Css

Personally i dont like the look of the angular-ui calendar itself, this is because the buttons are configured to use the btn-default style. To get round this i have added a class called datetime-picker to the surrounding div element that contains the angular-ui datepicker. Using this you can change the style of the calendar. For example, if i add this css code, you will see the difference to the calendar in the images below

.datetime-picker div > table .btn-default {
    border: 0;
}
BEFORE

alt tag

AFTER

alt tag

Example

Here is an example to use the directive with a bootstrap input, displaying a calendar button

####HTML

<p class="input-group">
    <input type="text" class="form-control" datetime-picker="dd MMM yyyy HH:mm" ng-model="myDate" is-open="isOpen"  />
    <span class="input-group-btn">
        <button type="button" class="btn btn-default" ng-click="openCalendar($event, prop)"><i class="fa fa-calendar"></i></button>
    </span>
</p>

####JAVASCRIPT

app.controller('MyController', ['$scope', function($scope) {
    $scope.isOpen = false;
    
    $scope.openCalendar = function(e) {
        e.preventDefault();
        e.stopPropagation();
        
        $scope.isOpen = true;
    }
}]);

Support

This was developed using angular-ui bootstrap Version: 0.12.0 - 2014-11-16. If you have a bug, please check what version of angular-ui you are using. If you are using a version prior to this, then please upgrade if you can and try it. If the problem persists, please let me know. I do have a day job but will try to get back to you asap. If you can fix the bug, then let me know how, or even better, submit a pull request.

About

AngularJs directive to allow use of the bootstrap UI date/time pickers in a single dropdown

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 83.8%
  • HTML 16.2%