diff --git a/src/App.vue b/src/App.vue index 8eae0d1a6..f381d2576 100644 --- a/src/App.vue +++ b/src/App.vue @@ -61,7 +61,7 @@ function responseError(error) { router.push({ path: '/login' }); } - return Promise.resolve(error); + return Promise.reject(error); } axios.interceptors.response.use((response) => { diff --git a/src/components/FetchData.vue b/src/components/FetchData.vue index 3da3a8e5f..0eee59f90 100644 --- a/src/components/FetchData.vue +++ b/src/components/FetchData.vue @@ -15,13 +15,10 @@ const $props = defineProps({ type: Object, default: null, }, - limit: { - type: String, - default: '20', - }, }); -const emit = defineEmits(['fetch-data']); +defineExpose({ fetch }); +const emit = defineEmits(['onFetch']); onMounted(async () => { if ($props.autoLoad) { @@ -34,7 +31,7 @@ async function fetch() { params: { filter: $props.filter }, }); - return emit('fetch-data', data); + emit('onFetch', data); } const render = () => { diff --git a/src/components/FormModel.vue b/src/components/FormModel.vue index ebb8f57cf..d36f8c4ea 100644 --- a/src/components/FormModel.vue +++ b/src/components/FormModel.vue @@ -5,11 +5,13 @@ import { useQuasar } from 'quasar'; import axios from 'axios'; import { useState } from 'src/composables/useState'; +import { useValidator } from 'src/composables/useValidator'; import SkeletonForm from 'src/components/SkeletonForm.vue'; const quasar = useQuasar(); const { t } = useI18n(); const state = useState(); +const { validate } = useValidator(); const $props = defineProps({ url: { @@ -26,7 +28,7 @@ const $props = defineProps({ }, }); -const emit = defineEmits(['fetch-data']); +const emit = defineEmits(['onFetch']); defineExpose({ save, @@ -53,7 +55,7 @@ async function fetch() { watch(formData.value, () => (hasChanges.value = true)); - return emit('fetch-data', state.get($props.model)); + emit('onFetch', state.get($props.model)); } async function save() { @@ -64,10 +66,10 @@ async function save() { }); } isLoading.value = true; - await new Promise((resolve) => { - setTimeout(resolve, 5000); - }); await axios.patch($props.url, formData.value); + + originalData.value = formData.value; + hasChanges.value = false; isLoading.value = false; } @@ -75,22 +77,41 @@ function reset() { state.set($props.model, originalData.value); hasChanges.value = false; } + +function filter(value, update, filterOptions) { + update( + () => { + const { options, filterFn } = filterOptions; + + options.value = filterFn(options, value); + }, + (ref) => { + ref.setOptionIndex(-1); + ref.moveOptionSelection(1, true); + } + ); +}