2
0
mirror of https://github.com/frappe/books.git synced 2025-01-05 08:02:15 +00:00

fix(ux): switch Date to use native input

This commit is contained in:
18alantom 2023-06-08 09:43:00 +05:30
parent 3d9dd9c02b
commit 3416327635
2 changed files with 133 additions and 5 deletions

View File

@ -20,7 +20,7 @@
<div
v-show="!showInput"
class="whitespace-nowrap overflow-x-auto no-scrollbar"
:class="[inputClasses, containerClasses, ,]"
:class="[inputClasses, containerClasses]"
@click="activateInput"
@focus="activateInput"
tabindex="0"

View File

@ -1,11 +1,139 @@
<template>
<div>
<div :class="labelClasses" v-if="showLabel">
{{ df.label }}
</div>
<input
v-show="showInput"
ref="input"
:class="[inputClasses, containerClasses]"
:type="inputType"
:value="inputValue"
:placeholder="inputPlaceholder"
:readonly="isReadOnly"
:tabindex="isReadOnly ? '-1' : '0'"
@blur="onBlur"
@focus="onFocus"
@input="(e) => $emit('input', e)"
/>
<div
v-show="!showInput"
class="flex"
:class="[containerClasses, sizeClasses]"
@click="activateInput"
@focus="activateInput"
tabindex="0"
>
<p
:class="[baseInputClasses]"
class="overflow-auto no-scrollbar whitespace-nowrap"
v-if="!isEmpty"
>
{{ formattedValue }}
</p>
<p v-else-if="inputPlaceholder" class="text-base text-gray-500 w-full">
{{ inputPlaceholder }}
</p>
<button v-if="!isReadOnly" class="-me-0.5 ms-1">
<FeatherIcon
name="calendar"
class="w-4 h-4"
:class="showMandatory ? 'text-red-600' : 'text-gray-600'"
/>
</button>
</div>
</div>
</template>
<script lang="ts">
import { defineComponent } from 'vue';
import Datetime from './Datetime.vue';
import { fyo } from 'src/initFyo';
import { defineComponent, nextTick } from 'vue';
import Base from './Base.vue';
export default defineComponent({
extends: Base,
emits: ['input', 'focus'],
data() {
return { selectTime: false };
return {
showInput: false,
};
},
methods: {
onFocus(e: FocusEvent) {
const target = e.target;
if (!(target instanceof HTMLInputElement)) {
return;
}
target.select();
this.showInput = true;
this.$emit('focus', e);
},
onBlur(e: FocusEvent) {
const target = e.target;
if (!(target instanceof HTMLInputElement)) {
return;
}
this.showInput = false;
let value: Date | null = new Date(target.value);
if (Number.isNaN(value.valueOf())) {
value = null;
}
this.triggerChange(value);
},
activateInput() {
if (this.isReadOnly) {
return;
}
this.showInput = true;
nextTick(() => {
this.focus();
// @ts-ignore
this.$refs.input.showPicker();
});
},
},
computed: {
inputValue(): string {
let value = this.value;
if (typeof value === 'string') {
value = new Date(value);
}
if (value instanceof Date && !Number.isNaN(value.valueOf())) {
return value.toISOString().split('T')[0];
}
return '';
},
inputType() {
return 'date';
},
formattedValue() {
const value = this.parse(this.value);
return fyo.format(value, this.df, this.doc);
},
borderClasses(): string {
if (!this.border) {
return '';
}
const border = 'border border-gray-200';
let background = 'bg-gray-25';
if (this.isReadOnly) {
background = 'bg-gray-50';
}
if (this.showInput) {
return background;
}
return border + ' ' + background;
},
},
extends: Datetime,
});
</script>