Compare commits
3 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
fe6a0e8fc9 | ||
| c10c774ac8 | |||
| 4b847eb1a2 |
@@ -1,2 +1,2 @@
|
|||||||
parameters:
|
parameters:
|
||||||
app.version: '0.1.4'
|
app.version: '0.1.5'
|
||||||
|
|||||||
@@ -1,16 +1,16 @@
|
|||||||
<template>
|
<template>
|
||||||
<div class="max-h-[80vh] overflow-auto rounded-lg border border-neutral-200 bg-white">
|
<div class="h-full min-h-0 overflow-auto rounded-lg border border-neutral-200 bg-white">
|
||||||
<div class="min-w-[900px]">
|
<div class="min-w-[900px]">
|
||||||
<div class="grid" :style="gridStyle">
|
<div class="grid" :style="gridStyle">
|
||||||
<div
|
<div
|
||||||
class="sticky left-0 z-20 border-b border-neutral-200 bg-tertiary-500 px-4 py-3 text-md font-semibold text-neutral-700"
|
class="sticky left-0 top-0 z-30 border-b border-neutral-200 bg-tertiary-500 px-4 py-3 text-md font-semibold text-neutral-700"
|
||||||
>
|
>
|
||||||
Employés
|
Employés
|
||||||
</div>
|
</div>
|
||||||
<div
|
<div
|
||||||
v-for="day in daysInMonth"
|
v-for="day in daysInMonth"
|
||||||
:key="day.date"
|
:key="day.date"
|
||||||
class="border-b border-neutral-200 bg-tertiary-500 px-2 py-3 text-center text-xs font-semibold text-neutral-700"
|
class="sticky top-0 z-20 border-b border-neutral-200 bg-tertiary-500 px-2 py-3 text-center text-xs font-semibold text-neutral-700"
|
||||||
>
|
>
|
||||||
<div>{{ day.label }}</div>
|
<div>{{ day.label }}</div>
|
||||||
<div class="text-[10px] text-neutral-500">{{ day.weekday }}</div>
|
<div class="text-[10px] text-neutral-500">{{ day.weekday }}</div>
|
||||||
|
|||||||
@@ -1,68 +1,80 @@
|
|||||||
<template>
|
<template>
|
||||||
<div>
|
<div class="h-full flex flex-col overflow-hidden">
|
||||||
<div class="flex flex-wrap items-center justify-between gap-4">
|
<div class="flex flex-wrap items-center justify-between gap-4">
|
||||||
<h1 class="text-4xl font-bold text-primary-500">Calendrier des absences</h1>
|
<h1 class="text-4xl font-bold text-primary-500">Calendrier des absences</h1>
|
||||||
</div>
|
</div>
|
||||||
<div class="flex items-center justify-between py-6">
|
<div class="py-6">
|
||||||
<div class="flex items-center gap-4">
|
<div class="flex items-center justify-between gap-4">
|
||||||
<div class="flex flex-wrap items-center gap-4 rounded-md border border-neutral-300 px-3 py-2">
|
<div class="flex items-center gap-4">
|
||||||
<div v-for="site in sites" :key="site.id" class="flex items-center gap-2">
|
<div class="flex flex-wrap items-center gap-4 rounded-md border border-neutral-300 px-3 py-2">
|
||||||
<div :style="{ backgroundColor: site.color }" class="h-4 w-4 rounded"></div>
|
<div v-for="site in sites" :key="site.id" class="flex items-center gap-2">
|
||||||
<label class="text-md" :for="`site-${site.id}`">{{ site.name }}</label>
|
<div :style="{ backgroundColor: site.color }" class="h-4 w-4 rounded"></div>
|
||||||
<input
|
<label class="text-md" :for="`site-${site.id}`">{{ site.name }}</label>
|
||||||
:id="`site-${site.id}`"
|
<input
|
||||||
v-model="selectedSiteIds"
|
:id="`site-${site.id}`"
|
||||||
:value="site.id"
|
v-model="selectedSiteIds"
|
||||||
type="checkbox"
|
:value="site.id"
|
||||||
class="h-4 w-4"
|
type="checkbox"
|
||||||
/>
|
class="h-4 w-4"
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
<select
|
||||||
|
v-model="selectedMonth"
|
||||||
|
class="h-10 rounded-md border border-neutral-300 bg-white px-3 text-md text-neutral-900"
|
||||||
|
>
|
||||||
|
<option v-for="month in months" :key="month.value" :value="month.value">
|
||||||
|
{{ month.label }}
|
||||||
|
</option>
|
||||||
|
</select>
|
||||||
|
<select
|
||||||
|
v-model="selectedYear"
|
||||||
|
class="h-10 rounded-md border border-neutral-300 bg-white px-3 text-md text-neutral-900"
|
||||||
|
>
|
||||||
|
<option v-for="year in years" :key="year" :value="year">
|
||||||
|
{{ year }}
|
||||||
|
</option>
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
<div class="flex gap-4">
|
||||||
|
<button
|
||||||
|
type="button"
|
||||||
|
class="h-10 rounded-lg bg-primary-500 px-4 text-md font-semibold text-white hover:bg-secondary-500"
|
||||||
|
@click="openCreateFromToday"
|
||||||
|
>
|
||||||
|
Ajouter une absence
|
||||||
|
</button>
|
||||||
|
<button
|
||||||
|
type="button"
|
||||||
|
class="h-10 rounded-lg bg-primary-500 px-4 text-md font-semibold text-white hover:bg-secondary-500"
|
||||||
|
@click="openPrint"
|
||||||
|
>
|
||||||
|
Imprimer
|
||||||
|
</button>
|
||||||
</div>
|
</div>
|
||||||
<select
|
|
||||||
v-model="selectedMonth"
|
|
||||||
class="h-10 rounded-md border border-neutral-300 bg-white px-3 text-md text-neutral-900"
|
|
||||||
>
|
|
||||||
<option v-for="month in months" :key="month.value" :value="month.value">
|
|
||||||
{{ month.label }}
|
|
||||||
</option>
|
|
||||||
</select>
|
|
||||||
<select
|
|
||||||
v-model="selectedYear"
|
|
||||||
class="h-10 rounded-md border border-neutral-300 bg-white px-3 text-md text-neutral-900"
|
|
||||||
>
|
|
||||||
<option v-for="year in years" :key="year" :value="year">
|
|
||||||
{{ year }}
|
|
||||||
</option>
|
|
||||||
</select>
|
|
||||||
</div>
|
</div>
|
||||||
<div class="flex gap-4">
|
<div class="mt-3 flex items-center gap-4">
|
||||||
<button
|
<input
|
||||||
type="button"
|
v-model="employeeFilter"
|
||||||
class="h-10 rounded-lg bg-primary-500 px-4 text-md font-semibold text-white hover:bg-secondary-500"
|
type="text"
|
||||||
@click="openCreateFromToday"
|
placeholder="Chercher un employé (nom ou prénom)"
|
||||||
>
|
class="h-10 w-full max-w-md rounded-md border border-neutral-300 bg-white px-3 text-md text-neutral-900"
|
||||||
Ajouter une absence
|
/>
|
||||||
</button>
|
|
||||||
<button
|
|
||||||
type="button"
|
|
||||||
class="h-10 rounded-lg bg-primary-500 px-4 text-md font-semibold text-white hover:bg-secondary-500"
|
|
||||||
@click="openPrint"
|
|
||||||
>
|
|
||||||
Imprimer
|
|
||||||
</button>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<CalendarGrid
|
<div class="flex-1 min-h-0">
|
||||||
:days-in-month="daysInMonth"
|
<CalendarGrid
|
||||||
:visible-employees="visibleEmployees"
|
:days-in-month="daysInMonth"
|
||||||
:grid-style="gridStyle"
|
:visible-employees="visibleEmployees"
|
||||||
:get-cell-style="getCellStyle"
|
:grid-style="gridStyle"
|
||||||
:get-cell-info="getCellInfo"
|
:get-cell-style="getCellStyle"
|
||||||
:format-employee-name="formatEmployeeName"
|
:get-cell-info="getCellInfo"
|
||||||
:is-holiday-date="isHolidayDate"
|
:format-employee-name="formatEmployeeName"
|
||||||
@cell-click="openCreate"
|
:is-holiday-date="isHolidayDate"
|
||||||
/>
|
@cell-click="openCreate"
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
|
||||||
<AbsenceFormDrawer
|
<AbsenceFormDrawer
|
||||||
v-model="isDrawerOpen"
|
v-model="isDrawerOpen"
|
||||||
@@ -139,10 +151,18 @@ const sortedEmployees = computed(() => {
|
|||||||
})
|
})
|
||||||
|
|
||||||
// Employés visibles selon le filtre de sites.
|
// Employés visibles selon le filtre de sites.
|
||||||
|
const employeeFilter = ref('')
|
||||||
|
|
||||||
const visibleEmployees = computed(() => {
|
const visibleEmployees = computed(() => {
|
||||||
if (selectedSiteIds.value.length === 0) return []
|
if (selectedSiteIds.value.length === 0) return []
|
||||||
|
const filter = employeeFilter.value.trim().toLowerCase()
|
||||||
return sortedEmployees.value.filter((employee) => {
|
return sortedEmployees.value.filter((employee) => {
|
||||||
return employee.site?.id && selectedSiteIds.value.includes(employee.site.id)
|
const siteOk = employee.site?.id && selectedSiteIds.value.includes(employee.site.id)
|
||||||
|
if (!siteOk) return false
|
||||||
|
if (!filter) return true
|
||||||
|
const first = employee.firstName?.toLowerCase() ?? ''
|
||||||
|
const last = employee.lastName?.toLowerCase() ?? ''
|
||||||
|
return first.includes(filter) || last.includes(filter)
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
// Données de référence et absences du mois affiché.
|
// Données de référence et absences du mois affiché.
|
||||||
|
|||||||
Reference in New Issue
Block a user