diff --git a/src/boot/qformMixin.js b/src/boot/qformMixin.js index a809140b0..0bf1f9795 100644 --- a/src/boot/qformMixin.js +++ b/src/boot/qformMixin.js @@ -27,7 +27,6 @@ export default { this.$el.addEventListener('keyup', function (evt) { if (evt.key === 'Enter') { const input = evt.target; - console.log('input', input); if (input.type == 'textarea' && evt.shiftKey) { evt.preventDefault(); let { selectionStart, selectionEnd } = input; diff --git a/src/components/CrudModel.vue b/src/components/CrudModel.vue index e58d342ce..8d0935288 100644 --- a/src/components/CrudModel.vue +++ b/src/components/CrudModel.vue @@ -75,6 +75,7 @@ const originalData = ref(); const vnPaginateRef = ref(); const formData = ref(); const saveButtonRef = ref(null); +const watchChanges = ref(); const formUrl = computed(() => $props.url); const emit = defineEmits(['onFetch', 'update:selected', 'saveChanges']); @@ -98,19 +99,26 @@ async function fetch(data) { data.map((d) => (d.$index = $index++)); } - originalData.value = data && JSON.parse(JSON.stringify(data)); - formData.value = data && JSON.parse(JSON.stringify(data)); - watch(formData, () => (hasChanges.value = true), { deep: true }); + resetData(data); emit('onFetch', data); return data; } +function resetData(data) { + if (!data) return; + originalData.value = JSON.parse(JSON.stringify(data)); + formData.value = JSON.parse(JSON.stringify(data)); + + if (watchChanges.value) watchChanges.value(); //destoy watcher + watchChanges.value = watch(formData, () => (hasChanges.value = true), { deep: true }); +} + async function reset() { await fetch(originalData.value); hasChanges.value = false; } -// eslint-disable-next-line vue/no-dupe-keys + function filter(value, update, filterOptions) { update( () => { @@ -287,6 +295,7 @@ watch(formUrl, async () => { :url="url" :limit="limit" @on-fetch="fetch" + @on-change="resetData" :skeleton="false" ref="vnPaginateRef" v-bind="$attrs" diff --git a/src/components/VnTable/VnTable.vue b/src/components/VnTable/VnTable.vue index bcca17cab..2aefc20fb 100644 --- a/src/components/VnTable/VnTable.vue +++ b/src/components/VnTable/VnTable.vue @@ -100,12 +100,6 @@ watch( { immediate: true } ); -// try without -watch( - () => route.params.id, - () => reload(attrs) -); - watch( () => route.query[$props.searchUrl], (val) => setUserParams(val) @@ -226,6 +220,7 @@ defineExpose({ ref="CrudModelRef" :search-url="searchUrl" :disable-infinite-scroll="mode == 'table'" + @save-changes="reload" >