Vue Time Picker 2 MDB Pro component
Vue Time Picker 2 - Bootstrap 4 & Material Design
Note: We are transitioning MDB4 to a legacy version and focusing on developing MDB5.
While we'll continue to support for the transition period, we encourage you to migrate to
MDB5. We're offering a 50% discount on MDB5 PRO to help with your transition,
enabling you to leverage the full potential of the latest version. You can find more information here.
get 50% discount on MDB5 PRO
Vue Bootstrap time picker is a component which allows user to select a time in the Bootstrap form.
This documentation may contain syntax introduced in the MDB Vue 6.7.0 and can be incompatible with previous versions. For old timepicker documentation please follow the link.
Basic examples MDB Pro component
<template>
<mdb-container>
<mdb-row>
<mdb-col col="6">
<mdb-time-picker-2 id="timePickerOne" placeholder="Select your time" label="format: am/pm"
v-model="pickerValue" />
</mdb-col>
</mdb-row>
</mdb-container>
</template>
<script>
import {
mdbTimePicker2,
mdbContainer,
mdbRow,
mdbCol
} from "mdbvue";
export default {
name: "TimePickerPage",
components: {
mdbTimePicker2,
mdbContainer,
mdbRow,
mdbCol
},
data() {
return {
pickerValue: ""
};
}
};
</script>
24 hour clock MDB Pro component
Set 12 or 24 hour clock.
<template>
<mdb-container>
<mdb-row>
<mdb-col col="6">
<mdb-time-picker-2 id="timePickerTwo" placeholder="Select your time" label="format: 24h"
:hours-format="24" v-model="pickerValue" />
</mdb-col>
</mdb-row>
</mdb-container>
</template>
<script>
import {
mdbTimePicker2,
mdbContainer,
mdbRow,
mdbCol
} from "mdbvue";
export default {
name: "TimePickerPage",
components: {
mdbTimePicker2,
mdbContainer,
mdbRow,
mdbCol
},
data() {
return {
pickerValue: ""
};
}
};
</script>
Step MDB Pro component
Step - 15
<template>
<mdb-container>
<mdb-row>
<mdb-col col="6">
<mdb-time-picker-2 id="timePickerTwo" placeholder="Select your time" label="format: 24h"
:hours-format="24" v-model="pickerValue" />
</mdb-col>
</mdb-row>
</mdb-container>
</template>
<script>
import {
mdbTimePicker2,
mdbContainer,
mdbRow,
mdbCol
} from "mdbvue";
export default {
name: "TimePickerPage",
components: {
mdbTimePicker2,
mdbContainer,
mdbRow,
mdbCol
},
data() {
return {
pickerValue: ""
};
}
};
</script>
Range MDB Pro component
Select time from 10:00am to 09:00pm
<template>
<mdb-container>
<mdb-row>
<mdb-col col="6">
<mdb-time-picker-2 id="timePickerTwo" placeholder="Select your time" label="format: 24h"
:hours-format="24" v-model="pickerValue" />
</mdb-col>
</mdb-row>
</mdb-container>
</template>
<script>
import {
mdbTimePicker2,
mdbContainer,
mdbRow,
mdbCol
} from "mdbvue";
export default {
name: "TimePickerPage",
components: {
mdbTimePicker2,
mdbContainer,
mdbRow,
mdbCol
},
data() {
return {
pickerValue: ""
};
}
};
</script>
Validation MDB Pro component
Validate Time Picker
<template>
<mdb-container>
<mdb-row>
<mdb-col sm="8" md="6">
<form @submit.prevent>
<mdb-time-picker2 label="Select time between 10:00 and 15:00" :hours-format="24" v-model="picker"
min="10:00" max="15:00" :wasValidated="wasValidated" :isValid="isValid"
validFeedback="Everything OK" invalidFeedback="Choose another hour!"
@getInputValue="handleChange" />
<mdb-btn @click="submit" type="submit" class="float-right" color="primary" rounded>Submit</mdb-btn>
<mdb-btn @click="wasValidated = false" type="submit" class="float-right" color="primary" rounded>Reset
</mdb-btn>
</form>
</mdb-col>
</mdb-row>
</mdb-container>
</template>
<script>
import {
mdbTimePicker2,
mdbContainer,
mdbRow,
mdbCol,
mdbBtn
} from "mdbvue";
export default {
components: {
mdbTimePicker2,
mdbContainer,
mdbRow,
mdbCol,
mdbBtn
},
data() {
return {
picker: "",
timePickerValue: "",
isValid: false,
inputValue: "12:00"
};
},
methods: {
submit() {
this.wasValidated = true;
this.validate();
},
handleChange(e) {
this.inputValue = e;
this.$nextTick(this.validate);
},
validate() {
if (this.inputValue === this.picker12 && this.inputValue !== "") {
this.isValid = true;
} else {
this.isValid = false;
}
}
}
};
</script>
Alternative input styling MDB Pro component
<template>
<mdb-container>
<mdb-row>
<mdb-col sm="8" md="6">
<mdb-time-picker2 label="Simple input" :outline="false" />
</mdb-col>
</mdb-row>
<mdb-row>
<mdb-col sm="8" md="6">
<mdb-time-picker2 label="Background input" bg />
</mdb-col>
</mdb-row>
<mdb-row>
<mdb-col sm="8" md="6">
<mdb-time-picker2 label="Large input" size="lg"
:picker-icon="{ icon: 'clock', class: 'fa-lg', far: true }" />
</mdb-col>
</mdb-row>
<mdb-row>
<mdb-col sm="8" md="6">
<mdb-time-picker2 label="Small input" size="sm"
:picker-icon="{ icon: 'clock', class: 'fa-sm', far: true }" />
</mdb-col>
</mdb-row>
</mdb-container>
</template>
<script>
import {
mdbTimePicker2,
mdbContainer,
mdbRow,
mdbCol
} from "mdbvue";
export default {
name: "TimePickerPage",
components: {
mdbTimePicker2,
mdbContainer,
mdbRow,
mdbCol
},
data() {
return {
pickerValue: ""
};
}
};
</script>
TimePicker with icon MDB Pro component
<template>
<mdb-container>
<mdb-row>
<mdb-col col="6">
<mdb-time-picker-2 id="timePickerFour" label="icon" icon="clock" v-model="pickerValue" />
</mdb-col>
</mdb-row>
</mdb-container>
</template>
<script>
import {
mdbTimePicker2,
mdbContainer,
mdbRow,
mdbCol
} from "mdbvue";
export default {
name: "TimePickerPage",
components: {
mdbTimePicker2,
mdbContainer,
mdbRow,
mdbCol
},
data() {
return {
pickerValue: ""
};
}
};
</script>
Keyboard navigation
Open time picker by pressing Enter
key and tab through
available options - and press Enter
again to select one. When the focus is on hours/minuts (header) use
up and down arrows to increment values. To
close a modal use Ecs
. Use backspace
to go back from minutes to hour
plate.
Default value
To set the default value just use v-model
directive and set
date as a value.
Access from outside
<template>
<mdb-container>
<mdb-row>
<mdb-col col="6">
<mdb-time-picker-2 label="outside access" ref="picker" v-model="pickerValue" />
<mdb-btn size="sm" @click.native="$refs.picker.open()">Open Picker</mdb-btn>
<mdb-btn size="sm" @click.native="$refs.picker.clear()">Clear Picker</mdb-btn>
</mdb-col>
</mdb-row>
</mdb-container>
</template>
<script>
import {
mdbTimePicker2,
mdbContainer,
mdbRow,
mdbCol,
mdbBtn
} from "mdbvue";
export default {
name: "TimePickerPage",
components: {
mdbTimePicker2,
mdbContainer,
mdbRow,
mdbCol,
mdbBtn
},
data() {
return {
pickerValue: ""
};
}
};
</script>
Time Picker - API
In this section you will find advanced information about the Time Picker component. You will learn which modules are required in this component, what are the possibilities of configuring the component, and what events and methods you can use in working with it.
Import statement
<script>
import {
mdbTimePicker
} from 'mdbvue';
</script>
API Reference: Properties
Name | Type | Default | Description | Example |
---|---|---|---|---|
color
|
String | 'primary-color' |
Changing picker elements color |
<mdb-time-picker color="secondary-color">
|
textColor
|
String | 'text-primary' |
Changing picker text color |
<mdb-time-picker text-color="grey-text">
|
autoClose
|
Boolean | false |
Makes the picker close after minutes are selected |
<mdb-time-picker auto-close >
|
hoursFormat
|
Number | 12 |
Changing picker format |
<mdb-time-picker :hoursFormat="24">
|
id |
String |
|
Adding id attribute to the component. |
<mdb-time-picker id="timePickerOne">
|
label
|
String |
|
Select label. |
<mdb-time-picker label="format: am/pm">
|
placeholder
|
String | 'Select time' |
Select placeholder. |
<mdb-time-picker placeholder="Select your time">
|
outline
|
Boolean | true |
Applies outline style to a component |
<mdb-time-picker-2 outline />
|
disableInput
|
Boolean |
|
The input is not rendered - option for opening time picker with a custom element |
<mdb-time-picker-2 disable-input />
|
pickerIcon
|
Object | { icon: 'clock' } |
Changes the picker's icon (available keys: icon, fab, far, fad, fal, class |
<mdb-time-picker-2 :pickerIcon="{icon: '', fab: true, class:
"red-text"}" />
|
step
|
Number | 1 |
Step for minutes (allowed: 1 or multiples of 5 ) |
<mdb-time-picker-2 :step="20" />
|
min
|
String |
|
Minimum value |
<mdb-time-picker-2 min="12:00am" />
|
max
|
String |
|
Maximum value |
<mdb-time-picker-2 max="12:00am" />
|
wasValidated
|
Boolean | false |
Adds validation styling |
<mdb-time-picker-2 :was-validated="true" />
|
isValid
|
Boolean | false |
Indicates if the selected time is value |
<mdb-time-picker-2 :was-validated="true" :is-valid="false"
/>
|
validFeedback
|
String |
|
Displays a validation message (valid) |
<mdb-time-picker-2 valid-feedback="OK!" />
|
invalidFeedback
|
String |
|
Displays a validation message (invalid) |
<mdb-time-picker-2 invalid-feedback="OK!" />
|
bg
|
Boolean | false |
Sets design to animated border with background |
<mdb-time-picker-2 bg />
|
icon
|
String |
|
Adds icon to a datepicker's input |
<mdb-time-picker-2 icon="clock" />
|
iconClass
|
String |
|
Adds custom class to a datepicker's icon |
<mdb-time-picker-2 icon="clock" iconClass="yellow-text"
/>
|
far
|
Boolean | false |
Changes icon's style to regular |
<mdb-time-picker-2 icon="paper-plane" far/>
|
fab
|
Boolean | false |
Changes icon's style to brands |
<mdb-time-picker-2 icon="..." fab />
|
fad
|
Boolean | false |
Changes icon's style to duotone |
<mdb-time-picker-2 icon="..." fad />
|
fal
|
Boolean | false |
Changes icon's style to light |
<mdb-time-picker-2 icon="..." fal />
|
v-model
|
String | '' |
Stores timePicker value |
<mdb-time-picker-2 v-model="pickerValue" />
|
doneLabel
|
String | 'Ok' |
Changes the label of the done button |
<mdb-time-picker-2 done-label="..." />
|
clearLabel
|
String | 'Ok' |
Changes the label of the clear button |
<mdb-time-picker-2 clear-label="..." />
|
closeLabel
|
String | 'Ok' |
Changes the label of the close button |
<mdb-time-picker-2 close-label="..." />
|
hoursAriaLabel
|
String | 'Ok' |
Changes the aria label of the hours buttons |
<mdb-time-picker-2 hours-aria-label="..." />
|
minutesAriaLabel
|
String | 'Ok' |
Changes the aria label of the minutes buttons |
<mdb-time-picker-2 minutes-aria-label="..." />
|
API Reference: Methods
Name | Parameters | Description | Example |
---|---|---|---|
@getValue |
value | Returns time-picker value. |
<mdb-time-picker @getValue="getPickersValue" />
|
@focus |
e |
Emitted on input's native focus event, meaning when the
field gains focus.
|
<mdb-time-picker-2 @focus="onFocus" />
|
@blur |
e |
Emitted on input's native blur event, meaning when the
field looses focus.
|
<mdb-time-picker-2 @blur="onBlur" />
|
@close |
e | Emitted on timePicker close. |
<mdb-time-picker @close="onClose" />
|
@getInputValue |
e | Emittes the input's value |
<mdb-time-picker @getInputValue="handleInputChange" />
|