vue-datepicker2

2.3.0-dev • Public • Published

vue-datepicker2

calendar and datepicker component with material design for Vue.js 2.x.

This project is a fork from vue-datepicker to cleanup code and refactor things

Screenshot

Requirements

TODO

  • Fork project and add suffix 2
  • Remove legacy code
  • Publish to npm
  • Use v-model directive
  • Change options to seperated props
  • Code review

Installation

npm

$ npm install vue-datepicker2

Usage

<script>
import myDatepicker from 'vue-datepicker2'
 
export default {
  data () {
    return {
      startTime: '',
 
      option: {
        type: 'day',
        week: ['Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa', 'Su'],
        month: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'],
        format: 'YYYY-MM-DD',
        placeholder: 'when?',
        inputStyle: {
          'display': 'inline-block',
          'padding': '6px',
          'line-height': '22px',
          'font-size': '16px',
          'border': '2px solid #fff',
          'box-shadow': '0 1px 3px 0 rgba(0, 0, 0, 0.2)',
          'border-radius': '2px',
          'color': '#5F5F5F'
        },
        color: {
          header: '#ccc',
          headerText: '#f00'
        },
        buttons: {
          ok: 'Ok',
          cancel: 'Cancel'
        },
        overlayOpacity: 0.5, // 0.5 as default
        dismissible: true // as true as default
      },
      timeoption: {
        type: 'min',
        week: ['Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa', 'Su'],
        month: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'],
        format: 'YYYY-MM-DD HH:mm'
      },
      multiOption: {
        type: 'multi-day',
        week: ['Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa', 'Su'],
        month: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'],
        format:"YYYY-MM-DD HH:mm"
      },
      limit: [{
        type: 'weekday',
        available: [1, 2, 3, 4, 5]
      },
      {
        type: 'fromto',
        from: '2016-02-01',
        to: '2016-02-20'
      }],
      dateBodyClass: 'date-body'
    }
  },
  components: {
    'date-picker': myDatepicker
  }
}
</script> 
<template>
  <div class="card">
    <div class="row">
      <span>Departure Date:</span>
      <date-picker v-model="startTime" :option="option" :limit="limit"></date-picker>
    </div>
 
  </div>
</template>

API

  • Option
  • type
  type: 'day' // 'min', 'multi-day'

  • format
format: 'YYYY-MM-DD HH:mm'
  • placeholder
placeholder: 'when?'
  • week
 week: ['Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa', 'Su']
  • month
  month: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August','September', 'October', 'November', 'December']
  • wrapperClass
wrapperClass: ''
  • inputClass
inputClass: ''
  • inputStyle
inputStyle: {
  'display': 'inline-block',
  'padding': '6px',
  'line-height': '22px',
  'font-size': '16px',
  'border': '2px solid #fff',
  'box-shadow': '0 1px 3px 0 rgba(0, 0, 0, 0.2)',
  'border-radius': '2px',
  'color': '#5F5F5F'
}
  • color
  color: {
    header: '#ccc',
    headerText: '#f00'
  }
  • buttons
buttons: {
  ok: 'OK',
  cancel: 'Cancel'
}
  • animate
  overlayOpacity: 0.5, // 0.5 as default
  dismissible: true // as true as default
  • limit
  • from sometime to sometime(when from/to is empty, days before/after end/start time will be available)
 
limit: {
  type:'fromto',
  from:'2016-01-10',
  to:'2016-01-30'
}
 
  • weekdays
 
limit:{
  type: 'weekday',
  available: [1, 2, 3, 4, 5]
}
 

prop

date: {
  time: '' // string
}
 
<date-picker :date="date" :limit="limit"></date-picker>
 

License

The MIT License

Package Sidebar

Install

npm i vue-datepicker2

Weekly Downloads

22

Version

2.3.0-dev

License

MIT

Last publish

Collaborators

  • inndy