Files
InvoiceShelf/resources/scripts/features/shared/document-form/SelectTemplateModal.vue
Darko Gjorgjijoski 71388ec6a5 Rename resources/scripts-v2 to resources/scripts and drop @v2 alias
Now that the legacy v1 frontend (commit 064bdf53) is gone, the v2 directory is the only frontend and the v2 suffix is just noise. Renames resources/scripts-v2 to resources/scripts via git mv (so git records the move as renames, preserving blame and log --follow), then bulk-rewrites the 152 files that imported via @v2/... to use @/scripts/... instead. The existing @ alias (resources/) covers the new path with no extra config needed.

Drops the now-unused @v2 alias from vite.config.js and points the laravel-vite-plugin entry at resources/scripts/main.ts. Updates the only blade reference (resources/views/app.blade.php) to match. The package.json test script (eslint ./resources/scripts) automatically targets the right place after the rename without any edit.

Verified: npm run build exits clean and the Vite warning lines now reference resources/scripts/plugins/i18n.ts, confirming every import resolved through the new path. git log --follow on any moved file walks back through its scripts-v2 history.
2026-04-07 12:50:16 +02:00

165 lines
4.6 KiB
Vue

<script setup lang="ts">
import { ref, computed } from 'vue'
import { useModalStore } from '@/scripts/stores/modal.store'
import { useUserStore } from '@/scripts/stores/user.store'
interface ModalData {
templates: Array<{ name: string; path?: string }>
store: { setTemplate: (name: string) => void; isEdit?: boolean; [key: string]: unknown }
storeProp: string
isMarkAsDefault: boolean
markAsDefaultDescription: string
}
const modalStore = useModalStore()
const userStore = useUserStore()
const selectedTemplate = ref<string>('')
const modalActive = computed<boolean>(
() => modalStore.active && modalStore.componentName === 'SelectTemplate',
)
const modalData = computed<ModalData | null>(() => {
return modalStore.data as ModalData | null
})
function setData(): void {
if (!modalData.value) return
const currentName =
(modalData.value.store[modalData.value.storeProp] as Record<string, unknown>)
?.template_name as string | undefined
if (currentName) {
selectedTemplate.value = currentName
} else if (modalData.value.templates.length) {
selectedTemplate.value = modalData.value.templates[0].name
}
}
async function chooseTemplate(): Promise<void> {
if (!modalData.value) return
modalData.value.store.setTemplate(selectedTemplate.value)
if (!modalData.value.store.isEdit && modalData.value.isMarkAsDefault) {
if (modalData.value.storeProp === 'newEstimate') {
await userStore.updateUserSettings({
settings: {
default_estimate_template: selectedTemplate.value,
},
})
} else if (modalData.value.storeProp === 'newInvoice') {
await userStore.updateUserSettings({
settings: {
default_invoice_template: selectedTemplate.value,
},
})
}
}
closeModal()
}
function getTickImage(): string {
return new URL('$images/tick.png', import.meta.url).href
}
function closeModal(): void {
modalStore.closeModal()
}
</script>
<template>
<BaseModal :show="modalActive" @close="closeModal" @open="setData">
<template #header>
<div class="flex justify-between w-full">
{{ modalStore.title }}
<BaseIcon
name="XMarkIcon"
class="h-6 w-6 text-muted cursor-pointer"
@click="closeModal"
/>
</div>
</template>
<div class="px-8 py-8 sm:p-6">
<div
v-if="modalData"
class="grid grid-cols-3 gap-2 p-1 overflow-x-auto"
>
<div
v-for="(template, index) in modalData.templates"
:key="index"
:class="{
'border border-solid border-primary-500':
selectedTemplate === template.name,
}"
class="
relative
flex flex-col
m-2
border border-line-default border-solid
cursor-pointer
hover:border-primary-300
"
@click="selectedTemplate = template.name"
>
<img
:src="template.path"
:alt="template.name"
class="w-full min-h-[100px]"
/>
<img
v-if="selectedTemplate === template.name"
:alt="template.name"
class="absolute z-10 w-5 h-5 text-primary-500"
style="top: -6px; right: -5px"
:src="getTickImage()"
/>
<span
:class="[
'w-full p-1 bg-surface-muted text-sm text-center absolute bottom-0 left-0',
{
'text-primary-500 bg-primary-100':
selectedTemplate === template.name,
'text-body': selectedTemplate !== template.name,
},
]"
>
{{ template.name }}
</span>
</div>
</div>
<div
v-if="modalData && !modalData.store.isEdit"
class="z-0 flex ml-3 pt-5"
>
<BaseCheckbox
v-model="modalData.isMarkAsDefault"
:set-initial-value="false"
variant="primary"
:label="$t('general.mark_as_default')"
:description="modalData.markAsDefaultDescription"
/>
</div>
</div>
<div
class="z-0 flex justify-end p-4 border-t border-line-default border-solid"
>
<BaseButton class="mr-3" variant="primary-outline" @click="closeModal">
{{ $t('general.cancel') }}
</BaseButton>
<BaseButton variant="primary" @click="chooseTemplate">
<template #left="slotProps">
<BaseIcon name="ArrowDownOnSquareIcon" :class="slotProps.class" />
</template>
{{ $t('general.choose') }}
</BaseButton>
</div>
</BaseModal>
</template>