JSPM

  • ESM via JSPM
  • ES Module Entrypoint
  • Export Map
  • Keywords
  • License
  • Repository URL
  • TypeScript Types
  • README
  • Created
  • Published
  • Downloads 317
  • Score
    100M100P100Q97866F
  • License MIT

React Datetime Range Picker Component that Implements Google's Material Design Via Material-UI.

Package Exports

  • material-ui-datetime-range-picker

This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (material-ui-datetime-range-picker) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.

Readme

Material-UI Datetime Range Picker

Material-UI Datetime Range Picker is a datetime range picker built off of Material-UI components.

Check out their documentation site for live examples.

Installation

Material-UI Datetime Range Picker is available as an npm package.

npm install material-ui-datetime-range-picker

Notes

This is still a work in progress so use it at your own risk. I've added some basic documentation. There are many attributes that need to be abstracted into a param and other work that needs to be done. Feel free to contribute!

Usage

import { DateRangePicker } from 'material-ui-datetime-range-picker';

Example:

<DateRangePicker
    autoOk={true}
    autoOpenField={true}
    onChange={onChange}
    onDismiss={onDismiss}
    showCalendarStatus={true}
    className="my-date-picker"
    firstDayOfWeek={0}
    dayButtonSize="6.25vw"
    calendarDateWidth="80vw"
    calendarTimeWidth="40vw"
    local='en-US'
    mode='portrait'
    startLabel='Beginning'
    endLabel='Ending'
/>

Options:

  autoOk:
    Description:
      Boolean - If true, this closes the calendar automatically when a date/time is selected.

    Default: false

  autoOpenField:
    Description:
      Boolean - If true, immediately jumps to the next input field. For example, if you just selected the start date, the start time field would open immediately.

    Default: false

  onChange(e, selection):
    Description:
      Function - Called when the datetimes have been selected for start and end.

    Default: null

    Example:
      The `selection` will be an object with start and end attributes that will either be a datetime value or falsey (undefined/null).
  {
    start: Wed Jun 13 2018 12:00:00 GMT-0600 (MDT),
    end: undefined
  }
      Note that if a date is not given it will be either undefined or null (falsey value).

  onDismiss(e, selection):
    Description:
      Function - Called when the picker has been closed/dismissed.

    Default: null

    Example:
      The `selection` will be an object with start and end attributes that will either be a datetime value or falsey (undefined/null).
  {
    start: null,
    end: null
  }
      Note that if a date is not given it will be either undefined or null (falsey value).

  showCalendarStatus:
    Description:
      Boolean - If true, this will show a header with the current field being selected.

    Default: false

    Example:
      If true, the user would see a header displaying "Start Date", "End Time", etc... or the custom labels provided.

  className:
    Description:
      String - If provided, it will allow the class styling to overwrite some basic styling of the root element.

    Default: null

  container:
    Description:
      String - Determines if the calendar/time picker should appear as a modal or inline when active.

    Default: 'dialog'

    Options: 'dialog' or 'inline'

  endLabel:
    Description:
      String - The text used to indicate the ending date/time selection fields.

    Default: 'End'

  firstDayOfWeek:
    Description:
      Integer - Used to change the first day of week. It varies from Saturday to Monday between different locales. The allowed range is 0 (Sunday) to 6 (Saturday). The default is `1`, Monday, as per ISO 8601.

    Default: 1

  dayButtonSize:
    Description:
      String - Allows you to adjust the size of the day button. It is a string because it allows you to use different units from px to vw.

    Default: '34px'

  calendarDateWidth:
    Description:
      String - Allows you to adjust the width of the day picker. It is a string because it allows you to use different units from px to vw.

    Default: '310px'

  calendarTimeWidth:
    Description:
      String - Allows you to adjust the width of the time picker. It is a string because it allows you to use different units from px to vw.

    Default: '125px'

  locale:
    Description:
      String - The locale for calculating the datetime.

    Default: 'en-US'

  mode:
    Description:
      String - Determines the rotation of the calendar.

    Default: 'portrait'

    Options: 'portrait' or 'landscape'

  startLabel:
    Description:
      String - The text used to indicate the beginning date/time selection fields.

    Default: 'Start'

  value:
    Description:
      Object - The default value for the date/time range picker

    Example:
  {
    start: Wed Jun 13 2018 12:00:00 GMT-0600 (MDT),
    end: Wed Jun 14 2018 12:00:00 GMT-0600 (MDT)
  }

## Contributions:

I don't have a lot of time to maintain this repo currently. If you see any bugs, feel free to open an issue and if you have time, code contributions are always welcome.

## License
This project is licensed under the terms of the
[MIT license](https://github.com/jkslyby/material-ui-datetime-range-picker/blob/master/LICENSE)