Skip to content
This repository has been archived by the owner on Sep 12, 2018. It is now read-only.

Latest commit

 

History

History
99 lines (79 loc) · 3.33 KB

README.md

File metadata and controls

99 lines (79 loc) · 3.33 KB

date-picker

An Angular directive of Scrollable datepicker.

Overview

A calendar is a widely used component to filter search results. This directive makes it easier to pick a date period without a whole lot of settings

Screenshots

popup_screen_shot

Usage

  1. include modules, service
  • include modules: datePeriodPicker, angularModalService
    ex) in app.js, angular.module('myApp', ['ngCookies', ..., 'datePeriodPicker', 'angularModalService'])
  • add service: DatepickerModalService
    ex) in filter.controller.js, angular.module('yourApp').controller('FilterController', function($scope, ..., DatepickerModalService)
  1. define options

  2. call DatepickerModalService.show parameters:

  • startDate: a variable that will be used as startDate
  • endDate: a variable that will be used as endDate
  • callback(eventName): a callback function, which will be called when a date is selected receiving callback will receive eventName such as 'start'(for start date selection), 'end'(for start date selection)
  • datePickerOptions:
    limitNight: maximum nights that a user can select as a period
    selectableDays: selectable days from today
    (ex: selectableDays:90 means that a user can select any date between today and today + 90 days).
    Visible months are based on this selectable days as well.

###html

<a href='javascript:;', ng-click="showDatepicker()">Picke a Date!</a>

####javascript

    $scope.startDate = null
    $scope.endDate = null

    var datePickerOptions = {
        enableKoreanCalendar: true,
        limitNights: 13,
        selectableDays: 90,
        // holidayUrl: `${appConfig.apiUrlPrefix}/common/holidays`,
        checkInString: '입실',
        checkOutString: '퇴실'
    }

    $scope.datepickerCallback = function(eventName) {
        if (eventName === 'start') {
            // start date selected
        } else if (eventName === 'end') {
            // end date selected
        }
    };


    $scope.showDatepicker = function() {
      $scope.isBottomHidden = true;
      return DatepickerModalService.show($scope.startDate, $scope.endDate, $scope.datepickerCallback, datePickerOptions).then(function(result) {
        $scope.startDate = result.start;
        return $scope.endDate = result.end;
      }).then(function() {
        // dates selected
      }, function(err) {
        // modal dismissed
      });
    };

limitation

HTML and CSS files are fixed, and the options are limited.

License

See LICENSE for full license text.

Copyright 2016 NAVER Corp.

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

    http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.

Contact

Please let us know, if you have any questions or suggestions. Also, if you are happy to use this directive, just share us the story so that we can make this component better!