Browse Source

fix(gui-v2): on blur event reset editable value

Signed-off-by: Pranav C <pranavxc@gmail.com>
pull/3005/head
Pranav C 2 years ago
parent
commit
c4c2e477bd
  1. 10
      packages/nc-gui-v2/components/cell/Currency.vue
  2. 1
      packages/nc-gui-v2/components/cell/Decimal.vue
  3. 2
      packages/nc-gui-v2/components/cell/Email.vue
  4. 1
      packages/nc-gui-v2/components/cell/Float.vue
  5. 1
      packages/nc-gui-v2/components/cell/Integer.vue
  6. 2
      packages/nc-gui-v2/components/cell/Url.vue

10
packages/nc-gui-v2/components/cell/Currency.vue

@ -37,10 +37,18 @@ const currency = computed(() => {
return vModel.value return vModel.value
} }
}) })
const focus = (el: HTMLInputElement) => el?.focus()
</script> </script>
<template> <template>
<input v-if="editEnabled" ref="root" v-model="vModel" /> <input
v-if="editEnabled"
:ref="focus"
v-model="vModel"
class="w-full h-full border-none outline-none"
@blur="editEnabled = false"
/>
<span v-else-if="vModel">{{ currency }}</span> <span v-else-if="vModel">{{ currency }}</span>
<span v-else /> <span v-else />
</template> </template>

1
packages/nc-gui-v2/components/cell/Decimal.vue

@ -31,6 +31,7 @@ const focus = (el: HTMLInputElement) => el?.focus()
class="outline-none pa-0 border-none w-full h-full prose-sm" class="outline-none pa-0 border-none w-full h-full prose-sm"
type="number" type="number"
step="0.1" step="0.1"
@blur="editEnabled = false"
/> />
<span v-else class="prose-sm">{{ vModel }}</span> <span v-else class="prose-sm">{{ vModel }}</span>
</template> </template>

2
packages/nc-gui-v2/components/cell/Email.vue

@ -25,7 +25,7 @@ const focus = (el: HTMLInputElement) => el?.focus()
</script> </script>
<template> <template>
<input v-if="editEnabled" ref="root" v-model="vModel" class="outline-none prose-sm" /> <input v-if="editEnabled" ref="root" v-model="vModel" class="outline-none prose-sm" @blur="editEnabled = false" />
<a v-else-if="validEmail" class="prose-sm underline hover:opacity-75" :href="`mailto:${vModel}`" target="_blank"> <a v-else-if="validEmail" class="prose-sm underline hover:opacity-75" :href="`mailto:${vModel}`" target="_blank">
{{ vModel }} {{ vModel }}
</a> </a>

1
packages/nc-gui-v2/components/cell/Float.vue

@ -29,6 +29,7 @@ const focus = (el: HTMLInputElement) => el?.focus()
class="outline-none pa-0 border-none w-full h-full prose-sm" class="outline-none pa-0 border-none w-full h-full prose-sm"
type="number" type="number"
step="0.1" step="0.1"
@blur="editEnabled = false"
/> />
<span v-else class="prose-sm">{{ vModel }}</span> <span v-else class="prose-sm">{{ vModel }}</span>
</template> </template>

1
packages/nc-gui-v2/components/cell/Integer.vue

@ -32,6 +32,7 @@ function onKeyDown(evt: KeyboardEvent) {
v-model="vModel" v-model="vModel"
class="outline-none pa-0 border-none w-full h-full prose-sm" class="outline-none pa-0 border-none w-full h-full prose-sm"
type="number" type="number"
@blur="editEnabled = false"
@keydown="onKeyDown" @keydown="onKeyDown"
/> />
<span v-else class="prose-sm">{{ vModel }}</span> <span v-else class="prose-sm">{{ vModel }}</span>

2
packages/nc-gui-v2/components/cell/Url.vue

@ -30,7 +30,7 @@ const focus = (el: HTMLInputElement) => el?.focus()
</script> </script>
<template> <template>
<input v-if="editEnabled" :ref="focus" v-model="vModel" class="outline-none" /> <input v-if="editEnabled" :ref="focus" v-model="vModel" class="outline-none" @blur="editEnabled = false" />
<nuxt-link v-else-if="isValid" class="py-2 underline hover:opacity-75" :to="value" target="_blank">{{ value }}</nuxt-link> <nuxt-link v-else-if="isValid" class="py-2 underline hover:opacity-75" :to="value" target="_blank">{{ value }}</nuxt-link>
<span v-else>{{ value }}</span> <span v-else>{{ value }}</span>
</template> </template>

Loading…
Cancel
Save