A lightweight & configurable time picker.
To change the time input, you can:
Note: Make sure to update the v-model reference when trying to change it from outside the component.
e.g. time = new Date(time)
| : | |||
<template>
  <time-picker v-model="time"/>
</template>
<script>
  export default {
    data () {
      return {
        time: new Date()
      }
    }
  }
</script>
<!-- time-picker-example.vue -->
| : | ||
<template>
  <time-picker v-model="time" :show-meridian="false"/>
</template>
<script>
  export default {
    data () {
      return {
        time: new Date()
      }
    }
  }
</script>
<!-- time-picker-24-example.vue -->
Example that limit time range from 8:00 AM to 8:00 PM:
| : | |||
<template>
  <time-picker v-model="time" :max="max" :min="min"/>
</template>
<script>
  export default {
    data () {
      return {
        time: new Date(),
        min: new Date('2017/01/01 8:00'), // date doesn't matter
        max: new Date('2017/01/01 20:00')
      }
    }
  }
</script>
<!-- time-picker-limit-example.vue -->
All input methods are all disabled in readonly mode.
| : | |||
<template>
  <time-picker v-model="time" readonly/>
</template>
<script>
  export default {
    data () {
      return {
        time: new Date()
      }
    }
  }
</script>
<!-- time-picker-readonly-example.vue -->
<template>
  <form class="form-inline">
    <dropdown class="form-group">
      <div class="input-group">
        <input class="form-control" type="text" :value="this.time.toTimeString()" readonly="readonly">
        <div class="input-group-btn">
          <btn class="dropdown-toggle"><i class="glyphicon glyphicon-time"></i></btn>
        </div>
      </div>
      <template slot="dropdown">
        <li style="padding: 10px">
          <time-picker v-model="time"/>
        </li>
      </template>
    </dropdown>
  </form>
</template>
<script>
  export default {
    data () {
      return {
        time: new Date()
      }
    }
  }
</script>
<!-- time-picker-with-dropdown.vue -->
| : | |||
<template>
  <time-picker v-model="time" icon-control-up="glyphicon glyphicon-plus" icon-control-down="glyphicon glyphicon-minus"/>
</template>
<script>
  export default {
    data () {
      return {
        time: new Date()
      }
    }
  }
</script>
<!-- time-picker-icons-example.vue -->
| : | 
<template>
  <time-picker v-model="time" :controls="false"/>
</template>
<script>
  export default {
    data () {
      return {
        time: new Date()
      }
    }
  }
</script>
<!-- time-picker-no-controls-example.vue -->
| : | |||
<template>
  <time-picker v-model="time" :input-width="inputWidth"/>
</template>
<script>
  export default {
    data () {
      return {
        time: new Date(''),
        inputWidth: 180
      }
    }
  }
</script>
<!-- time-picker-input-width-example.vue -->
| : | |||
<template>
  <time-picker v-model="time"/>
</template>
<script>
  export default {
    data () {
      return {
        time: new Date('')
      }
    }
  }
</script>
<!-- time-picker-empty-fields-example.vue -->
| Name | Type | Default | Required | Description | 
|---|---|---|---|---|
| v-model | Date | ✔ | The selected time. | |
| show-meridian | Boolean | true | Use 12H or 24H mode. | |
| hour-step | Number | 1 | Hours to increase or decrease when using a button. | |
| min-step | Number | 1 | Minutes to increase or decrease when using a button. | |
| readonly | Boolean | false | ||
| max | Date | The maximum time that user can select or input. | ||
| min | Date | The minimum time that user can select or input. | ||
| icon-control-up | String | glyphicon glyphicon-chevron-up | The arrow icon shown inside the increasebutton. | |
| icon-control-down | String | glyphicon glyphicon-chevron-down | The arrow icon shown inside the decreasebutton. | |
| controls | Boolean | true | Hide the up/down controlsif set tofalse. | |
| input-width | Number | 50 | (0.34+) The width in pixels of the hoursandminutesinputs. | 
Caught a mistake or want to contribute to the documentation? Edit this page on Github!
Designed and built by @wxsm
Code under MIT License
Document under CC BY 4.0