mirror of
https://github.com/scinote-eln/scinote-web.git
synced 2025-01-11 01:50:18 +08:00
52 lines
1.2 KiB
Vue
52 lines
1.2 KiB
Vue
|
<template>
|
||
|
<div class="sci-input-container time-container right-icon">
|
||
|
<input class="time-part sci-input-field"
|
||
|
@input="update"
|
||
|
:id="this.selectorId"
|
||
|
type="text"
|
||
|
data-mask-type="time"
|
||
|
v-model="value"
|
||
|
placeholder="HH:mm"/>
|
||
|
<i class="fas fa-clock"></i>
|
||
|
</div>
|
||
|
</template>
|
||
|
|
||
|
<script>
|
||
|
export default {
|
||
|
name: 'TimePicker',
|
||
|
props: {
|
||
|
selectorId: { type: String, required: true }
|
||
|
},
|
||
|
data() {
|
||
|
return {
|
||
|
value: ''
|
||
|
}
|
||
|
},
|
||
|
mounted() {
|
||
|
Inputmask('datetime', {
|
||
|
inputFormat: 'HH:MM',
|
||
|
placeholder: 'HH:mm',
|
||
|
clearIncomplete: true,
|
||
|
showMaskOnHover: true,
|
||
|
hourFormat: 24
|
||
|
}).mask($('#' + this.selectorId));
|
||
|
|
||
|
$('#' + this.selectorId).next().click(() => {
|
||
|
var inputField = $('#' + this.selectorId);
|
||
|
var d = new Date();
|
||
|
var h = ('0' + d.getHours()).slice(-2);
|
||
|
var m = ('0' + d.getMinutes()).slice(-2);
|
||
|
var value= h + ':' + m
|
||
|
inputField.val(value);
|
||
|
this.value = value;
|
||
|
this.update();
|
||
|
});
|
||
|
},
|
||
|
methods: {
|
||
|
update() {
|
||
|
this.$emit('change', this.value);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
</script>
|