Added printing + Resume name input
Some checks failed
linter / quality (push) Failing after 6m25s
tests / ci (push) Failing after 12m38s

This commit is contained in:
2025-08-27 14:54:51 +02:00
parent 55a52086c1
commit f3ff6fd6ac
11 changed files with 303 additions and 16 deletions

View File

@@ -0,0 +1,18 @@
<script setup lang="ts">
import { Resume } from '@/types/resume';
import Button from '../ui/button/Button.vue';
import { exportToPdf } from '@/lib/pdfExport';
import { FileText } from 'lucide-vue-next';
const props = defineProps<{
resume: Resume,
}>();
function printResume() {
exportToPdf(document.getElementById('resume')!, (props.resume.name || 'Sans titre') + '.pdf');
}
</script>
<template>
<Button variant="outline" class="cursor-pointer" @click="printResume"><FileText />Exporter le CV</Button>
</template>

View File

@@ -16,5 +16,7 @@ const componentFile = defineAsyncComponent(
</script>
<template>
<component :is="componentFile" :componentPlacement="props.componentPlacement" />
<div class="w-full">
<component :is="componentFile" :componentPlacement="props.componentPlacement" />
</div>
</template>

View File

@@ -0,0 +1,58 @@
<script setup lang="ts">
import { ref, Transition } from 'vue';
import { Save } from 'lucide-vue-next';
import Button from '../ui/button/Button.vue';
import Input from '../ui/input/Input.vue';
import { Form } from '@inertiajs/vue3';
import { httpApi } from '@/lib/utils';
import { Resume } from '@/types/resume';
const props = defineProps<{
resume: Resume,
resumeTitle: string,
}>();
const emit = defineEmits(['update:resume-title']);
const originalTitle = ref<string>(props.resumeTitle);
const titleChanged = ref<boolean>(false);
function saveTitle() {
const resume = { ...props.resume, name: props.resumeTitle };
resume['components_placements'] = null;
httpApi(route('resumes.update', props.resume), {
method: 'POST',
headers: {
'Content-Type': 'application/json',
'X-CSRF-TOKEN': document.querySelector('meta[name="csrf-token"]')?.getAttribute('content') || '',
'Accept': 'application/json'
},
body: JSON.stringify({ ...resume, _method: 'PUT' })
}).then(() => {
location.reload();
});
}
</script>
<template>
<div class="flex gap-1" >
<Input type="text" v-model="props.resumeTitle" placeholder="Sans titre" class="border p-2 rounded" @input="(event) => {emit('update:resume-title', event.target.value); titleChanged = (event.target.value !== originalTitle)}" />
<Transition>
<Button v-if="titleChanged" variant="outline" class="cursor-pointer transition" @click="saveTitle"><Save /></Button>
</Transition>
</div>
</template>
<style lang="css" scoped>
.v-enter-active,
.v-leave-active {
transition: opacity 0.3s ease;
}
.v-enter-from,
.v-leave-to {
opacity: 0;
}
</style>

View File

@@ -1,19 +1,25 @@
<script setup lang="ts">
import { Resume, ResumeComponentPlacement } from '@/types/resume';
import ResumeComponent from './ResumeComponent.vue';
import PrintResumeButton from './PrintResumeButton.vue';
import ResumeNameInput from './ResumeNameInput.vue';
const props = defineProps<{
resume: Resume,
selectedComponent: ResumeComponentPlacement | null
}>();
const emit = defineEmits(['selected-component-change']);
const emit = defineEmits(['selected-component-change', 'update:resume-title']);
</script>
<template>
<div class="flex-2 w-full p-6">
<div class="flex-2 flex flex-col gap-3 w-full">
<div id="tools" class="w-full flex gap-3 justify-between">
<ResumeNameInput :resume="props.resume" :resumeTitle="props.resume.name" @update:resume-title="emit('update:resume-title', $event)" />
<PrintResumeButton :resume="props.resume" />
</div>
<div id="resume" class="aspect-[0.707317073] w-full max-w-[84.1cm] bg-white text-black">
<ResumeComponent v-for="componentPlacement in resume.components_placements" :key="componentPlacement.id" :componentPlacement="componentPlacement" @click="emit('selected-component-change', componentPlacement)" />
<ResumeComponent v-for="componentPlacement in props.resume.components_placements" :key="componentPlacement.id" :componentPlacement="componentPlacement" @click="emit('selected-component-change', componentPlacement)" />
</div>
</div>
</template>

View File

@@ -8,8 +8,9 @@ const props = defineProps<{
</script>
<template>
<div class="w-full">
<div class="w-full" style="background-color: aqua; height: 10%;">
I'm an email component : {{ props.componentPlacement?.component_data?.input_data[0].value }}
</div>
<div style="width: 365px; height: 50px; background-color: red;"></div>
</template>