Skip to content

Commit

Permalink
Merge pull request #195 from bcgov/bug/empty-form-autosaves
Browse files Browse the repository at this point in the history
Fixed autosave from triggering on empty forms
  • Loading branch information
kyle1morel authored Nov 18, 2024
2 parents 7fa264d + 37e97ba commit 03a9e93
Show file tree
Hide file tree
Showing 3 changed files with 61 additions and 26 deletions.
20 changes: 13 additions & 7 deletions frontend/src/components/file/AdvancedFileUpload.vue
Original file line number Diff line number Diff line change
Expand Up @@ -15,19 +15,22 @@ const {
activityId = undefined,
accept = undefined,
disabled = false,
reject = undefined
reject = undefined,
generateActivityId
} = defineProps<{
activityId?: string;
accept?: string[];
reject?: string[];
disabled?: boolean;
generateActivityId: () => Promise<string | undefined>;
}>();
// Store
const { getConfig } = storeToRefs(useConfigStore());
const submissionStore = useSubmissionStore();
// State
// const curActivityId: Ref<string | undefined> = ref(undefined);
const fileInput: Ref<any> = ref(null);
const uploading: Ref<Boolean> = ref(false);
Expand All @@ -54,13 +57,16 @@ const onFileUploadDragAndDrop = (event: FileUploadUploaderEvent) => {
const onUpload = async (files: Array<File>) => {
uploading.value = true;
let currentActivityId: string | undefined = activityId;
currentActivityId = activityId ? activityId : await generateActivityId();
await Promise.allSettled(
files.map((file: File) => {
return new Promise((resolve, reject) => {
if (activityId) {
if (currentActivityId) {
documentService
.createDocument(file, activityId, getConfig.value.coms.bucketId)
.createDocument(file, currentActivityId, getConfig.value.coms.bucketId)
.then((response) => {
if (response?.data) {
submissionStore.addDocument(response.data);
Expand All @@ -80,10 +86,10 @@ const onUpload = async (files: Array<File>) => {
uploading.value = false;
};
// filter documents based on accept and reject props
// if accept and reject are not provided, all documents are shown
// if accept is provided, only documents with extensions in accept are shown
// if reject is provided, only documents with extensions not in reject are shown
// Filter documents based on accept and reject props
// If accept and reject are not provided, all documents are shown
// If accept is provided, only documents with extensions in accept are shown
// If reject is provided, only documents with extensions not in reject are shown
const filteredDocuments = computed(() => {
let documents = submissionStore.getDocuments;
return documents.filter(
Expand Down
12 changes: 11 additions & 1 deletion frontend/src/components/form/internal/InputMaskInternal.vue
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
<script setup lang="ts">
import { computed } from 'vue';
import { useField } from 'vee-validate';
import { InputMask } from '@/lib/primevue';
Expand All @@ -14,6 +15,15 @@ const { label, name, mask, placeholder, disabled, bold } = defineProps<{
}>();
const { errorMessage, value } = useField<string>(name);
const normalizedValue = computed({
get: () => {
return value.value === '' ? undefined : value.value;
},
set: (val) => {
value.value = val === '' || val === undefined ? (undefined as unknown as string) : val;
}
});
</script>

<template>
Expand All @@ -25,7 +35,7 @@ const { errorMessage, value } = useField<string>(name);
{{ label }}
</label>
<InputMask
v-model="value"
v-model="normalizedValue"
:aria-describedby="`${name}-help`"
:aria-labelledby="`${name}-label`"
:name="name"
Expand Down
55 changes: 37 additions & 18 deletions frontend/src/components/housing/submission/SubmissionIntakeForm.vue
Original file line number Diff line number Diff line change
Expand Up @@ -107,10 +107,10 @@ const editable: Ref<boolean> = ref(true);
const formRef: Ref<InstanceType<typeof Form> | null> = ref(null);
const geomarkAccordionIndex: Ref<number | undefined> = ref(undefined);
const initialFormValues: Ref<any | undefined> = ref(undefined);
const isSubmittable: Ref<boolean> = ref(false);
const mapLatitude: Ref<number | undefined> = ref(undefined);
const mapLongitude: Ref<number | undefined> = ref(undefined);
const mapRef: Ref<InstanceType<typeof Map> | null> = ref(null);
const isSubmittable: Ref<boolean> = ref(false);
const orgBookOptions: Ref<Array<any>> = ref([]);
const parcelAccordionIndex: Ref<number | undefined> = ref(undefined);
const validationErrors = computed(() => {
Expand Down Expand Up @@ -151,6 +151,21 @@ function confirmSubmit(data: any) {
});
}
async function generateActivityId() {
try {
const response = await submissionService.updateDraft({});
if (response.data?.activityId && response.data?.submissionId) {
syncFormAndRoute(response.data.activityId, response.data.submissionId);
return response.data.activityId;
} else {
return undefined;
}
} catch (error) {
toast.error('Failed to generate activity ID');
return undefined;
}
}
const getAddressSearchLabel = (e: GeocoderEntry) => {
return e?.properties?.fullAddress;
};
Expand Down Expand Up @@ -302,17 +317,7 @@ async function onSaveDraft(
response = await submissionService.updateDraft(draftData);
if (response.data.activityId && response.data.submissionId) {
formRef.value?.setFieldValue('activityId', response.data.activityId);
formRef.value?.setFieldValue('submissionId', response.data.submissionId);
// Update route query for refreshing
router.replace({
name: RouteName.HOUSING_SUBMISSION_INTAKE,
query: {
activityId: response.data.activityId,
submissionId: response.data.submissionId
}
});
syncFormAndRoute(response.data.activityId, response.data.submissionId);
} else {
throw new Error('Failed to retrieve correct draft data');
}
Expand All @@ -336,12 +341,6 @@ function onStepChange(stepNumber: number) {
// Map component misaligned if mounted while not visible. Trigger resize to fix on show
if (stepNumber === 2) nextTick().then(() => mapRef?.value?.resizeMap());
if (stepNumber === 3) isSubmittable.value = true;
// Save a draft on very first stepper navigation if no activityId yet
// Need this to generate an activityId for the file uploads
if (!formRef.value?.values.activityId) {
onSaveDraft(formRef.value?.values, true, false);
}
}
async function onSubmit(data: any) {
Expand Down Expand Up @@ -404,6 +403,25 @@ async function onRegisteredNameInput(e: AutoCompleteCompleteEvent) {
}
}
function syncFormAndRoute(activityId: string, submissionId: string) {
formRef.value?.resetForm({
values: {
...formRef.value?.values,
activityId: activityId,
submissionId: submissionId
}
});
// Update route query for refreshing
router.replace({
name: RouteName.HOUSING_SUBMISSION_INTAKE,
query: {
activityId: activityId,
submissionId: submissionId
}
});
}
onBeforeMount(async () => {
try {
let response,
Expand Down Expand Up @@ -787,6 +805,7 @@ onBeforeMount(async () => {
<AdvancedFileUpload
:activity-id="values.activityId"
:disabled="!editable"
:generate-activity-id="generateActivityId"
/>
</div>
</template>
Expand Down

0 comments on commit 03a9e93

Please sign in to comment.