7658-devToTest_2428 #508

Merged
alexm merged 392 commits from 7658-devToTest_2428 into test 2024-07-02 10:38:20 +00:00
5 changed files with 21 additions and 23 deletions
Showing only changes of commit bea756d7cb - Show all commits

View File

@ -27,7 +27,6 @@ export default {
this.$el.addEventListener('keyup', function (evt) { this.$el.addEventListener('keyup', function (evt) {
if (evt.key === 'Enter') { if (evt.key === 'Enter') {
const input = evt.target; const input = evt.target;
console.log('input', input);
if (input.type == 'textarea' && evt.shiftKey) { if (input.type == 'textarea' && evt.shiftKey) {
evt.preventDefault(); evt.preventDefault();
let { selectionStart, selectionEnd } = input; let { selectionStart, selectionEnd } = input;

View File

@ -75,6 +75,7 @@ const originalData = ref();
const vnPaginateRef = ref(); const vnPaginateRef = ref();
const formData = ref(); const formData = ref();
const saveButtonRef = ref(null); const saveButtonRef = ref(null);
const watchChanges = ref();
const formUrl = computed(() => $props.url); const formUrl = computed(() => $props.url);
const emit = defineEmits(['onFetch', 'update:selected', 'saveChanges']); const emit = defineEmits(['onFetch', 'update:selected', 'saveChanges']);
@ -98,19 +99,26 @@ async function fetch(data) {
data.map((d) => (d.$index = $index++)); data.map((d) => (d.$index = $index++));
} }
originalData.value = data && JSON.parse(JSON.stringify(data)); resetData(data);
formData.value = data && JSON.parse(JSON.stringify(data));
watch(formData, () => (hasChanges.value = true), { deep: true });
emit('onFetch', data); emit('onFetch', data);
return 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() { async function reset() {
await fetch(originalData.value); await fetch(originalData.value);
hasChanges.value = false; hasChanges.value = false;
} }
// eslint-disable-next-line vue/no-dupe-keys
function filter(value, update, filterOptions) { function filter(value, update, filterOptions) {
update( update(
() => { () => {
@ -287,6 +295,7 @@ watch(formUrl, async () => {
:url="url" :url="url"
:limit="limit" :limit="limit"
@on-fetch="fetch" @on-fetch="fetch"
@on-change="resetData"
:skeleton="false" :skeleton="false"
ref="vnPaginateRef" ref="vnPaginateRef"
v-bind="$attrs" v-bind="$attrs"

View File

@ -100,12 +100,6 @@ watch(
{ immediate: true } { immediate: true }
); );
// try without
watch(
() => route.params.id,
() => reload(attrs)
);
watch( watch(
() => route.query[$props.searchUrl], () => route.query[$props.searchUrl],
(val) => setUserParams(val) (val) => setUserParams(val)
@ -226,6 +220,7 @@ defineExpose({
ref="CrudModelRef" ref="CrudModelRef"
:search-url="searchUrl" :search-url="searchUrl"
:disable-infinite-scroll="mode == 'table'" :disable-infinite-scroll="mode == 'table'"
@save-changes="reload"
> >
<template #body="{ rows }"> <template #body="{ rows }">
<QTable <QTable

View File

@ -68,7 +68,7 @@ const props = defineProps({
}, },
}); });
const emit = defineEmits(['onFetch', 'onPaginate']); const emit = defineEmits(['onFetch', 'onPaginate', 'onChange']);
const isLoading = ref(false); const isLoading = ref(false);
const pagination = ref({ const pagination = ref({
sortBy: props.order, sortBy: props.order,
@ -102,7 +102,12 @@ watch(
watch( watch(
() => store.data, () => store.data,
(data) => emit('onFetch', data) (data) => emit('onChange', data)
);
watch(
() => props.url,
(url) => fetch({ url })
); );
const addFilter = async (filter, params) => { const addFilter = async (filter, params) => {
@ -150,7 +155,6 @@ function endPagination() {
emit('onPaginate'); emit('onPaginate');
} }
async function onLoad(index, done) { async function onLoad(index, done) {
console.log('onLoad?');
if (!store.data) return done(); if (!store.data) return done();
if (store.data.length === 0 || !props.url) return done(false); if (store.data.length === 0 || !props.url) return done(false);

View File

@ -66,19 +66,10 @@ export function useArrayData(key = useRoute().meta.moduleName, userOptions) {
} }
} }
} }
console.log('setOptions store.url: ', store.url);
} }
async function fetch({ append = false, updateRouter = true }) { async function fetch({ append = false, updateRouter = true }) {
if (!store.url) return; if (!store.url) return;
console.log('store.url: ', store.url);
console.log('userOptions.url: ', userOptions.url);
console.log('route.params.id: ', route.params.id);
// const urlSplited = store.url.split('/');
// if (!isNaN(+urlSplited[1]) && urlSplited[1] != route.params.id) {
// urlSplited[1] = route.params.id;
// store.url = urlSplited.join('/');
// }
cancelRequest(); cancelRequest();
canceller = new AbortController(); canceller = new AbortController();