Migrated calendar to new v-model and $attrs api
parent
d3dca3e042
commit
9b06b72e26
|
@ -1,6 +1,6 @@
|
||||||
<template>
|
<template>
|
||||||
<span :class="containerClass">
|
<span :class="containerClass" :style="style">
|
||||||
<CalendarInputText ref="input" v-if="!inline" type="text" v-bind="$attrs" v-on="listeners" :value="inputFieldValue" :readonly="!manualInput" :aria-labelledby="ariaLabelledBy" inputmode="none" />
|
<CalendarInputText ref="input" v-if="!inline" type="text" v-bind="$attrs" :value="inputFieldValue" @input="onInput" @focus="onFocus" @blur="onBlur" @keydown="onKeyDown" :readonly="!manualInput" :aria-labelledby="ariaLabelledBy" inputmode="none" />
|
||||||
<CalendarButton v-if="showIcon" :icon="icon" tabindex="-1" class="p-datepicker-trigger" :disabled="$attrs.disabled" @click="onButtonClick" type="button" :aria-label="inputFieldValue"/>
|
<CalendarButton v-if="showIcon" :icon="icon" tabindex="-1" class="p-datepicker-trigger" :disabled="$attrs.disabled" @click="onButtonClick" type="button" :aria-label="inputFieldValue"/>
|
||||||
<transition name="p-connected-overlay" @enter="onOverlayEnter" @after-enter="onOverlayEnterComplete" @leave="onOverlayLeave">
|
<transition name="p-connected-overlay" @enter="onOverlayEnter" @after-enter="onOverlayEnterComplete" @leave="onOverlayLeave">
|
||||||
<div ref="overlay" :class="panelStyleClass" v-if="inline ? true : overlayVisible" :role="inline ? null : 'dialog'" :aria-labelledby="ariaLabelledBy">
|
<div ref="overlay" :class="panelStyleClass" v-if="inline ? true : overlayVisible" :role="inline ? null : 'dialog'" :aria-labelledby="ariaLabelledBy">
|
||||||
|
@ -138,7 +138,7 @@ import Ripple from '../ripple/Ripple';
|
||||||
export default {
|
export default {
|
||||||
inheritAttrs: false,
|
inheritAttrs: false,
|
||||||
props: {
|
props: {
|
||||||
value: null,
|
modelValue: null,
|
||||||
selectionMode: {
|
selectionMode: {
|
||||||
type: String,
|
type: String,
|
||||||
default: 'single'
|
default: 'single'
|
||||||
|
@ -307,7 +307,9 @@ export default {
|
||||||
appendTo: {
|
appendTo: {
|
||||||
type: String,
|
type: String,
|
||||||
default: null
|
default: null
|
||||||
}
|
},
|
||||||
|
class: null,
|
||||||
|
style: null
|
||||||
},
|
},
|
||||||
navigationState: null,
|
navigationState: null,
|
||||||
created() {
|
created() {
|
||||||
|
@ -367,20 +369,20 @@ export default {
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
isComparable() {
|
isComparable() {
|
||||||
return this.value != null && typeof this.value !== 'string';
|
return this.modelValue != null && typeof this.modelValue !== 'string';
|
||||||
},
|
},
|
||||||
isSelected(dateMeta) {
|
isSelected(dateMeta) {
|
||||||
if (!this.isComparable()) {
|
if (!this.isComparable()) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.value) {
|
if (this.modelValue) {
|
||||||
if (this.isSingleSelection()) {
|
if (this.isSingleSelection()) {
|
||||||
return this.isDateEquals(this.value, dateMeta);
|
return this.isDateEquals(this.modelValue, dateMeta);
|
||||||
}
|
}
|
||||||
else if (this.isMultipleSelection()) {
|
else if (this.isMultipleSelection()) {
|
||||||
let selected = false;
|
let selected = false;
|
||||||
for (let date of this.value) {
|
for (let date of this.modelValue) {
|
||||||
selected = this.isDateEquals(date, dateMeta);
|
selected = this.isDateEquals(date, dateMeta);
|
||||||
if (selected) {
|
if (selected) {
|
||||||
break;
|
break;
|
||||||
|
@ -390,10 +392,10 @@ export default {
|
||||||
return selected;
|
return selected;
|
||||||
}
|
}
|
||||||
else if( this.isRangeSelection()) {
|
else if( this.isRangeSelection()) {
|
||||||
if (this.value[1])
|
if (this.modelValue[1])
|
||||||
return this.isDateEquals(this.value[0], dateMeta) || this.isDateEquals(this.value[1], dateMeta) || this.isDateBetween(this.value[0], this.value[1], dateMeta);
|
return this.isDateEquals(this.modelValue[0], dateMeta) || this.isDateEquals(this.modelValue[1], dateMeta) || this.isDateBetween(this.modelValue[0], this.modelValue[1], dateMeta);
|
||||||
else {
|
else {
|
||||||
return this.isDateEquals(this.value[0], dateMeta);
|
return this.isDateEquals(this.modelValue[0], dateMeta);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -402,7 +404,7 @@ export default {
|
||||||
return false;
|
return false;
|
||||||
},
|
},
|
||||||
isMonthSelected(month) {
|
isMonthSelected(month) {
|
||||||
return this.isComparable() ? (this.value.getMonth() === month && this.value.getFullYear() === this.currentYear) : false;
|
return this.isComparable() ? (this.modelValue.getMonth() === month && this.modelValue.getFullYear() === this.currentYear) : false;
|
||||||
},
|
},
|
||||||
isDateEquals(value, dateMeta) {
|
isDateEquals(value, dateMeta) {
|
||||||
if (value)
|
if (value)
|
||||||
|
@ -706,7 +708,7 @@ export default {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.isMultipleSelection() && this.isSelected(dateMeta)) {
|
if (this.isMultipleSelection() && this.isSelected(dateMeta)) {
|
||||||
let newValue = this.value.filter(date => !this.isDateEquals(date, dateMeta));
|
let newValue = this.modelValue.filter(date => !this.isDateEquals(date, dateMeta));
|
||||||
this.updateModel(newValue);
|
this.updateModel(newValue);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
@ -765,12 +767,12 @@ export default {
|
||||||
modelVal = date;
|
modelVal = date;
|
||||||
}
|
}
|
||||||
else if (this.isMultipleSelection()) {
|
else if (this.isMultipleSelection()) {
|
||||||
modelVal = this.value ? [...this.value, date] : [date];
|
modelVal = this.modelValue ? [...this.modelValue, date] : [date];
|
||||||
}
|
}
|
||||||
else if (this.isRangeSelection()) {
|
else if (this.isRangeSelection()) {
|
||||||
if (this.value && this.value.length) {
|
if (this.modelValue && this.modelValue.length) {
|
||||||
let startDate = this.value[0];
|
let startDate = this.modelValue[0];
|
||||||
let endDate = this.value[1];
|
let endDate = this.modelValue[1];
|
||||||
|
|
||||||
if (!endDate && date.getTime() >= startDate.getTime()) {
|
if (!endDate && date.getTime() >= startDate.getTime()) {
|
||||||
endDate = date;
|
endDate = date;
|
||||||
|
@ -792,11 +794,11 @@ export default {
|
||||||
this.$emit('date-select', date);
|
this.$emit('date-select', date);
|
||||||
},
|
},
|
||||||
updateModel(value) {
|
updateModel(value) {
|
||||||
this.$emit('input', value);
|
this.$emit('update:modelValue', value);
|
||||||
},
|
},
|
||||||
shouldSelectDate() {
|
shouldSelectDate() {
|
||||||
if (this.isMultipleSelection())
|
if (this.isMultipleSelection())
|
||||||
return this.maxDateCount != null ? this.maxDateCount > (this.value ? this.value.length : 0) : true;
|
return this.maxDateCount != null ? this.maxDateCount > (this.modelValue ? this.modelValue.length : 0) : true;
|
||||||
else
|
else
|
||||||
return true;
|
return true;
|
||||||
},
|
},
|
||||||
|
@ -1083,16 +1085,16 @@ export default {
|
||||||
},
|
},
|
||||||
validateHour(hour) {
|
validateHour(hour) {
|
||||||
let valid = true;
|
let valid = true;
|
||||||
let value = this.value;
|
let value = this.modelValue;
|
||||||
if (!this.isComparable()) {
|
if (!this.isComparable()) {
|
||||||
return valid;
|
return valid;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.isRangeSelection()) {
|
if (this.isRangeSelection()) {
|
||||||
value = this.value[1] || this.value[0];
|
value = this.modelValue[1] || this.modelValue[0];
|
||||||
}
|
}
|
||||||
if (this.isMultipleSelection()) {
|
if (this.isMultipleSelection()) {
|
||||||
value = this.value[this.value.length - 1];
|
value = this.modelValue[this.modelValue.length - 1];
|
||||||
}
|
}
|
||||||
let valueDateString = value ? value.toDateString() : null;
|
let valueDateString = value ? value.toDateString() : null;
|
||||||
|
|
||||||
|
@ -1129,16 +1131,16 @@ export default {
|
||||||
},
|
},
|
||||||
validateMinute(minute) {
|
validateMinute(minute) {
|
||||||
let valid = true;
|
let valid = true;
|
||||||
let value = this.value;
|
let value = this.modelValue;
|
||||||
if (!this.isComparable()) {
|
if (!this.isComparable()) {
|
||||||
return valid;
|
return valid;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.isRangeSelection()) {
|
if (this.isRangeSelection()) {
|
||||||
value = this.value[1] || this.value[0];
|
value = this.modelValue[1] || this.modelValue[0];
|
||||||
}
|
}
|
||||||
if (this.isMultipleSelection()) {
|
if (this.isMultipleSelection()) {
|
||||||
value = this.value[this.value.length - 1];
|
value = this.modelValue[this.modelValue.length - 1];
|
||||||
}
|
}
|
||||||
let valueDateString = value ? value.toDateString() : null;
|
let valueDateString = value ? value.toDateString() : null;
|
||||||
if (this.minDate && valueDateString && this.minDate.toDateString() === valueDateString) {
|
if (this.minDate && valueDateString && this.minDate.toDateString() === valueDateString) {
|
||||||
|
@ -1178,16 +1180,16 @@ export default {
|
||||||
},
|
},
|
||||||
validateSecond(second) {
|
validateSecond(second) {
|
||||||
let valid = true;
|
let valid = true;
|
||||||
let value = this.value;
|
let value = this.modelValue;
|
||||||
if (!this.isComparable()) {
|
if (!this.isComparable()) {
|
||||||
return valid;
|
return valid;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.isRangeSelection()) {
|
if (this.isRangeSelection()) {
|
||||||
value = this.value[1] || this.value[0];
|
value = this.modelValue[1] || this.modelValue[0];
|
||||||
}
|
}
|
||||||
if (this.isMultipleSelection()) {
|
if (this.isMultipleSelection()) {
|
||||||
value = this.value[this.value.length - 1];
|
value = this.modelValue[this.modelValue.length - 1];
|
||||||
}
|
}
|
||||||
let valueDateString = value ? value.toDateString() : null;
|
let valueDateString = value ? value.toDateString() : null;
|
||||||
|
|
||||||
|
@ -1206,13 +1208,13 @@ export default {
|
||||||
return valid;
|
return valid;
|
||||||
},
|
},
|
||||||
updateModelTime() {
|
updateModelTime() {
|
||||||
let value = this.isComparable() ? this.value : new Date();
|
let value = this.isComparable() ? this.modelValue : new Date();
|
||||||
|
|
||||||
if (this.isRangeSelection()) {
|
if (this.isRangeSelection()) {
|
||||||
value = this.value[1] || this.value[0];
|
value = this.modelValue[1] || this.modelValue[0];
|
||||||
}
|
}
|
||||||
if (this.isMultipleSelection()) {
|
if (this.isMultipleSelection()) {
|
||||||
value = this.value[this.value.length - 1];
|
value = this.modelValue[this.modelValue.length - 1];
|
||||||
}
|
}
|
||||||
value = value ? new Date(value.getTime()) : new Date();
|
value = value ? new Date(value.getTime()) : new Date();
|
||||||
|
|
||||||
|
@ -1230,14 +1232,14 @@ export default {
|
||||||
value.setSeconds(this.currentSecond);
|
value.setSeconds(this.currentSecond);
|
||||||
|
|
||||||
if (this.isRangeSelection()) {
|
if (this.isRangeSelection()) {
|
||||||
if (this.value[1])
|
if (this.modelValue[1])
|
||||||
value = [this.value[0], value];
|
value = [this.modelValue[0], value];
|
||||||
else
|
else
|
||||||
value = [value, null];
|
value = [value, null];
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.isMultipleSelection()){
|
if (this.isMultipleSelection()){
|
||||||
value = [...this.value.slice(0, -1), value];
|
value = [...this.modelValue.slice(0, -1), value];
|
||||||
}
|
}
|
||||||
|
|
||||||
this.updateModel(value);
|
this.updateModel(value);
|
||||||
|
@ -1893,7 +1895,7 @@ export default {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
onInput(val) {
|
onInput(event) {
|
||||||
// IE 11 Workaround for input placeholder : https://github.com/primefaces/primeng/issues/2026
|
// IE 11 Workaround for input placeholder : https://github.com/primefaces/primeng/issues/2026
|
||||||
if (!this.isKeydown) {
|
if (!this.isKeydown) {
|
||||||
return;
|
return;
|
||||||
|
@ -1904,13 +1906,13 @@ export default {
|
||||||
this.selectionStart = this.$refs.input.$el.selectionStart;
|
this.selectionStart = this.$refs.input.$el.selectionStart;
|
||||||
this.selectionEnd = this.$refs.input.$el.selectionEnd;
|
this.selectionEnd = this.$refs.input.$el.selectionEnd;
|
||||||
|
|
||||||
let value = this.parseValue(val);
|
let value = this.parseValue(event.target.value);
|
||||||
if (this.isValidSelection(value)) {
|
if (this.isValidSelection(value)) {
|
||||||
this.updateModel(value);
|
this.updateModel(value);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch(err) {
|
catch(err) {
|
||||||
this.updateModel(val);
|
this.updateModel(event.target.value);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
appendContainer() {
|
appendContainer() {
|
||||||
|
@ -1928,63 +1930,48 @@ export default {
|
||||||
else
|
else
|
||||||
document.getElementById(this.appendTo).removeChild(this.$refs.overlay);
|
document.getElementById(this.appendTo).removeChild(this.$refs.overlay);
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
onFocus() {
|
||||||
|
if (this.showOnFocus && this.isEnabled()) {
|
||||||
|
this.overlayVisible = true;
|
||||||
|
}
|
||||||
|
this.focused = true;
|
||||||
|
},
|
||||||
|
onBlur() {
|
||||||
|
this.focused = false;
|
||||||
|
},
|
||||||
|
onKeyDown(event) {
|
||||||
|
this.isKeydown = true;
|
||||||
|
|
||||||
|
switch (event.which) {
|
||||||
|
//escape
|
||||||
|
case 27: {
|
||||||
|
this.overlayVisible = false;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
//tab
|
||||||
|
case 9: {
|
||||||
|
if (this.touchUI) {
|
||||||
|
this.disableModality();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (event.shiftKey) {
|
||||||
|
this.overlayVisible = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
default:
|
||||||
|
//no op
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
listeners() {
|
|
||||||
let $vm = this;
|
|
||||||
|
|
||||||
return {
|
|
||||||
...$vm.$listeners,
|
|
||||||
input: val => {
|
|
||||||
this.onInput(val);
|
|
||||||
},
|
|
||||||
focus: event => {
|
|
||||||
$vm.focus = true;
|
|
||||||
if ($vm.showOnFocus && $vm.isEnabled()) {
|
|
||||||
$vm.overlayVisible = true;
|
|
||||||
}
|
|
||||||
$vm.focused = true;
|
|
||||||
$vm.$emit('focus', event)
|
|
||||||
},
|
|
||||||
blur: event => {
|
|
||||||
$vm.focused = false;
|
|
||||||
$vm.$emit('blur', event);
|
|
||||||
},
|
|
||||||
keydown: event => {
|
|
||||||
$vm.isKeydown = true;
|
|
||||||
|
|
||||||
switch (event.which) {
|
|
||||||
//escape
|
|
||||||
case 27: {
|
|
||||||
$vm.overlayVisible = false;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
//tab
|
|
||||||
case 9: {
|
|
||||||
if ($vm.touchUI) {
|
|
||||||
$vm.disableModality();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (event.shiftKey) {
|
|
||||||
$vm.overlayVisible = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
default:
|
|
||||||
//no op
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
$vm.$emit('keydown', event);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
},
|
|
||||||
viewDate() {
|
viewDate() {
|
||||||
let propValue = this.value;
|
let propValue = this.modelValue;
|
||||||
if (typeof propValue === 'string') {
|
if (typeof propValue === 'string') {
|
||||||
return new Date();
|
return new Date();
|
||||||
}
|
}
|
||||||
|
@ -1996,15 +1983,15 @@ export default {
|
||||||
return propValue || new Date();
|
return propValue || new Date();
|
||||||
},
|
},
|
||||||
inputFieldValue() {
|
inputFieldValue() {
|
||||||
return this.formatValue(this.value);
|
return this.formatValue(this.modelValue);
|
||||||
},
|
},
|
||||||
containerClass() {
|
containerClass() {
|
||||||
return [
|
return [
|
||||||
'p-calendar p-component p-inputwrapper',
|
'p-calendar p-component p-inputwrapper', this.class,
|
||||||
{
|
{
|
||||||
'p-calendar-w-btn': this.showIcon,
|
'p-calendar-w-btn': this.showIcon,
|
||||||
'p-calendar-timeonly': this.timeOnly,
|
'p-calendar-timeonly': this.timeOnly,
|
||||||
'p-inputwrapper-filled': this.value,
|
'p-inputwrapper-filled': this.modelValue,
|
||||||
'p-inputwrapper-focus': this.focused
|
'p-inputwrapper-focus': this.focused
|
||||||
}
|
}
|
||||||
];
|
];
|
||||||
|
|
Loading…
Reference in New Issue