Link up data to final page.
This commit is contained in:
parent
5b5a63114c
commit
dbc5db9727
5 changed files with 256 additions and 141 deletions
|
|
@ -46,6 +46,7 @@
|
|||
id="contact-name"
|
||||
name="name"
|
||||
placeholder="Enter your name"
|
||||
v-model="contact.name"
|
||||
/>
|
||||
</div>
|
||||
|
||||
|
|
@ -61,6 +62,7 @@
|
|||
id="contact-phone"
|
||||
name="phone"
|
||||
placeholder="(555) 123-4567"
|
||||
v-model="contact.phone"
|
||||
/>
|
||||
</div>
|
||||
|
||||
|
|
@ -71,8 +73,7 @@
|
|||
class="form-check-input"
|
||||
type="checkbox"
|
||||
id="can-text"
|
||||
name="can_text"
|
||||
value="yes"
|
||||
v-model="contact.can_text"
|
||||
/>
|
||||
<label class="form-check-label" for="can-text">
|
||||
You may send text messages to this number
|
||||
|
|
@ -93,8 +94,8 @@
|
|||
type="email"
|
||||
class="form-control"
|
||||
id="contact-email"
|
||||
name="email"
|
||||
placeholder="your.email@example.com"
|
||||
v-model="contact.email"
|
||||
/>
|
||||
<div class="form-text">
|
||||
We'll send you a confirmation and any updates about this request
|
||||
|
|
@ -114,20 +115,44 @@
|
|||
<RouterLink class="btn btn-outline-secondary" to="./permission">
|
||||
Back
|
||||
</RouterLink>
|
||||
<RouterLink class="btn btn-primary flex-grow-1" to="process">
|
||||
<button class="btn btn-primary flex-grow-1" @click="doContinue()">
|
||||
Continue
|
||||
</RouterLink>
|
||||
</button>
|
||||
</div>
|
||||
</form>
|
||||
</main>
|
||||
</div>
|
||||
</template>
|
||||
<script setup lang="ts">
|
||||
import { ref } from "vue";
|
||||
|
||||
import { router } from "@/rmo/router";
|
||||
import type { District } from "@/type/api";
|
||||
import HeaderCompliance from "@/rmo/components/HeaderCompliance.vue";
|
||||
import ProgressBarCompliance from "@/rmo/components/ProgressBarCompliance.vue";
|
||||
|
||||
export interface Contact {
|
||||
name: string;
|
||||
phone: string;
|
||||
can_text: boolean;
|
||||
email: string;
|
||||
}
|
||||
interface Emits {
|
||||
(e: "doContact", contact: Contact): void;
|
||||
}
|
||||
interface Props {
|
||||
district: District;
|
||||
}
|
||||
const emit = defineEmits<Emits>();
|
||||
const props = defineProps<Props>();
|
||||
const contact = ref<Contact>({
|
||||
name: "",
|
||||
phone: "",
|
||||
can_text: true,
|
||||
email: "",
|
||||
});
|
||||
function doContinue() {
|
||||
emit("doContact", contact.value);
|
||||
router.push("./process");
|
||||
}
|
||||
</script>
|
||||
|
|
|
|||
|
|
@ -83,8 +83,8 @@
|
|||
<input
|
||||
type="radio"
|
||||
id="access-allowed"
|
||||
:value="Permission.GRANTED"
|
||||
v-model="selectedPermission"
|
||||
:value="PermissionAccess.GRANTED"
|
||||
v-model="permission.access"
|
||||
class="mt-1"
|
||||
/>
|
||||
<label for="access-allowed">
|
||||
|
|
@ -99,7 +99,7 @@
|
|||
<!-- Conditional fields for Option 1 -->
|
||||
<div
|
||||
v-if="
|
||||
selectedPermission && selectedPermission == Permission.GRANTED
|
||||
permission.access && permission.access == PermissionAccess.GRANTED
|
||||
"
|
||||
class="conditional-section"
|
||||
>
|
||||
|
|
@ -112,8 +112,9 @@
|
|||
class="form-control"
|
||||
id="access-instructions"
|
||||
name="access_instructions"
|
||||
rows="3"
|
||||
placeholder="Example: Side gate on left, backyard near shed..."
|
||||
rows="3"
|
||||
v-model="permission.access_instructions"
|
||||
></textarea>
|
||||
</div>
|
||||
|
||||
|
|
@ -123,42 +124,31 @@
|
|||
<span class="text-muted">(Optional)</span>
|
||||
</label>
|
||||
<input
|
||||
type="text"
|
||||
class="form-control"
|
||||
id="gate-code"
|
||||
name="gate_code"
|
||||
placeholder="Enter code if applicable"
|
||||
type="text"
|
||||
v-model="permission.gate_code"
|
||||
/>
|
||||
</div>
|
||||
|
||||
<div class="mb-3">
|
||||
<label class="form-label">Dog on Property?</label>
|
||||
<div class="form-check">
|
||||
<input
|
||||
class="form-check-input"
|
||||
type="radio"
|
||||
type="checkbox"
|
||||
name="has_dog"
|
||||
id="dog-no"
|
||||
value="no"
|
||||
checked
|
||||
onchange="toggleDogWarning()"
|
||||
id="has_dog"
|
||||
v-model="permission.has_dog"
|
||||
/>
|
||||
<label class="form-check-label" for="dog-no"> No </label>
|
||||
</div>
|
||||
<div class="form-check">
|
||||
<input
|
||||
class="form-check-input"
|
||||
id="dog-yes"
|
||||
type="radio"
|
||||
name="has_dog"
|
||||
v-model="hasDog"
|
||||
onchange="toggleDogWarning()"
|
||||
/>
|
||||
<label class="form-check-label" for="dog-yes"> Yes </label>
|
||||
<label class="form-check-label" for="has_dog"
|
||||
>Dog on Property?</label
|
||||
>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="dog-warning" v-if="hasDog">
|
||||
<div class="dog-warning" v-if="permission.has_dog">
|
||||
<small>
|
||||
<i class="bi bi-exclamation-triangle"></i>
|
||||
<strong>Important:</strong> Our staff will only enter if the dog
|
||||
|
|
@ -174,8 +164,8 @@
|
|||
<input
|
||||
type="radio"
|
||||
id="access-with-owner"
|
||||
:value="Permission.WITH_OWNER"
|
||||
v-model="selectedPermission"
|
||||
:value="PermissionAccess.WITH_OWNER"
|
||||
v-model="permission.access"
|
||||
class="mt-1"
|
||||
/>
|
||||
<label for="access-with-owner">
|
||||
|
|
@ -191,30 +181,31 @@
|
|||
<div
|
||||
class="conditional-section"
|
||||
v-if="
|
||||
selectedPermission && selectedPermission == Permission.WITH_OWNER
|
||||
permission.access &&
|
||||
permission.access == PermissionAccess.WITH_OWNER
|
||||
"
|
||||
>
|
||||
<div class="form-check mb-3">
|
||||
<input
|
||||
class="form-check-input"
|
||||
type="checkbox"
|
||||
id="request-scheduled"
|
||||
id="request_scheduled"
|
||||
name="request_scheduled"
|
||||
value="yes"
|
||||
v-model="permission.wants_scheduled"
|
||||
/>
|
||||
<label class="form-check-label" for="request-scheduled">
|
||||
<label class="form-check-label" for="request_scheduled">
|
||||
I would like to request a scheduled visit
|
||||
</label>
|
||||
</div>
|
||||
|
||||
<div class="mb-3">
|
||||
<label for="availability-notes" class="form-label">
|
||||
<label for="availability_notes" class="form-label">
|
||||
Availability / Access Notes
|
||||
<span class="text-muted">(Optional)</span>
|
||||
</label>
|
||||
<textarea
|
||||
class="form-control"
|
||||
id="availability-notes"
|
||||
id="availability_notes"
|
||||
name="availability_notes"
|
||||
rows="3"
|
||||
placeholder="Example: Available weekday mornings, please call before visiting..."
|
||||
|
|
@ -228,8 +219,8 @@
|
|||
<input
|
||||
type="radio"
|
||||
id="access-denied"
|
||||
:value="Permission.DENIED"
|
||||
v-model="selectedPermission"
|
||||
:value="PermissionAccess.DENIED"
|
||||
v-model="permission.access"
|
||||
class="mt-1"
|
||||
/>
|
||||
<label for="access-denied">
|
||||
|
|
@ -244,7 +235,9 @@
|
|||
<!-- Conditional message for Option 3 -->
|
||||
<div
|
||||
class="conditional-section"
|
||||
v-if="selectedPermission && selectedPermission == Permission.DENIED"
|
||||
v-if="
|
||||
permission.access && permission.access == PermissionAccess.DENIED
|
||||
"
|
||||
>
|
||||
<div class="encouragement-box">
|
||||
<p class="mb-2">
|
||||
|
|
@ -276,9 +269,9 @@
|
|||
<RouterLink class="btn btn-outline-secondary" to="./evidence">
|
||||
Back
|
||||
</RouterLink>
|
||||
<RouterLink class="btn btn-primary flex-grow-1" to="contact">
|
||||
<button class="btn btn-primary flex-grow-1" @click="doContinue">
|
||||
Continue
|
||||
</RouterLink>
|
||||
</button>
|
||||
</div>
|
||||
</form>
|
||||
</main>
|
||||
|
|
@ -286,31 +279,37 @@
|
|||
</template>
|
||||
<script setup lang="ts">
|
||||
import { ref } from "vue";
|
||||
import type { District } from "@/type/api";
|
||||
import { router } from "@/rmo/router";
|
||||
import HeaderCompliance from "@/rmo/components/HeaderCompliance.vue";
|
||||
import ProgressBarCompliance from "@/rmo/components/ProgressBarCompliance.vue";
|
||||
import { type District, PermissionAccess } from "@/type/api";
|
||||
|
||||
interface Emits {
|
||||
(e: "doPermission", permission: Permission): void;
|
||||
}
|
||||
export interface Permission {
|
||||
access?: PermissionAccess;
|
||||
access_instructions: string;
|
||||
availability_notes: string;
|
||||
gate_code: string;
|
||||
has_dog: boolean;
|
||||
wants_scheduled: boolean;
|
||||
}
|
||||
interface Props {
|
||||
district: District;
|
||||
}
|
||||
enum Permission {
|
||||
GRANTED = "access-granted",
|
||||
WITH_OWNER = "access-with-owner",
|
||||
DENIED = "access-denied",
|
||||
}
|
||||
const emit = defineEmits<Emits>();
|
||||
const props = defineProps<Props>();
|
||||
const hasDog = ref<boolean>(false);
|
||||
const selectedPermission = ref<Permission | undefined>();
|
||||
|
||||
function toggleDogWarning() {
|
||||
/*
|
||||
const dogYes = document.getElementById("dog-yes");
|
||||
const dogWarning = document.getElementById("dog-warning");
|
||||
|
||||
if (dogYes.checked) {
|
||||
dogWarning.style.display = "block";
|
||||
} else {
|
||||
dogWarning.style.display = "none";
|
||||
}
|
||||
*/
|
||||
const permission = ref<Permission>({
|
||||
access_instructions: "",
|
||||
availability_notes: "",
|
||||
gate_code: "",
|
||||
has_dog: false,
|
||||
wants_scheduled: false,
|
||||
});
|
||||
function doContinue() {
|
||||
emit("doPermission", permission.value);
|
||||
router.push("./contact");
|
||||
}
|
||||
</script>
|
||||
|
|
|
|||
|
|
@ -103,102 +103,161 @@
|
|||
</p>
|
||||
</div>
|
||||
|
||||
<form id="submit-form" method="POST" action="/compliance/submit">
|
||||
<!-- Response Summary -->
|
||||
<div class="mb-4">
|
||||
<h3 class="h6 mb-3 text-muted">Your Response Summary</h3>
|
||||
<!-- Response Summary -->
|
||||
<div class="mb-4">
|
||||
<h3 class="h6 mb-3 text-muted">Your Response Summary</h3>
|
||||
|
||||
<!-- Address -->
|
||||
<div class="summary-section">
|
||||
<h3><i class="bi bi-geo-alt"></i> Property Address</h3>
|
||||
<div class="summary-item">
|
||||
<div class="summary-value">
|
||||
123 Main St
|
||||
<span class="status-badge status-provided ms-2">
|
||||
<i class="bi bi-check-circle"></i> Provided
|
||||
</span>
|
||||
</div>
|
||||
<!-- Address -->
|
||||
<div class="summary-section">
|
||||
<h3><i class="bi bi-geo-alt"></i> Property Address</h3>
|
||||
<div class="summary-item">
|
||||
<div class="summary-value" v-if="compliance.locator?.address.raw">
|
||||
{{ compliance.locator.address.raw }}
|
||||
<span class="status-badge status-provided ms-2">
|
||||
<i class="bi bi-check-circle"></i> Provided
|
||||
</span>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- Photos -->
|
||||
<div class="summary-section">
|
||||
<h3><i class="bi bi-camera"></i> Photos</h3>
|
||||
<div class="summary-item">
|
||||
<div class="summary-value">
|
||||
<span class="photo-count">
|
||||
<i class="bi bi-images"></i>
|
||||
3 photos uploaded
|
||||
</span>
|
||||
</div>
|
||||
<div class="summary-value mt-2">
|
||||
<div class="summary-label">Comments:</div>
|
||||
<small class="text-muted">These are my comments</small>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- Access Permission -->
|
||||
<div class="summary-section">
|
||||
<h3><i class="bi bi-door-open"></i> Property Access</h3>
|
||||
<div class="summary-item">
|
||||
<div class="summary-value">
|
||||
<span class="status-badge status-provided">
|
||||
<i class="bi bi-check-circle"></i> Entry permitted without
|
||||
owner present
|
||||
</span>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- Contact Information -->
|
||||
<div class="summary-section">
|
||||
<h3><i class="bi bi-person"></i> Contact Information</h3>
|
||||
<div class="summary-item">
|
||||
<div class="summary-label">Name</div>
|
||||
<div class="summary-value">Kai Fu Lee</div>
|
||||
</div>
|
||||
<div class="summary-item">
|
||||
<div class="summary-label">Phone</div>
|
||||
<div class="summary-value">
|
||||
123-555-6789
|
||||
<small class="text-muted">(texting OK)</small>
|
||||
</div>
|
||||
</div>
|
||||
<div class="summary-item">
|
||||
<div class="summary-label">Email</div>
|
||||
<div class="summary-value">me@aol.com</div>
|
||||
<div class="summary-value" v-else>
|
||||
<span class="status-badge status-not-provided ms-2">
|
||||
<i class="bi bi-x-circle"></i> Not Provided
|
||||
</span>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- Submit Button -->
|
||||
<div class="d-grid gap-2 mt-4">
|
||||
<RouterLink class="btn btn-primary btn-lg submit-btn" to="complete">
|
||||
<i class="bi bi-check-circle"></i>
|
||||
Submit Response
|
||||
</RouterLink>
|
||||
<RouterLink class="btn btn-outline-secondary" to="process">
|
||||
Back
|
||||
</RouterLink>
|
||||
<!-- Photos -->
|
||||
<div class="summary-section">
|
||||
<h3><i class="bi bi-camera"></i> Photos</h3>
|
||||
<div class="summary-item">
|
||||
<div class="summary-value">
|
||||
<span class="photo-count" v-if="compliance.images.length > 0">
|
||||
<i class="bi bi-images"></i>
|
||||
{{ compliance.images.length }} photo{{
|
||||
compliance.images.length > 1 ? "s" : ""
|
||||
}}
|
||||
uploaded
|
||||
</span>
|
||||
<span class="photo-count status-badge status-not-provided" v-else>
|
||||
<i class="bi bi-x-circle"></i> Not Provided
|
||||
</span>
|
||||
</div>
|
||||
<div class="summary-value mt-2" v-if="compliance.comments">
|
||||
<div class="summary-label">Comments:</div>
|
||||
<small class="text-muted">{{ compliance.comments }}</small>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="text-center mt-3">
|
||||
<small class="text-muted">
|
||||
By submitting, you confirm the information provided is accurate to
|
||||
the best of your knowledge.
|
||||
</small>
|
||||
<!-- Access Permission -->
|
||||
<div class="summary-section">
|
||||
<h3><i class="bi bi-door-open"></i> Property Access</h3>
|
||||
<div class="summary-item">
|
||||
<div class="summary-value">
|
||||
<span
|
||||
class="status-badge status-provided"
|
||||
v-if="compliance.permission?.access == PermissionAccess.GRANTED"
|
||||
>
|
||||
<i class="bi bi-check-circle"></i> Entry permitted without owner
|
||||
present
|
||||
</span>
|
||||
<span
|
||||
class="status-badge status-provided"
|
||||
v-else-if="
|
||||
compliance.permission?.access == PermissionAccess.WITH_OWNER
|
||||
"
|
||||
>
|
||||
<i class="bi bi-check-circle"></i> Entry permitted with owner
|
||||
present
|
||||
</span>
|
||||
<span
|
||||
class="status-badge status-not-provided"
|
||||
v-else-if="
|
||||
compliance.permission?.access == PermissionAccess.DENIED
|
||||
"
|
||||
>
|
||||
<i class="bi bi-x-circle"></i> Entry denied
|
||||
</span>
|
||||
<span class="status-badge status-not-provided" v-else>
|
||||
<i class="bi bi-x-circle"></i> Not provided
|
||||
</span>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</form>
|
||||
|
||||
<!-- Contact Information -->
|
||||
<div class="summary-section">
|
||||
<h3><i class="bi bi-person"></i> Contact Information</h3>
|
||||
<div class="summary-item">
|
||||
<div class="summary-label">Name</div>
|
||||
<div class="summary-value" v-if="compliance.contact?.name">
|
||||
{{ compliance.contact.name }}
|
||||
</div>
|
||||
<div class="summary-value status-badge status-not-provided" v-else>
|
||||
<i class="bi bi-x-circle"></i> Not provided
|
||||
</div>
|
||||
</div>
|
||||
<div class="summary-item">
|
||||
<div class="summary-label">Phone</div>
|
||||
<div class="summary-value" v-if="compliance.contact?.phone">
|
||||
{{ compliance.contact.phone }}
|
||||
<small class="text-muted" v-if="compliance.contact?.can_text"
|
||||
>(texting OK)</small
|
||||
>
|
||||
</div>
|
||||
<div class="summary-value status-badge status-not-provided" v-else>
|
||||
<i class="bi bi-x-circle"></i> Not provided
|
||||
</div>
|
||||
</div>
|
||||
<div class="summary-item">
|
||||
<div class="summary-label">Email</div>
|
||||
<div class="summary-value" v-if="compliance.contact?.email">
|
||||
{{ compliance.contact?.email }}
|
||||
</div>
|
||||
<div class="summary-value status-badge status-not-provided" v-else>
|
||||
<i class="bi bi-x-circle"></i> Not provided
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- Submit Button -->
|
||||
<div class="d-flex gap-2 mt-4">
|
||||
<RouterLink class="btn btn-outline-secondary" to="process">
|
||||
Back
|
||||
</RouterLink>
|
||||
<button class="btn btn-primary flex-grow-1" @click="doContinue()">
|
||||
<i class="bi bi-check-circle"></i>
|
||||
Submit Response
|
||||
</button>
|
||||
</div>
|
||||
|
||||
<div class="text-center mt-3">
|
||||
<small class="text-muted">
|
||||
By submitting, you confirm the information provided is accurate to the
|
||||
best of your knowledge.
|
||||
</small>
|
||||
</div>
|
||||
</main>
|
||||
</div>
|
||||
</template>
|
||||
<script setup lang="ts">
|
||||
import type { District } from "@/type/api";
|
||||
import { router } from "@/rmo/router";
|
||||
import HeaderCompliance from "@/rmo/components/HeaderCompliance.vue";
|
||||
import ProgressBarCompliance from "@/rmo/components/ProgressBarCompliance.vue";
|
||||
import { type District, PermissionAccess } from "@/type/api";
|
||||
import type { Compliance } from "@/rmo/view/Compliance.vue";
|
||||
|
||||
interface Emits {
|
||||
(e: "doSubmit"): void;
|
||||
}
|
||||
interface Props {
|
||||
compliance: Compliance;
|
||||
district: District;
|
||||
}
|
||||
const emit = defineEmits<Emits>();
|
||||
const props = defineProps<Props>();
|
||||
function doContinue() {
|
||||
emit("doSubmit");
|
||||
router.push("./complete");
|
||||
}
|
||||
</script>
|
||||
|
|
|
|||
|
|
@ -20,10 +20,13 @@ body > .container-fluid {
|
|||
<router-view v-slot="{ Component }">
|
||||
<component
|
||||
:is="Component"
|
||||
:compliance="compliance"
|
||||
:district="district"
|
||||
@doComments="doComments"
|
||||
@doContact="doContact"
|
||||
@doImages="doImages"
|
||||
@doLocator="doLocator"
|
||||
@doPermission="doPermission"
|
||||
/>
|
||||
</router-view>
|
||||
</template>
|
||||
|
|
@ -41,13 +44,26 @@ import { useStoreDistrict } from "@/rmo/store/district";
|
|||
import Intro from "@/rmo/content/compliance/Intro.vue";
|
||||
import type { District } from "@/type/api";
|
||||
import { Locator } from "@/type/map";
|
||||
import { type Contact } from "@/rmo/content/compliance/Contact.vue";
|
||||
import { type Permission } from "@/rmo/content/compliance/Permission.vue";
|
||||
|
||||
export interface Compliance {
|
||||
comments: string;
|
||||
contact?: Contact;
|
||||
locator?: Locator;
|
||||
images: Image[];
|
||||
permission?: Permission;
|
||||
}
|
||||
interface Props {
|
||||
slug: string;
|
||||
}
|
||||
|
||||
const districtStore = useStoreDistrict();
|
||||
|
||||
const compliance = ref<Compliance>({
|
||||
comments: "",
|
||||
images: [],
|
||||
});
|
||||
const props = defineProps<Props>();
|
||||
const district = computedAsync(async (): Promise<District | undefined> => {
|
||||
const districts = await districtStore.list();
|
||||
|
|
@ -55,11 +71,22 @@ const district = computedAsync(async (): Promise<District | undefined> => {
|
|||
});
|
||||
function doComments(comments: string) {
|
||||
console.log("comments", comments);
|
||||
compliance.value.comments = comments;
|
||||
}
|
||||
function doContact(contact: Contact | undefined) {
|
||||
console.log("contact", contact);
|
||||
compliance.value.contact = contact;
|
||||
}
|
||||
function doImages(images: Image[]) {
|
||||
console.log("images", images);
|
||||
compliance.value.images = images;
|
||||
}
|
||||
function doLocator(locator: Locator | null) {
|
||||
function doLocator(locator: Locator | undefined) {
|
||||
console.log("locator", locator);
|
||||
compliance.value.locator = locator;
|
||||
}
|
||||
function doPermission(permission: Permission | undefined) {
|
||||
console.log("permission", permission);
|
||||
compliance.value.permission = permission;
|
||||
}
|
||||
</script>
|
||||
|
|
|
|||
|
|
@ -1,3 +1,8 @@
|
|||
export enum PermissionAccess {
|
||||
GRANTED = "access-granted",
|
||||
WITH_OWNER = "access-with-owner",
|
||||
DENIED = "access-denied",
|
||||
}
|
||||
export interface Address {
|
||||
country: string;
|
||||
gid: string;
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue