Compare commits
No commits in common. "production-hfc" and "develop-ezway" have entirely different histories.
production
...
develop-ez
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
@ -26,8 +26,8 @@
|
||||
:class="{ 'property-title__input--readonly': isReadOnly }">
|
||||
<input v-if="!isReadOnly"
|
||||
v-focus
|
||||
:type="type"
|
||||
:placeholder="computedPlaceholder"
|
||||
type="text"
|
||||
:placeholder="t('calendar', 'Nom et prénom du défunt')"
|
||||
:value="value"
|
||||
@input.prevent.stop="changeValue">
|
||||
<!-- eslint-disable-next-line vue/singleline-html-element-content-newline -->
|
||||
@ -53,19 +53,6 @@ export default {
|
||||
type: String,
|
||||
default: '',
|
||||
},
|
||||
type: {
|
||||
type: String,
|
||||
default: 'text',
|
||||
},
|
||||
placeholder: {
|
||||
type: String,
|
||||
default: '',
|
||||
},
|
||||
},
|
||||
computed: {
|
||||
computedPlaceholder() {
|
||||
return this.placeholder || this.t('calendar', 'Nom et prénom du défunt')
|
||||
},
|
||||
},
|
||||
methods: {
|
||||
changeValue(event) {
|
||||
|
||||
@ -118,14 +118,6 @@ export default {
|
||||
return this.calendarObjectInstance?.embalmer ?? null
|
||||
},
|
||||
|
||||
lieuDeces() {
|
||||
return this.calendarObjectInstance?.lieuDeces ?? null
|
||||
},
|
||||
|
||||
dateNaissance() {
|
||||
return this.calendarObjectInstance?.dateNaissance ?? null
|
||||
},
|
||||
|
||||
/**
|
||||
* Returns the isleave property
|
||||
*
|
||||
@ -163,6 +155,7 @@ export default {
|
||||
return this.calendarObjectInstance?.isPrivate ?? false
|
||||
},
|
||||
|
||||
|
||||
/**
|
||||
* Returns the description or null if the event is still loading
|
||||
*
|
||||
@ -456,23 +449,23 @@ export default {
|
||||
|
||||
return false
|
||||
},
|
||||
|
||||
|
||||
/**
|
||||
* Returns the absence type
|
||||
*
|
||||
* @return {string|null}
|
||||
*/
|
||||
absenceType() {
|
||||
const isleave = this.calendarObjectInstance?.isLeave ?? false
|
||||
const isleave = this.calendarObjectInstance?.isLeave ?? false
|
||||
const absenceType = this.calendarObjectInstance?.absenceType ?? null
|
||||
if (absenceType) {
|
||||
return this.calendarObjectInstance?.absenceType
|
||||
}
|
||||
if (isleave && !absenceType) {
|
||||
return 'LEAVE'
|
||||
if (isleave && !absenceType ) {
|
||||
return 'LEAVE'
|
||||
}
|
||||
|
||||
return ''
|
||||
return '';
|
||||
},
|
||||
},
|
||||
methods: {
|
||||
@ -590,7 +583,7 @@ export default {
|
||||
this.isLoading = true
|
||||
this.isSaving = true
|
||||
try {
|
||||
this.setPendingCalendar(false)
|
||||
this.setPendingCalendar(false);
|
||||
await this.$store.dispatch('saveCalendarObjectInstance', {
|
||||
thisAndAllFuture,
|
||||
calendarId: this.calendarId,
|
||||
@ -608,6 +601,8 @@ export default {
|
||||
setPendingCalendar(isPending = true) {
|
||||
this.calendarObjectInstance.eventComponent.isCalendarPending = isPending
|
||||
this.calendarObjectInstance.isCalendarPending = isPending
|
||||
|
||||
|
||||
},
|
||||
async savePendingCalendar(thisAndAllFuture = false) {
|
||||
if (!this.calendarObject) {
|
||||
@ -625,7 +620,7 @@ export default {
|
||||
this.isSaving = true
|
||||
try {
|
||||
this.setPendingCalendar();
|
||||
await this.$store.dispatch('saveCalendarObjectInstance', {
|
||||
await this.$store.dispatch('saveCalendarObjectInstance', {
|
||||
thisAndAllFuture,
|
||||
calendarId: this.calendarId,
|
||||
})
|
||||
@ -766,6 +761,7 @@ export default {
|
||||
embalmer,
|
||||
})
|
||||
},
|
||||
|
||||
|
||||
/**
|
||||
* Updates the start date of this event
|
||||
@ -831,7 +827,7 @@ export default {
|
||||
toggleIsPrivate(isPrivate) {
|
||||
this.$store.commit('toggleIsPrivate', {
|
||||
calendarObjectInstance: this.calendarObjectInstance,
|
||||
isPrivate,
|
||||
isPrivate
|
||||
})
|
||||
},
|
||||
|
||||
@ -839,23 +835,23 @@ export default {
|
||||
// * Toggles the event between all-day and timed
|
||||
// */
|
||||
// toggleIsLeave(isLeave) {
|
||||
// this.$store.commit('toggleIsLeave', {
|
||||
// calendarObjectInstance: this.calendarObjectInstance,
|
||||
// isLeave
|
||||
// })
|
||||
// this.$store.commit('toggleIsLeave', {
|
||||
// calendarObjectInstance: this.calendarObjectInstance,
|
||||
// isLeave
|
||||
// })
|
||||
// },
|
||||
|
||||
/**
|
||||
* Toggles the event pending
|
||||
* @param isCalendarPending
|
||||
*/
|
||||
toggleIsCalendarPending(isCalendarPending) {
|
||||
this.$store.commit('toggleIsCalendarPending', {
|
||||
calendarObjectInstance: this.calendarObjectInstance,
|
||||
isCalendarPending,
|
||||
isCalendarPending
|
||||
})
|
||||
},
|
||||
|
||||
|
||||
/**
|
||||
* Resets the internal state after changing the viewed calendar-object
|
||||
*/
|
||||
@ -899,31 +895,7 @@ export default {
|
||||
calendarObjectInstance: this.calendarObjectInstance,
|
||||
absenceType,
|
||||
})
|
||||
},
|
||||
|
||||
/**
|
||||
* Updates the lieu de décès of this event
|
||||
*
|
||||
* @param {string} lieuDeces New lieu de décès
|
||||
*/
|
||||
updateLieuDeces(lieuDeces) {
|
||||
this.$store.commit('changeLieuDeces', {
|
||||
calendarObjectInstance: this.calendarObjectInstance,
|
||||
lieuDeces,
|
||||
})
|
||||
},
|
||||
|
||||
/**
|
||||
* Updates the date de naissance of this event
|
||||
*
|
||||
* @param {string} dateNaissance New date de naissance
|
||||
*/
|
||||
updateDateNaissance(dateNaissance) {
|
||||
this.$store.commit('changeDateNaissance', {
|
||||
calendarObjectInstance: this.calendarObjectInstance,
|
||||
dateNaissance,
|
||||
})
|
||||
},
|
||||
}
|
||||
},
|
||||
/**
|
||||
* This is executed before entering the Editor routes
|
||||
|
||||
@ -21,7 +21,7 @@
|
||||
*/
|
||||
|
||||
import { getDateFromDateTimeValue } from '../utils/date.js'
|
||||
import { DurationValue, DateTimeValue, Property } from '@nextcloud/calendar-js'
|
||||
import { DurationValue, DateTimeValue } from '@nextcloud/calendar-js'
|
||||
import { getHexForColorName, getClosestCSS3ColorNameForHex } from '../utils/color.js'
|
||||
import { mapAlarmComponentToAlarmObject } from './alarm.js'
|
||||
import { mapAttendeePropertyToAttendeeObject } from './attendee.js'
|
||||
@ -52,28 +52,24 @@ const getDefaultEventObject = (props = {}) => Object.assign({}, {
|
||||
endTimezoneId: null,
|
||||
// Indicator whether or not event is all-day
|
||||
isAllDay: false,
|
||||
// leave
|
||||
//leave
|
||||
isLeave: false,
|
||||
// calendarPending
|
||||
//calendarPending
|
||||
isCalendarPending: false,
|
||||
// Whether or not the user is allowed to toggle the all-day checkbox
|
||||
canModifyAllDay: true,
|
||||
// Location that the event takes places in
|
||||
location: null,
|
||||
// client of the event
|
||||
client: null,
|
||||
// embalmer(Thanato) of the event
|
||||
embalmer: null,
|
||||
// lieu de décès
|
||||
lieuDeces: null,
|
||||
// date de naissance
|
||||
dateNaissance: null,
|
||||
// absenceType
|
||||
absenceType: null,
|
||||
// Private
|
||||
//client of the event
|
||||
client : null,
|
||||
//embalmer(Thanato) of the event
|
||||
embalmer : null,
|
||||
//absenceType
|
||||
absenceType : null,
|
||||
//Private
|
||||
isPrivate: false,
|
||||
// comment of the event
|
||||
comment: null,
|
||||
//comment of the event
|
||||
comment : null,
|
||||
// description of the event
|
||||
description: null,
|
||||
// Access class of the event (PUBLIC, PRIVATE, CONFIDENTIAL)
|
||||
@ -122,12 +118,10 @@ const mapEventComponentToEventObject = (eventComponent) => {
|
||||
isCalendarPending: false,
|
||||
canModifyAllDay: eventComponent.canModifyAllDay(),
|
||||
location: eventComponent.location,
|
||||
client: 'CLIENT',
|
||||
embalmer: 'TEST',
|
||||
lieuDeces: null,
|
||||
dateNaissance: null,
|
||||
absenceType: '',
|
||||
comment: '',
|
||||
client : "CLIENT",
|
||||
embalmer : "TEST",
|
||||
absenceType : "",
|
||||
comment : "",
|
||||
description: eventComponent.description,
|
||||
accessClass: eventComponent.accessClass,
|
||||
status: eventComponent.status,
|
||||
@ -213,46 +207,39 @@ const mapEventComponentToEventObject = (eventComponent) => {
|
||||
}
|
||||
}
|
||||
|
||||
if (eventComponent.hasProperty('CLIENT')) {
|
||||
eventObject.client = eventComponent.getFirstPropertyFirstValue('CLIENT')
|
||||
if(eventComponent.hasProperty('CLIENT')){
|
||||
eventObject.client = eventComponent.getFirstPropertyFirstValue('CLIENT');
|
||||
}
|
||||
|
||||
if (eventComponent.hasProperty('EMBALMER')) {
|
||||
eventObject.embalmer = eventComponent.getFirstPropertyFirstValue('EMBALMER')
|
||||
if(eventComponent.hasProperty('EMBALMER')){
|
||||
eventObject.embalmer = eventComponent.getFirstPropertyFirstValue('EMBALMER');
|
||||
}
|
||||
|
||||
if (eventComponent.hasProperty('COMMENT')) {
|
||||
eventObject.comment = eventComponent.getFirstPropertyFirstValue('COMMENT')
|
||||
if(eventComponent.hasProperty('COMMENT')){
|
||||
eventObject.comment = eventComponent.getFirstPropertyFirstValue('COMMENT');
|
||||
}
|
||||
|
||||
if (eventComponent.hasProperty('ISPRIVATE')) {
|
||||
eventObject.isPrivate = eventComponent.getFirstPropertyFirstValue('ISPRIVATE') === '1'
|
||||
if(eventComponent.hasProperty('ISPRIVATE')){
|
||||
eventObject.isPrivate = eventComponent.getFirstPropertyFirstValue('ISPRIVATE') === '1' ? true : false;
|
||||
}
|
||||
|
||||
if (eventComponent.hasProperty('ABSENCETYPE')) {
|
||||
eventObject.absenceType = eventComponent.getFirstPropertyFirstValue('ABSENCETYPE')
|
||||
|
||||
} else {
|
||||
if (eventComponent.hasProperty('ISLEAVE')) {
|
||||
if (eventComponent.getFirstPropertyFirstValue('ISLEAVE') === '1') {
|
||||
eventObject.absenceType = 'LEAVE'
|
||||
|
||||
if(eventComponent.hasProperty('ABSENCETYPE')){
|
||||
eventObject.absenceType = eventComponent.getFirstPropertyFirstValue('ABSENCETYPE');
|
||||
|
||||
}else{
|
||||
if(eventComponent.hasProperty('ISLEAVE')){
|
||||
if( eventComponent.getFirstPropertyFirstValue('ISLEAVE') === '1'){
|
||||
eventObject.absenceType = 'LEAVE';
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (eventComponent.hasProperty('ISCALENDARPENDING')) {
|
||||
eventObject.isCalendarPending = eventComponent.getFirstPropertyFirstValue('ISCALENDARPENDING') === '1'
|
||||
if(eventComponent.hasProperty('ISCALENDARPENDING')){
|
||||
eventObject.isCalendarPending = eventComponent.getFirstPropertyFirstValue('ISCALENDARPENDING') === '1' ? true : false;
|
||||
}
|
||||
|
||||
if (eventComponent.hasProperty('LIEUDECES')) {
|
||||
eventObject.lieuDeces = eventComponent.getFirstPropertyFirstValue('LIEUDECES')
|
||||
}
|
||||
|
||||
if (eventComponent.hasProperty('DATENAISSANCE')) {
|
||||
eventObject.dateNaissance = eventComponent.getFirstPropertyFirstValue('DATENAISSANCE')
|
||||
}
|
||||
|
||||
return eventObject
|
||||
return eventObject;
|
||||
}
|
||||
|
||||
/**
|
||||
@ -266,20 +253,6 @@ const copyCalendarObjectInstanceIntoEventComponent = (eventObject, eventComponen
|
||||
eventComponent.location = eventObject.location
|
||||
eventComponent.client = eventObject.client
|
||||
eventComponent.embalmer = eventObject.embalmer
|
||||
|
||||
if (eventObject.lieuDeces) {
|
||||
eventComponent.deleteAllProperties('LIEUDECES')
|
||||
const lieuDecesProperty = new Property('LIEUDECES', eventObject.lieuDeces)
|
||||
eventComponent.addProperty(lieuDecesProperty)
|
||||
}
|
||||
|
||||
// Gérer dateNaissance comme une propriété ICS personnalisée
|
||||
if (eventObject.dateNaissance) {
|
||||
eventComponent.deleteAllProperties('DATENAISSANCE')
|
||||
const dateNaissanceProperty = new Property('DATENAISSANCE', eventObject.dateNaissance)
|
||||
eventComponent.addProperty(dateNaissanceProperty)
|
||||
}
|
||||
|
||||
eventComponent.isPrivate = eventObject.isPrivate
|
||||
eventComponent.isCalendarPending = eventObject.isCalendarPending
|
||||
eventComponent.comment = eventObject.comment
|
||||
|
||||
@ -22,6 +22,7 @@
|
||||
import { translate as t } from '@nextcloud/l10n'
|
||||
import { getDefaultCategories } from '../defaults/defaultCategories.js'
|
||||
|
||||
|
||||
/**
|
||||
* Gets all supported RFC properties
|
||||
*
|
||||
@ -145,7 +146,7 @@ const getRFCProperties = () => {
|
||||
readableName: t('calendar', 'Type d\'absence'),
|
||||
placeholder: t('calendar', 'Type d\'absence'),
|
||||
},
|
||||
|
||||
|
||||
embalmers: {
|
||||
readableName: t('calendar', 'Embalmers'),
|
||||
icon: 'Human',
|
||||
@ -156,6 +157,7 @@ const getRFCProperties = () => {
|
||||
tagPlaceholder: t('calendar', 'Choose thanatopracteur'),
|
||||
options: [],
|
||||
},
|
||||
|
||||
|
||||
embalmer: {
|
||||
readableName: t('calendar', 'Embalmer'),
|
||||
@ -181,21 +183,7 @@ const getRFCProperties = () => {
|
||||
placeholder: t('calendar', 'Commentaires'),
|
||||
tagPlaceholder: t('calendar', 'Commentaires'),
|
||||
options: [],
|
||||
defaultNumberOfRows: 4,
|
||||
},
|
||||
|
||||
lieuDeces: {
|
||||
readableName: t('calendar', 'Lieu du décès'),
|
||||
placeholder: t('calendar', 'Lieu du décès'),
|
||||
icon: 'MapMarker',
|
||||
type: 'text',
|
||||
},
|
||||
|
||||
dateNaissance: {
|
||||
readableName: t('calendar', 'Date de naissance'),
|
||||
placeholder: t('calendar', 'Date de naissance'),
|
||||
icon: 'Tag',
|
||||
type: 'date',
|
||||
defaultNumberOfRows: 4
|
||||
},
|
||||
}
|
||||
}
|
||||
|
||||
@ -285,14 +285,13 @@ const mutations = {
|
||||
calendarObjectInstance.eventComponent.endDate.addDuration(DurationValue.fromSeconds(60 * 60 * 24))
|
||||
}
|
||||
},
|
||||
|
||||
|
||||
/**
|
||||
* Is private
|
||||
*
|
||||
* @param {object} state The Vuex state
|
||||
* @param {object} data The destructuring object
|
||||
* @param {object} data.calendarObjectInstance The calendarObjectInstance object
|
||||
* @param data.isPrivate
|
||||
*/
|
||||
toggleIsPrivate(state, { calendarObjectInstance, isPrivate }) {
|
||||
calendarObjectInstance.eventComponent.isPrivate = isPrivate
|
||||
@ -404,40 +403,6 @@ const mutations = {
|
||||
calendarObjectInstance.embalmer = embalmer
|
||||
},
|
||||
|
||||
/**
|
||||
* Change the lieu de décès of an event
|
||||
*
|
||||
* @param {object} state The Vuex state
|
||||
* @param {object} data The destructuring object
|
||||
* @param {object} data.calendarObjectInstance The calendarObjectInstance object
|
||||
* @param {string} data.lieuDeces New lieu de décès to set
|
||||
*/
|
||||
changeLieuDeces(state, { calendarObjectInstance, lieuDeces }) {
|
||||
calendarObjectInstance.eventComponent.deleteAllProperties('LIEUDECES')
|
||||
if (lieuDeces && lieuDeces.trim() !== '') {
|
||||
const lieuDecesProperty = new Property('LIEUDECES', lieuDeces)
|
||||
calendarObjectInstance.eventComponent.addProperty(lieuDecesProperty)
|
||||
}
|
||||
calendarObjectInstance.lieuDeces = lieuDeces
|
||||
},
|
||||
|
||||
/**
|
||||
* Change the date de naissance of an event
|
||||
*
|
||||
* @param {object} state The Vuex state
|
||||
* @param {object} data The destructuring object
|
||||
* @param {object} data.calendarObjectInstance The calendarObjectInstance object
|
||||
* @param {string} data.dateNaissance New date de naissance to set
|
||||
*/
|
||||
changeDateNaissance(state, { calendarObjectInstance, dateNaissance }) {
|
||||
calendarObjectInstance.eventComponent.deleteAllProperties('DATENAISSANCE')
|
||||
if (dateNaissance && dateNaissance.trim() !== '') {
|
||||
const dateNaissanceProperty = new Property('DATENAISSANCE', dateNaissance)
|
||||
calendarObjectInstance.eventComponent.addProperty(dateNaissanceProperty)
|
||||
}
|
||||
calendarObjectInstance.dateNaissance = dateNaissance
|
||||
},
|
||||
|
||||
/**
|
||||
* Change the absence type of an event
|
||||
*
|
||||
@ -445,7 +410,6 @@ const mutations = {
|
||||
* @param {object} data The destructuring object
|
||||
* @param {object} data.calendarObjectInstance The calendarObjectInstance object
|
||||
* @param {string} data.embalmer New embalmer to set
|
||||
* @param data.absenceType
|
||||
*/
|
||||
changeAbsenceType(state, { calendarObjectInstance, absenceType }) {
|
||||
calendarObjectInstance.eventComponent.absenceType = absenceType ?? null
|
||||
@ -1822,14 +1786,12 @@ const actions = {
|
||||
let client = eventComponent.client;
|
||||
|
||||
let additionalFieldWasUpdated =
|
||||
eventComponent.client != null ||
|
||||
eventComponent.client != null ||
|
||||
eventComponent.isPrivate != null ||
|
||||
eventComponent.comment != null ||
|
||||
eventComponent.isLeave != null ||
|
||||
eventComponent.absenceType ||
|
||||
eventComponent.isCalendarPending != null ||
|
||||
state.calendarObjectInstance.lieuDeces != null ||
|
||||
state.calendarObjectInstance.dateNaissance != null;
|
||||
eventComponent.absenceType ||
|
||||
eventComponent.isCalendarPending != null;
|
||||
if (eventComponent.isDirty() || additionalFieldWasUpdated) {
|
||||
const isForkedItem = eventComponent.primaryItem !== null
|
||||
let original = null
|
||||
|
||||
@ -101,29 +101,8 @@
|
||||
@update-start-timezone="updateStartTimezone"
|
||||
@update-end-date="updateEndDate"
|
||||
@update-end-timezone="updateEndTimezone"
|
||||
@toggle-all-day="toggleAllDay" />
|
||||
@toggle-all-day="toggleAllDay"/>
|
||||
|
||||
<!-- Lieu du décès - plus petit -->
|
||||
<PropertyTitle class="property-lieu-deces property-small property-spaced"
|
||||
:is-read-only="isReadOnly"
|
||||
:prop-model="rfcProps.lieuDeces"
|
||||
:value="lieuDeces"
|
||||
:placeholder="'Lieu du décès'"
|
||||
type="text"
|
||||
@update:value="updateLieuDeces" />
|
||||
|
||||
<!-- Date de naissance avec libellé -->
|
||||
<div class="field-with-label">
|
||||
<label class="field-label">Date de naissance</label>
|
||||
<PropertyTitle class="property-date-naissance property-small"
|
||||
:is-read-only="isReadOnly"
|
||||
:prop-model="rfcProps.dateNaissance"
|
||||
:value="dateNaissance"
|
||||
:placeholder="'Date de naissance'"
|
||||
type="date"
|
||||
title="Saisissez la date de naissance du défunt"
|
||||
@update:value="updateDateNaissance" />
|
||||
</div>
|
||||
|
||||
<div style='margin-top: 13px; display:flex ;width: 81%;'>
|
||||
<div style='width:100%'>
|
||||
@ -910,26 +889,4 @@ export default {
|
||||
padding: 0 20px;
|
||||
}
|
||||
}
|
||||
|
||||
.property-small {
|
||||
max-width: 250px;
|
||||
}
|
||||
|
||||
.field-with-label {
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
gap: 4px;
|
||||
margin-bottom: 10px;
|
||||
}
|
||||
|
||||
.field-label {
|
||||
font-weight: 500;
|
||||
font-size: 14px;
|
||||
color: #333;
|
||||
margin-bottom: 2px;
|
||||
}
|
||||
|
||||
.property-spaced {
|
||||
margin-top: 15px;
|
||||
}
|
||||
</style>
|
||||
|
||||
@ -22,13 +22,15 @@
|
||||
-->
|
||||
|
||||
<template>
|
||||
<Popover ref="popover"
|
||||
<Popover
|
||||
ref="popover"
|
||||
:shown="showPopover"
|
||||
:auto-hide="false"
|
||||
:placement="placement"
|
||||
:boundary="boundaryElement"
|
||||
popover-base-class="event-popover"
|
||||
:triggers="[]">
|
||||
:triggers="[]"
|
||||
>
|
||||
<div class="event-popover__inner">
|
||||
<template v-if="isLoading && !isSaving">
|
||||
<PopoverLoadingIndicator />
|
||||
@ -46,8 +48,10 @@
|
||||
</Actions>
|
||||
</div>
|
||||
|
||||
<EmptyContent :name="$t('calendar', 'Event does not exist')"
|
||||
:description="error">
|
||||
<EmptyContent
|
||||
:name="$t('calendar', 'Event does not exist')"
|
||||
:description="error"
|
||||
>
|
||||
<template #icon>
|
||||
<CalendarBlank :size="20" decorative />
|
||||
</template>
|
||||
@ -57,22 +61,28 @@
|
||||
<template v-else>
|
||||
<div class="event-popover__top-right-actions">
|
||||
<Actions v-if="!isLoading && !isError && !isNew" :force-menu="true">
|
||||
<ActionLink v-if="!hideEventExport && hasDownloadURL"
|
||||
:href="downloadURL">
|
||||
<ActionLink
|
||||
v-if="!hideEventExport && hasDownloadURL"
|
||||
:href="downloadURL"
|
||||
>
|
||||
<template #icon>
|
||||
<Download :size="20" decorative />
|
||||
</template>
|
||||
{{ $t("calendar", "Export") }}
|
||||
</ActionLink>
|
||||
<ActionButton v-if="!canCreateRecurrenceException && !isReadOnly"
|
||||
@click="duplicateEvent()">
|
||||
<ActionButton
|
||||
v-if="!canCreateRecurrenceException && !isReadOnly"
|
||||
@click="duplicateEvent()"
|
||||
>
|
||||
<template #icon>
|
||||
<ContentDuplicate :size="20" decorative />
|
||||
</template>
|
||||
{{ $t("calendar", "Duplicate") }}
|
||||
</ActionButton>
|
||||
<ActionButton v-if="canDelete && !canCreateRecurrenceException"
|
||||
@click="deleteAndLeave(false)">
|
||||
<ActionButton
|
||||
v-if="canDelete && !canCreateRecurrenceException"
|
||||
@click="deleteAndLeave(false)"
|
||||
>
|
||||
<template #icon>
|
||||
<Delete :size="20" decorative />
|
||||
</template>
|
||||
@ -107,162 +117,160 @@
|
||||
</Actions>
|
||||
</div>
|
||||
|
||||
<!-- Zone de contenu scrollable -->
|
||||
<div class="popover-content-wrapper">
|
||||
<CalendarPickerHeader :value="selectedCalendar"
|
||||
:calendars="calendars"
|
||||
:is-read-only="isReadOnlyOrViewing || !canModifyCalendar"
|
||||
@update:value="changeCalendar" />
|
||||
<CalendarPickerHeader
|
||||
:value="selectedCalendar"
|
||||
:calendars="calendars"
|
||||
:is-read-only="isReadOnlyOrViewing || !canModifyCalendar"
|
||||
@update:value="changeCalendar"
|
||||
/>
|
||||
|
||||
<PropertyTitle :value="titleOrPlaceholder"
|
||||
:is-read-only="isReadOnlyOrViewing"
|
||||
@update:value="updateTitle" />
|
||||
<PropertyTitle
|
||||
:value="titleOrPlaceholder"
|
||||
:is-read-only="isReadOnlyOrViewing"
|
||||
@update:value="updateTitle"
|
||||
/>
|
||||
|
||||
<PropertyTitleTimePicker :start-date="startDate"
|
||||
:start-timezone="startTimezone"
|
||||
:end-date="endDate"
|
||||
:end-timezone="endTimezone"
|
||||
:is-all-day="isAllDay"
|
||||
:is-read-only="isReadOnlyOrViewing"
|
||||
:can-modify-all-day="canModifyAllDay"
|
||||
:user-timezone="currentUserTimezone"
|
||||
@update-start-date="updateStartDate"
|
||||
@update-start-timezone="updateStartTimezone"
|
||||
@update-end-date="updateEndDate"
|
||||
@update-end-timezone="updateEndTimezone"
|
||||
@toggle-all-day="toggleAllDay" />
|
||||
<PropertyTitleTimePicker
|
||||
:start-date="startDate"
|
||||
:start-timezone="startTimezone"
|
||||
:end-date="endDate"
|
||||
:end-timezone="endTimezone"
|
||||
:is-all-day="isAllDay"
|
||||
:is-read-only="isReadOnlyOrViewing"
|
||||
:can-modify-all-day="canModifyAllDay"
|
||||
:user-timezone="currentUserTimezone"
|
||||
@update-start-date="updateStartDate"
|
||||
@update-start-timezone="updateStartTimezone"
|
||||
@update-end-date="updateEndDate"
|
||||
@update-end-timezone="updateEndTimezone"
|
||||
@toggle-all-day="toggleAllDay"
|
||||
/>
|
||||
|
||||
<!-- Lieu du décès - plus petit -->
|
||||
<PropertyTitle class="property-lieu-deces property-small"
|
||||
:is-read-only="isReadOnly"
|
||||
:prop-model="rfcProps.lieuDeces"
|
||||
:value="lieuDeces"
|
||||
:placeholder="'Lieu du décès'"
|
||||
type="text"
|
||||
@update:value="updateLieuDeces" />
|
||||
|
||||
<!-- Date de naissance avec libellé -->
|
||||
<div class="field-with-label">
|
||||
<label class="field-label">Date de naissance</label>
|
||||
<PropertyTitle class="property-date-naissance property-small"
|
||||
<div style='display:flex ;margin-left: 7%;'>
|
||||
<div style='width:70%'>
|
||||
<PropertySelectAbsenceType
|
||||
:value="absenceType"
|
||||
:is-read-only="isReadOnly"
|
||||
:prop-model="rfcProps.dateNaissance"
|
||||
:value="dateNaissance"
|
||||
:placeholder="'Date de naissance'"
|
||||
type="date"
|
||||
title="Saisissez la date de naissance du défunt"
|
||||
@update:value="updateDateNaissance" />
|
||||
:prop-model="rfcProps.absenceType"
|
||||
:noWrap='true'
|
||||
sle
|
||||
@update:value="updateAbsenceType" />
|
||||
</div>
|
||||
|
||||
<div style='display:flex ;margin-left: 7%;'>
|
||||
<div style='width:70%'>
|
||||
<PropertySelectAbsenceType
|
||||
:value="absenceType"
|
||||
:is-read-only="isReadOnly"
|
||||
:prop-model="rfcProps.absenceType"
|
||||
:noWrap='true'
|
||||
@update:value="updateAbsenceType" />
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<PropertySelectClient
|
||||
class="property-location"
|
||||
url="/apps/gestion/ajaxGetClientsName"
|
||||
<!-- <div style='width:30% ;margin-top: -11px;'>
|
||||
<PropertyIsPrivate
|
||||
:is-read-only="isReadOnly"
|
||||
:prop-model="rfcProps.clients"
|
||||
:value="client"
|
||||
:linkify-links="true"
|
||||
@update:value="updateClient"
|
||||
/>
|
||||
|
||||
<PropertySelectLieu
|
||||
class="property-location"
|
||||
url="/apps/gestion/ajaxGetLieux"
|
||||
:is-read-only="isReadOnly"
|
||||
:prop-model="rfcProps.locations"
|
||||
:value="location"
|
||||
:linkify-links="true"
|
||||
@update:value="updateLocation"
|
||||
/>
|
||||
|
||||
<PropertySelectArticle
|
||||
:is-read-only="isReadOnlyOrViewing"
|
||||
url="/apps/gestion/ajaxGetProduits?orderDirection=ASC"
|
||||
:prop-model="rfcProps.articles"
|
||||
:value="description"
|
||||
:linkify-links="true"
|
||||
@add-single-value="addArticle"
|
||||
@remove-single-value="removeArticle"
|
||||
/>
|
||||
|
||||
<PropertyText
|
||||
:is-read-only="isReadOnly"
|
||||
:prop-model="rfcProps.comment"
|
||||
:value="comment"
|
||||
:linkify-links="false"
|
||||
@update:value="updateComment"
|
||||
/>
|
||||
|
||||
<InviteesList
|
||||
class="event-popover__invitees"
|
||||
:hide-if-empty="true"
|
||||
:hide-buttons="true"
|
||||
:hide-errors="true"
|
||||
:show-header="true"
|
||||
:is-read-only="isReadOnlyOrViewing"
|
||||
:is-shared-with-me="isSharedWithMe"
|
||||
:calendar-object-instance="calendarObjectInstance"
|
||||
:limit="3"
|
||||
/>
|
||||
|
||||
<InvitationResponseButtons
|
||||
v-if="isViewedByAttendee && isViewing"
|
||||
class="event-popover__response-buttons"
|
||||
:attendee="userAsAttendee"
|
||||
:calendar-id="calendarId"
|
||||
@close="closeEditorAndSkipAction"
|
||||
/>
|
||||
:is-private="isPrivate"
|
||||
@toggle-is-private="toggleIsPrivate"/>
|
||||
</div> -->
|
||||
|
||||
</div>
|
||||
|
||||
<!-- Zone des boutons fixes -->
|
||||
<div class="popover-buttons-wrapper">
|
||||
<SaveButtons
|
||||
v-if="!isWidget"
|
||||
class="event-popover__buttons"
|
||||
:can-create-recurrence-exception="canCreateRecurrenceException"
|
||||
:is-new="isNew"
|
||||
:is-read-only="isReadOnlyOrViewing"
|
||||
:force-this-and-all-future="forceThisAndAllFuture"
|
||||
:show-more-button="true"
|
||||
:more-button-type="isViewing ? 'tertiary' : undefined"
|
||||
:grow-horizontally="!isViewing && canCreateRecurrenceException"
|
||||
:disabled="isSaving"
|
||||
:is-calendar-pending="isCalendarPending"
|
||||
@save-this-only="saveAndView(false)"
|
||||
@save-this-and-all-future="saveAndView(true)"
|
||||
@show-more="showMore"
|
||||
@save-pending-calendar-event="saveAsPendingCalendarEvent"
|
||||
<!-- <PropertyIsLeave
|
||||
:is-read-only="isReadOnlyOrViewing"
|
||||
:is-leave="isLeave"
|
||||
@toggle-is-leave="toggleIsLeave"
|
||||
/> -->
|
||||
|
||||
<!-- <PropertyIsCalendarPending
|
||||
:is-read-only="isReadOnlyOrViewing"
|
||||
:is-calendar-pending="isCalendarPending"
|
||||
@toggle-is-calendar-pending="toggleIsCalendarPending" /> -->
|
||||
|
||||
<PropertySelectClient
|
||||
class="property-location"
|
||||
url="/apps/gestion/ajaxGetClientsName"
|
||||
:is-read-only="isReadOnly"
|
||||
:prop-model="rfcProps.clients"
|
||||
:value="client"
|
||||
:linkify-links="true"
|
||||
@update:value="updateClient"
|
||||
/>
|
||||
|
||||
<PropertySelectLieu
|
||||
class="property-location"
|
||||
url="/apps/gestion/ajaxGetLieux"
|
||||
:is-read-only="isReadOnly"
|
||||
:prop-model="rfcProps.locations"
|
||||
:value="location"
|
||||
:linkify-links="true"
|
||||
@update:value="updateLocation"
|
||||
/>
|
||||
|
||||
<PropertySelectArticle
|
||||
:is-read-only="isReadOnlyOrViewing"
|
||||
url="/apps/gestion/ajaxGetProduits?orderDirection=ASC"
|
||||
:prop-model="rfcProps.articles"
|
||||
:value="description"
|
||||
:linkify-links="true"
|
||||
@add-single-value="addArticle"
|
||||
@remove-single-value="removeArticle"
|
||||
/>
|
||||
|
||||
<PropertyText
|
||||
:is-read-only="isReadOnly"
|
||||
:prop-model="rfcProps.comment"
|
||||
:value="comment"
|
||||
:linkify-links="false"
|
||||
@update:value="updateComment"
|
||||
/>
|
||||
|
||||
<InviteesList
|
||||
class="event-popover__invitees"
|
||||
:hide-if-empty="true"
|
||||
:hide-buttons="true"
|
||||
:hide-errors="true"
|
||||
:show-header="true"
|
||||
:is-read-only="isReadOnlyOrViewing"
|
||||
:is-shared-with-me="isSharedWithMe"
|
||||
:calendar-object-instance="calendarObjectInstance"
|
||||
:limit="3"
|
||||
/>
|
||||
|
||||
<InvitationResponseButtons
|
||||
v-if="isViewedByAttendee && isViewing"
|
||||
class="event-popover__response-buttons"
|
||||
:attendee="userAsAttendee"
|
||||
:calendar-id="calendarId"
|
||||
@close="closeEditorAndSkipAction"
|
||||
/>
|
||||
|
||||
|
||||
<SaveButtons
|
||||
v-if="!isWidget"
|
||||
class="event-popover__buttons"
|
||||
:can-create-recurrence-exception="canCreateRecurrenceException"
|
||||
:is-new="isNew"
|
||||
:is-read-only="isReadOnlyOrViewing"
|
||||
:force-this-and-all-future="forceThisAndAllFuture"
|
||||
:show-more-button="true"
|
||||
:more-button-type="isViewing ? 'tertiary' : undefined"
|
||||
:grow-horizontally="!isViewing && canCreateRecurrenceException"
|
||||
:disabled="isSaving"
|
||||
:is-calendar-pending="isCalendarPending"
|
||||
@save-this-only="saveAndView(false)"
|
||||
@save-this-and-all-future="saveAndView(true)"
|
||||
@show-more="showMore"
|
||||
@save-pending-calendar-event="saveAsPendingCalendarEvent"
|
||||
>
|
||||
<NcButton
|
||||
@click="viewDefunt"
|
||||
v-if="defuntUrl"
|
||||
:type="undefined"
|
||||
:class="'d-flex w-max-content'"
|
||||
>
|
||||
<NcButton
|
||||
@click="viewDefunt"
|
||||
v-if="defuntUrl"
|
||||
:type="undefined"
|
||||
:class="'d-flex w-max-content'"
|
||||
>
|
||||
Voir le defunt
|
||||
</NcButton>
|
||||
<NcButton
|
||||
v-if="!isReadOnly && isViewing"
|
||||
:type="isViewedByAttendee ? 'tertiary' : undefined"
|
||||
@click="isViewing = false"
|
||||
>
|
||||
<template #icon>
|
||||
<EditIcon :size="20" />
|
||||
</template>
|
||||
{{ $t("calendar", "Edit") }}
|
||||
</NcButton>
|
||||
</SaveButtons>
|
||||
</div>
|
||||
Voir le defunt
|
||||
</NcButton>
|
||||
<NcButton
|
||||
v-if="!isReadOnly && isViewing"
|
||||
:type="isViewedByAttendee ? 'tertiary' : undefined"
|
||||
@click="isViewing = false"
|
||||
>
|
||||
<template #icon>
|
||||
<EditIcon :size="20" />
|
||||
</template>
|
||||
{{ $t("calendar", "Edit") }}
|
||||
</NcButton>
|
||||
</SaveButtons>
|
||||
</template>
|
||||
</div>
|
||||
</Popover>
|
||||
@ -289,7 +297,7 @@ import InvitationResponseButtons from "../components/Editor/InvitationResponseBu
|
||||
import CalendarPickerHeader from "../components/Editor/CalendarPickerHeader.vue";
|
||||
import InviteesList from "../components/Editor/Invitees/InviteesList.vue";
|
||||
|
||||
import CalendarBlank from 'vue-material-design-icons/CalendarBlank.vue';
|
||||
import CalendarBlank from "vue-material-design-icons/CalendarBlank.vue";
|
||||
import Close from "vue-material-design-icons/Close.vue";
|
||||
import Delete from "vue-material-design-icons/Delete.vue";
|
||||
import Download from "vue-material-design-icons/Download.vue";
|
||||
@ -353,7 +361,7 @@ export default {
|
||||
boundaryElement: null,
|
||||
isVisible: true,
|
||||
isViewing: true,
|
||||
defuntUrl: undefined
|
||||
defuntUrl: undefined,
|
||||
};
|
||||
},
|
||||
computed: {
|
||||
@ -599,148 +607,7 @@ export default {
|
||||
},
|
||||
viewDefunt() {
|
||||
window.open(this.defuntUrl, "_blank");
|
||||
}
|
||||
},
|
||||
},
|
||||
};
|
||||
</script>
|
||||
|
||||
<style scoped>
|
||||
.property-small {
|
||||
max-width: 250px;
|
||||
}
|
||||
|
||||
.field-with-label {
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
gap: 4px;
|
||||
margin-bottom: 10px;
|
||||
}
|
||||
|
||||
.field-label {
|
||||
font-weight: 500;
|
||||
font-size: 14px;
|
||||
color: #333;
|
||||
margin-bottom: 2px;
|
||||
}
|
||||
|
||||
/* Structure du popover - CSS SCOPED */
|
||||
:deep(.event-popover) {
|
||||
max-height: calc(100vh - 80px) !important;
|
||||
min-width: 500px !important;
|
||||
display: flex !important;
|
||||
flex-direction: column !important;
|
||||
left: 50% !important;
|
||||
transform: translateX(-50%) !important;
|
||||
}
|
||||
|
||||
:deep(.event-popover__inner) {
|
||||
display: flex !important;
|
||||
flex-direction: column !important;
|
||||
height: 100% !important;
|
||||
max-height: calc(100vh - 80px) !important;
|
||||
overflow: hidden !important;
|
||||
}
|
||||
|
||||
/* Zone de contenu scrollable */
|
||||
.popover-content-wrapper {
|
||||
flex: 1 1 auto !important;
|
||||
overflow-y: auto !important;
|
||||
padding: 15px !important;
|
||||
min-height: 0 !important;
|
||||
}
|
||||
|
||||
/* Zone des boutons fixes */
|
||||
.popover-buttons-wrapper {
|
||||
flex: 0 0 auto !important;
|
||||
border-top: 1px solid #e0e0e0 !important;
|
||||
background: white !important;
|
||||
padding: 15px !important;
|
||||
margin: 0 !important;
|
||||
position: relative !important;
|
||||
bottom: 0 !important;
|
||||
width: 100% !important;
|
||||
box-shadow: 0 -2px 8px rgba(0,0,0,0.1) !important;
|
||||
z-index: 1000 !important;
|
||||
}
|
||||
|
||||
:deep(.event-popover__buttons) {
|
||||
margin: 0 !important;
|
||||
padding: 0 !important;
|
||||
}
|
||||
</style>
|
||||
|
||||
<!-- CSS GLOBAL pour forcer absolument tout -->
|
||||
<style>
|
||||
/* CSS GLOBAL - SOLUTION BRUTALE POUR FORCER */
|
||||
.event-popover {
|
||||
max-height: calc(100vh - 80px) !important;
|
||||
min-width: 500px !important;
|
||||
max-width: calc(100vw - 350px) !important; /* Évite le débordement à droite */
|
||||
display: flex !important;
|
||||
flex-direction: column !important;
|
||||
/* Forcer le positionnement pour éviter les débordements */
|
||||
position: fixed !important;
|
||||
top: auto !important;
|
||||
bottom: auto !important;
|
||||
left: 320px !important; /* Position fixe après la sidebar */
|
||||
right: auto !important;
|
||||
z-index: 10000 !important;
|
||||
}
|
||||
|
||||
/* S'assurer que le popover ne sort jamais de l'écran */
|
||||
.event-popover[data-popper-placement] {
|
||||
left: 320px !important;
|
||||
right: auto !important;
|
||||
max-width: calc(100vw - 350px) !important;
|
||||
}
|
||||
|
||||
/* Si pas assez d'espace à droite, positionner à gauche de la sidebar */
|
||||
@media (max-width: 1200px) {
|
||||
.event-popover {
|
||||
left: 20px !important;
|
||||
max-width: 280px !important;
|
||||
}
|
||||
}
|
||||
|
||||
.event-popover .event-popover__inner {
|
||||
display: flex !important;
|
||||
flex-direction: column !important;
|
||||
height: 100% !important;
|
||||
max-height: calc(100vh - 80px) !important;
|
||||
overflow: hidden !important;
|
||||
}
|
||||
|
||||
.event-popover .popover-buttons-wrapper {
|
||||
position: sticky !important;
|
||||
bottom: 0 !important;
|
||||
background: white !important;
|
||||
border-top: 1px solid #ddd !important;
|
||||
padding: 15px !important;
|
||||
z-index: 9999 !important;
|
||||
box-shadow: 0 -2px 10px rgba(0,0,0,0.2) !important;
|
||||
flex: 0 0 auto !important;
|
||||
margin: 0 !important;
|
||||
width: 100% !important;
|
||||
}
|
||||
|
||||
.event-popover .popover-content-wrapper {
|
||||
flex: 1 1 auto !important;
|
||||
overflow-y: auto !important;
|
||||
min-height: 0 !important;
|
||||
padding: 15px !important;
|
||||
}
|
||||
|
||||
/* Forcer une largeur minimale convenable */
|
||||
.event-popover .popover__wrapper,
|
||||
.event-popover .popover__inner {
|
||||
min-width: 500px !important;
|
||||
max-height: calc(100vh - 80px) !important;
|
||||
}
|
||||
|
||||
/* Centrer verticalement le popover */
|
||||
.event-popover {
|
||||
top: 50% !important;
|
||||
transform: translateY(-50%) !important;
|
||||
}
|
||||
</style>
|
||||
|
||||
|
||||
@ -99,7 +99,6 @@ return [
|
||||
|
||||
// generation attestation pacemaker, rapport de soins, de bijoux
|
||||
['name' => 'page#saveAttestationPacemaker', 'url' => '/saveAttestationPacemaker', 'verb' => 'POST'],
|
||||
['name' => 'page#saveAttestationAbsentPacemaker', 'url' => '/saveAttestationAbsentPacemaker', 'verb' => 'POST'],
|
||||
['name' => 'page#saveRapportSoin', 'url' => '/saveRapportSoin', 'verb' => 'POST'],
|
||||
['name' => 'page#saveRapportBijoux', 'url' => '/saveRapportBijoux', 'verb' => 'POST'],
|
||||
|
||||
|
||||
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
@ -2028,268 +2028,265 @@ class PageController extends Controller
|
||||
}
|
||||
|
||||
/**
|
||||
* @NoAdminRequired
|
||||
* @NoCSRFRequired
|
||||
*/
|
||||
public function apiReloadFec()
|
||||
{
|
||||
$this->reloadFec();
|
||||
return new DataResponse("", 200, ['Content-Type' => 'application/json']);
|
||||
}
|
||||
* @NoAdminRequired
|
||||
* @NoCSRFRequired
|
||||
*/
|
||||
public function apiReloadFec() {
|
||||
$this->reloadFec();
|
||||
return new DataResponse("", 200, ['Content-Type' => 'application/json']);
|
||||
}
|
||||
|
||||
private function reloadFec()
|
||||
{
|
||||
$current_config = json_decode($this->myDb->getConfiguration($this->idNextcloud));
|
||||
$clean_folder = html_entity_decode($current_config[0]->path).'/';
|
||||
private function reloadFec(){
|
||||
$current_config = json_decode($this->myDb->getConfiguration($this->idNextcloud));
|
||||
$clean_folder = html_entity_decode($current_config[0]->path).'/';
|
||||
|
||||
try {
|
||||
try {
|
||||
$data_factures = array();
|
||||
$factures = json_decode($this->myDb->getFacturesListWithDependencies());
|
||||
foreach ($factures as $key => $facture) {
|
||||
$factureIsSingle = $facture->facture_type == FactureTypeConstant::TYPE_SINGLE;
|
||||
$facture_temp = array(
|
||||
'num' => $facture->num,
|
||||
'client' => $facture->entreprise,
|
||||
'nom_client' => $facture->nom,
|
||||
'date' => $facture->date,
|
||||
'date_facture' => $facture->date_paiement,
|
||||
'defunt' => $facture->nom_defunt,
|
||||
'montant_htc' => 0,
|
||||
'tva' => $current_config[0]->tva_default,
|
||||
'montant_tva' => 0,
|
||||
'montant_ttc' => 0,
|
||||
);
|
||||
if($factureIsSingle) {
|
||||
$produits = json_decode($this->getProduitsById($facture->id_devis));
|
||||
foreach ($produits as $key => $produit) {
|
||||
$htPrice = $produit->prix_unitaire;
|
||||
if($facture->fk_client_group_id != null || $facture->fk_client_group_id != 0) {
|
||||
$price = $this->myDb->getProductPriceByClientGroupId($facture->fk_client_group_id, $produit->id);
|
||||
if($price != null) {
|
||||
$htPrice = $price;
|
||||
}
|
||||
}
|
||||
$facture_temp['montant_htc'] += $htPrice * $produit->quantite;
|
||||
};
|
||||
$facture_temp['montant_tva'] = ($facture_temp['montant_htc'] * $facture_temp['tva']) / 100;
|
||||
$facture_temp['montant_ttc'] = $facture_temp['montant_tva'] + $facture_temp['montant_htc'];
|
||||
} else {
|
||||
$devis = $this->myDb->getDevisByFkFactureId($facture->id);
|
||||
$factureGroupIsRelatedToAnyDevis = $devis != null;
|
||||
$mentionFilters = [
|
||||
DevisMentionConstant::FACTURED,
|
||||
DevisMentionConstant::FACTURED_FORMATTED
|
||||
];
|
||||
try {
|
||||
try {
|
||||
$data_factures = array();
|
||||
$factures = json_decode($this->myDb->getFacturesListWithDependencies());
|
||||
foreach ($factures as $key => $facture) {
|
||||
$factureIsSingle = $facture->facture_type == FactureTypeConstant::TYPE_SINGLE;
|
||||
$facture_temp = array(
|
||||
'num' => $facture->num,
|
||||
'client' => $facture->entreprise,
|
||||
'nom_client' => $facture->nom,
|
||||
'date' => $facture->date,
|
||||
'date_facture' => $facture->date_paiement,
|
||||
'defunt' => $facture->nom_defunt,
|
||||
'montant_htc' => 0,
|
||||
'tva' => $current_config[0]->tva_default,
|
||||
'montant_tva' => 0,
|
||||
'montant_ttc' => 0,
|
||||
);
|
||||
if($factureIsSingle){
|
||||
$produits = json_decode($this->getProduitsById($facture->id_devis));
|
||||
foreach ($produits as $key => $produit) {
|
||||
$htPrice = $produit->prix_unitaire;
|
||||
if($facture->fk_client_group_id != null || $facture->fk_client_group_id != 0){
|
||||
$price = $this->myDb->getProductPriceByClientGroupId($facture->fk_client_group_id,$produit->id);
|
||||
if($price != null){
|
||||
$htPrice = $price;
|
||||
}
|
||||
}
|
||||
$facture_temp['montant_htc'] += $htPrice * $produit->quantite;
|
||||
};
|
||||
$facture_temp['montant_tva'] = ($facture_temp['montant_htc'] * $facture_temp['tva'])/100;
|
||||
$facture_temp['montant_ttc'] = $facture_temp['montant_tva'] + $facture_temp['montant_htc'];
|
||||
}
|
||||
else{
|
||||
$devis = $this->myDb->getDevisByFkFactureId($facture->id);
|
||||
$factureGroupIsRelatedToAnyDevis = $devis != null;
|
||||
$mentionFilters = [
|
||||
DevisMentionConstant::FACTURED,
|
||||
DevisMentionConstant::FACTURED_FORMATTED
|
||||
];
|
||||
|
||||
|
||||
$isFactureGroupForSingleClient = $facture->facture_client_id != null && $facture->facture_client_id != 0;
|
||||
if($isFactureGroupForSingleClient){
|
||||
$facture_temp["client"] = $facture->facture_client_entreprise;
|
||||
$facture_temp["nom_client"] = $facture->facture_client_name;
|
||||
|
||||
if(!$factureGroupIsRelatedToAnyDevis ){
|
||||
$devisList = $this->myDb->getDevisByClientIdAndMonthYear(
|
||||
$facture->facture_client_id,
|
||||
$facture->facture_month,
|
||||
$facture->facture_year,
|
||||
$mentionFilters
|
||||
);
|
||||
}
|
||||
}
|
||||
else{
|
||||
$facture_temp["client"] = $facture->group_code_comptable ??'-';
|
||||
$facture_temp["nom_client"] = $facture->facture_group_name;
|
||||
|
||||
$isFactureGroupForSingleClient = $facture->facture_client_id != null && $facture->facture_client_id != 0;
|
||||
if($isFactureGroupForSingleClient) {
|
||||
$facture_temp["client"] = $facture->facture_client_entreprise;
|
||||
$facture_temp["nom_client"] = $facture->facture_client_name;
|
||||
if(!$factureGroupIsRelatedToAnyDevis ){
|
||||
$devisList = $this->myDb->getDevisByClientGroupFacturationIdAndMonthYear(
|
||||
$facture->facture_client_group_facturation_id,
|
||||
$facture->facture_month,
|
||||
$facture->facture_year,
|
||||
[
|
||||
DevisMentionConstant::FACTURED,
|
||||
DevisMentionConstant::FACTURED_FORMATTED
|
||||
]
|
||||
);
|
||||
}
|
||||
}
|
||||
if($factureGroupIsRelatedToAnyDevis){
|
||||
$devisList = $this->myDb->getDevisByClientIdByFactureId($facture->id, $mentionFilters );
|
||||
}
|
||||
|
||||
if(!$factureGroupIsRelatedToAnyDevis) {
|
||||
$devisList = $this->myDb->getDevisByClientIdAndMonthYear(
|
||||
$facture->facture_client_id,
|
||||
$facture->facture_month,
|
||||
$facture->facture_year,
|
||||
$mentionFilters
|
||||
);
|
||||
}
|
||||
} else {
|
||||
$facture_temp["client"] = $facture->group_code_comptable ?? '-';
|
||||
$facture_temp["nom_client"] = $facture->facture_group_name;
|
||||
foreach($devisList as $currentDevis){
|
||||
$produits = json_decode($this->getProduitsById($currentDevis['id']));
|
||||
foreach ($produits as $key => $produit) {
|
||||
$htPrice = $produit->prix_unitaire;
|
||||
if($currentDevis["fk_client_group_id"] != null || $currentDevis["fk_client_group_id"] != 0){
|
||||
$price = $this->myDb->getProductPriceByClientGroupId($currentDevis["fk_client_group_id"],$produit->id);
|
||||
if($price != null){
|
||||
$htPrice = $price;
|
||||
}
|
||||
}
|
||||
$facture_temp['montant_htc'] += $htPrice * $produit->quantite;
|
||||
};
|
||||
}
|
||||
$facture_temp['montant_tva'] = ($facture_temp['montant_htc'] * $facture_temp['tva'])/100;
|
||||
$facture_temp['montant_ttc'] = $facture_temp['montant_tva'] + $facture_temp['montant_htc'];
|
||||
}
|
||||
|
||||
array_push($data_factures, $facture_temp);
|
||||
};
|
||||
$data_temp = array();
|
||||
foreach ($data_factures as $key => $facture) {
|
||||
$datesplit = explode('-', $facture['date_facture']);
|
||||
if($data_temp[strval($datesplit[0])]==NULL) {
|
||||
$data_temp[strval($datesplit[0])][strval($datesplit[1])] = array(0=>$facture);
|
||||
} else {
|
||||
if($data_temp[strval($datesplit[0])][strval($datesplit[1])]==NULL) {
|
||||
$data_temp[strval($datesplit[0])][strval($datesplit[1])] = array(0=>$facture);
|
||||
} else {
|
||||
array_push($data_temp[strval($datesplit[0])][strval($datesplit[1])], $facture);
|
||||
}
|
||||
}
|
||||
}
|
||||
$fec_headers_txt = [
|
||||
utf8_decode('JOURNALCODE'),
|
||||
utf8_decode('JOURNALLIB'),
|
||||
utf8_decode('ECRITURENUM'),
|
||||
utf8_decode('ECRITUREDATE'),
|
||||
utf8_decode('COMPTENUM'),
|
||||
utf8_decode('COMPTELIB'),
|
||||
utf8_decode('COMPAUXLIB'),
|
||||
utf8_decode('COMPAUXNUM'),
|
||||
utf8_decode('PIECEREF'),
|
||||
utf8_decode('PIECEDATE'),
|
||||
utf8_decode('ECRITURELIB'),
|
||||
utf8_decode('DEBIT'),
|
||||
utf8_decode('CREDIT'),
|
||||
utf8_decode('ECRITURELET'),
|
||||
utf8_decode('DATELET'),
|
||||
utf8_decode('VALIDDATE'),
|
||||
utf8_decode('MONTANTDEVISE'),
|
||||
utf8_decode('IDEVISE'),
|
||||
];
|
||||
//parcours annee
|
||||
foreach ($data_temp as $key_annee => $annee) {
|
||||
//parcours annee
|
||||
$_clean_folder = $clean_folder.'FEC/'.$key_annee.'/';
|
||||
try {
|
||||
$this->storage->newFolder($_clean_folder);
|
||||
} catch(\OCP\Files\NotPermittedException $e) { }
|
||||
foreach ($annee as $key_mois => $mois) {
|
||||
// Initialize FEC headers
|
||||
|
||||
$fec_temp_txt = implode(TAB1, $fec_headers_txt) . PHP_EOL . PHP_EOL;
|
||||
$fec_temp = implode(';', $fec_headers_txt) . "\n\n";
|
||||
|
||||
foreach ($mois as $key => $facture) {
|
||||
// Define FEC entry data
|
||||
$fec_entries = [
|
||||
[
|
||||
'journal' => 'VT',
|
||||
'journal_lib' => 'VENTES',
|
||||
'ecriturenum' => '',
|
||||
'date' => $facture['date_facture'],
|
||||
'compte' => $facture['client'],
|
||||
'libelle_compte' => $facture['client'],
|
||||
'compauxlib' => '',
|
||||
'compauxnum' => '',
|
||||
'piece' => $facture['num'],
|
||||
'piece_date' => '',
|
||||
'libelle_ecriture' => $facture['nom_client'],
|
||||
'debit' => $facture['montant_ttc'],
|
||||
'credit' => '0',
|
||||
'ecriture_lettrage' => '',
|
||||
'date_lettrage' => '',
|
||||
'valid_date' => '',
|
||||
'montant_devise' => '',
|
||||
'devise' => 'EUR',
|
||||
],
|
||||
[
|
||||
'journal' => 'VT',
|
||||
'journal_lib' => 'VENTES',
|
||||
'ecriturenum' => '',
|
||||
'date' => $facture['date_facture'],
|
||||
'compte' => '706000',
|
||||
'libelle_compte' => 'VENTES DE MARCHANDISES',
|
||||
'compauxlib' => '',
|
||||
'compauxnum' => '',
|
||||
'piece' => $facture['num'],
|
||||
'piece_date' => '',
|
||||
'libelle_ecriture' => $facture['client'],
|
||||
'debit' => '0',
|
||||
'credit' => $facture['montant_htc'],
|
||||
'ecriture_lettrage' => '',
|
||||
'date_lettrage' => '',
|
||||
'valid_date' => '',
|
||||
'montant_devise' => '',
|
||||
'devise' => 'EUR',
|
||||
],
|
||||
[
|
||||
'journal' => 'VT',
|
||||
'journal_lib' => 'VENTES',
|
||||
'ecriturenum' => '',
|
||||
'date' => $facture['date_facture'],
|
||||
'compte' => '445710',
|
||||
'compauxlib' => '',
|
||||
'compauxnum' => '',
|
||||
'libelle_compte' => '',
|
||||
'piece' => $facture['num'],
|
||||
'piece_date' => '',
|
||||
'libelle_ecriture' => $facture['client'],
|
||||
'debit' => '',
|
||||
'credit' => $facture['montant_tva'],
|
||||
'ecriture_lettrage' => '',
|
||||
'date_lettrage' => '',
|
||||
'valid_date' => '',
|
||||
'montant_devise' => '',
|
||||
'devise' => 'EUR',
|
||||
]
|
||||
];
|
||||
|
||||
// Generate FEC entries
|
||||
foreach ($fec_entries as $entry) {
|
||||
$fec_line_txt = [
|
||||
$entry['journal'], $entry['journal_lib'], $entry['ecriturenum'], $entry['date'],
|
||||
$entry['compte'], $entry['libelle_compte'],
|
||||
$entry['compauxlib'], $entry['compauxnum'],
|
||||
$entry['piece'], $entry['piece_date'],
|
||||
$entry['libelle_ecriture'], $entry['debit'],$entry['credit'],$entry['ecriture_lettrage'],
|
||||
$entry['date_lettrage'], $entry['valid_date'], $entry['montant_devise'], $entry['devise']
|
||||
];
|
||||
|
||||
$fec_line_csv = [
|
||||
$entry['journal'], $entry['journal_lib'], $entry['ecriturenum'], $entry['date'],
|
||||
$entry['compte'], $entry['libelle_compte'],
|
||||
$entry['compauxlib'], $entry['compauxnum'],
|
||||
$entry['piece'], $entry['piece_date'],
|
||||
$entry['libelle_ecriture'], $entry['debit'],$entry['credit'],$entry['ecriture_lettrage'],
|
||||
$entry['date_lettrage'], $entry['valid_date'], $entry['montant_devise'], $entry['devise']
|
||||
];
|
||||
|
||||
$fec_temp_txt .= implode(TAB1, $fec_line_txt) . PHP_EOL . PHP_EOL;
|
||||
$fec_temp .= implode(';', $fec_line_csv) . "\n\n";
|
||||
}
|
||||
}
|
||||
$ff = $_clean_folder.'FEC_'.$key_mois.'_'.$key_annee.'.csv';
|
||||
$this->storage->newFile($ff);
|
||||
$file = $this->storage->get($ff);
|
||||
$file->putContent($fec_temp);
|
||||
|
||||
if(!$factureGroupIsRelatedToAnyDevis) {
|
||||
$devisList = $this->myDb->getDevisByClientGroupFacturationIdAndMonthYear(
|
||||
$facture->facture_client_group_facturation_id,
|
||||
$facture->facture_month,
|
||||
$facture->facture_year,
|
||||
[
|
||||
DevisMentionConstant::FACTURED,
|
||||
DevisMentionConstant::FACTURED_FORMATTED
|
||||
]
|
||||
);
|
||||
}
|
||||
}
|
||||
if($factureGroupIsRelatedToAnyDevis) {
|
||||
$devisList = $this->myDb->getDevisByClientIdByFactureId($facture->id, $mentionFilters);
|
||||
}
|
||||
$ff_txt = $_clean_folder.'FEC_'.$key_mois.'_'.$key_annee.'.txt';
|
||||
$this->storage->newFile($ff_txt);
|
||||
$file_txt = $this->storage->get($ff_txt);
|
||||
$file_txt->putContent($fec_temp_txt);
|
||||
// $file->putContent(implode(';', array('Jane Smith', 'janesmith@example.com', '555-5678')) . "\n");
|
||||
}
|
||||
}
|
||||
|
||||
} catch(\OCP\Files\NotFoundException $e) { }
|
||||
|
||||
foreach($devisList as $currentDevis) {
|
||||
$produits = json_decode($this->getProduitsById($currentDevis['id']));
|
||||
foreach ($produits as $key => $produit) {
|
||||
$htPrice = $produit->prix_unitaire;
|
||||
if($currentDevis["fk_client_group_id"] != null || $currentDevis["fk_client_group_id"] != 0) {
|
||||
$price = $this->myDb->getProductPriceByClientGroupId($currentDevis["fk_client_group_id"], $produit->id);
|
||||
if($price != null) {
|
||||
$htPrice = $price;
|
||||
}
|
||||
}
|
||||
$facture_temp['montant_htc'] += $htPrice * $produit->quantite;
|
||||
};
|
||||
}
|
||||
$facture_temp['montant_tva'] = ($facture_temp['montant_htc'] * $facture_temp['tva']) / 100;
|
||||
$facture_temp['montant_ttc'] = $facture_temp['montant_tva'] + $facture_temp['montant_htc'];
|
||||
}
|
||||
|
||||
array_push($data_factures, $facture_temp);
|
||||
};
|
||||
$data_temp = array();
|
||||
foreach ($data_factures as $key => $facture) {
|
||||
$datesplit = explode('-', $facture['date_facture']);
|
||||
if($data_temp[strval($datesplit[0])] == null) {
|
||||
$data_temp[strval($datesplit[0])][strval($datesplit[1])] = array(0 => $facture);
|
||||
} else {
|
||||
if($data_temp[strval($datesplit[0])][strval($datesplit[1])] == null) {
|
||||
$data_temp[strval($datesplit[0])][strval($datesplit[1])] = array(0 => $facture);
|
||||
} else {
|
||||
array_push($data_temp[strval($datesplit[0])][strval($datesplit[1])], $facture);
|
||||
}
|
||||
}
|
||||
}
|
||||
$fec_headers_txt = [
|
||||
utf8_decode('JOURNALCODE'),
|
||||
utf8_decode('JOURNALLIB'),
|
||||
utf8_decode('ECRITURENUM'),
|
||||
utf8_decode('ECRITUREDATE'),
|
||||
utf8_decode('COMPTENUM'),
|
||||
utf8_decode('COMPTELIB'),
|
||||
utf8_decode('COMPAUXLIB'),
|
||||
utf8_decode('COMPAUXNUM'),
|
||||
utf8_decode('PIECEREF'),
|
||||
utf8_decode('PIECEDATE'),
|
||||
utf8_decode('ECRITURELIB'),
|
||||
utf8_decode('DEBIT'),
|
||||
utf8_decode('CREDIT'),
|
||||
utf8_decode('ECRITURELET'),
|
||||
utf8_decode('DATELET'),
|
||||
utf8_decode('VALIDDATE'),
|
||||
utf8_decode('MONTANTDEVISE'),
|
||||
utf8_decode('IDEVISE'),
|
||||
];
|
||||
//parcours annee
|
||||
foreach ($data_temp as $key_annee => $annee) {
|
||||
//parcours annee
|
||||
$_clean_folder = $clean_folder.'FEC/'.$key_annee.'/';
|
||||
try {
|
||||
$this->storage->newFolder($_clean_folder);
|
||||
} catch(\OCP\Files\NotPermittedException $e) {
|
||||
}
|
||||
foreach ($annee as $key_mois => $mois) {
|
||||
// Initialize FEC headers
|
||||
|
||||
$fec_temp_txt = implode(TAB1, $fec_headers_txt) . PHP_EOL . PHP_EOL;
|
||||
$fec_temp = implode(';', $fec_headers_txt) . "\n\n";
|
||||
|
||||
foreach ($mois as $key => $facture) {
|
||||
// Define FEC entry data
|
||||
$fec_entries = [
|
||||
[
|
||||
'journal' => 'VT',
|
||||
'journal_lib' => 'VENTES',
|
||||
'ecriturenum' => '',
|
||||
'date' => $facture['date_facture'],
|
||||
'compte' => $facture['client'],
|
||||
'libelle_compte' => $facture['client'],
|
||||
'compauxlib' => '',
|
||||
'compauxnum' => '',
|
||||
'piece' => $facture['num'],
|
||||
'piece_date' => '',
|
||||
'libelle_ecriture' => $facture['nom_client'],
|
||||
'debit' => $facture['montant_ttc'],
|
||||
'credit' => '0',
|
||||
'ecriture_lettrage' => '',
|
||||
'date_lettrage' => '',
|
||||
'valid_date' => '',
|
||||
'montant_devise' => '',
|
||||
'devise' => 'EUR',
|
||||
],
|
||||
[
|
||||
'journal' => 'VT',
|
||||
'journal_lib' => 'VENTES',
|
||||
'ecriturenum' => '',
|
||||
'date' => $facture['date_facture'],
|
||||
'compte' => '706000',
|
||||
'libelle_compte' => 'VENTES DE MARCHANDISES',
|
||||
'compauxlib' => '',
|
||||
'compauxnum' => '',
|
||||
'piece' => $facture['num'],
|
||||
'piece_date' => '',
|
||||
'libelle_ecriture' => $facture['client'],
|
||||
'debit' => '0',
|
||||
'credit' => $facture['montant_htc'],
|
||||
'ecriture_lettrage' => '',
|
||||
'date_lettrage' => '',
|
||||
'valid_date' => '',
|
||||
'montant_devise' => '',
|
||||
'devise' => 'EUR',
|
||||
],
|
||||
[
|
||||
'journal' => 'VT',
|
||||
'journal_lib' => 'VENTES',
|
||||
'ecriturenum' => '',
|
||||
'date' => $facture['date_facture'],
|
||||
'compte' => '445710',
|
||||
'compauxlib' => '',
|
||||
'compauxnum' => '',
|
||||
'libelle_compte' => '',
|
||||
'piece' => $facture['num'],
|
||||
'piece_date' => '',
|
||||
'libelle_ecriture' => $facture['client'],
|
||||
'debit' => '',
|
||||
'credit' => $facture['montant_tva'],
|
||||
'ecriture_lettrage' => '',
|
||||
'date_lettrage' => '',
|
||||
'valid_date' => '',
|
||||
'montant_devise' => '',
|
||||
'devise' => 'EUR',
|
||||
]
|
||||
];
|
||||
|
||||
// Generate FEC entries
|
||||
foreach ($fec_entries as $entry) {
|
||||
$fec_line_txt = [
|
||||
$entry['journal'], $entry['journal_lib'], $entry['ecriturenum'], $entry['date'],
|
||||
$entry['compte'], $entry['libelle_compte'],
|
||||
$entry['compauxlib'], $entry['compauxnum'],
|
||||
$entry['piece'], $entry['piece_date'],
|
||||
$entry['libelle_ecriture'], $entry['debit'],$entry['credit'],$entry['ecriture_lettrage'],
|
||||
$entry['date_lettrage'], $entry['valid_date'], $entry['montant_devise'], $entry['devise']
|
||||
];
|
||||
|
||||
$fec_line_csv = [
|
||||
$entry['journal'], $entry['journal_lib'], $entry['ecriturenum'], $entry['date'],
|
||||
$entry['compte'], $entry['libelle_compte'],
|
||||
$entry['compauxlib'], $entry['compauxnum'],
|
||||
$entry['piece'], $entry['piece_date'],
|
||||
$entry['libelle_ecriture'], $entry['debit'],$entry['credit'],$entry['ecriture_lettrage'],
|
||||
$entry['date_lettrage'], $entry['valid_date'], $entry['montant_devise'], $entry['devise']
|
||||
];
|
||||
|
||||
$fec_temp_txt .= implode(TAB1, $fec_line_txt) . PHP_EOL . PHP_EOL;
|
||||
$fec_temp .= implode(';', $fec_line_csv) . "\n\n";
|
||||
}
|
||||
}
|
||||
$ff = $_clean_folder.'FEC_'.$key_mois.'_'.$key_annee.'.csv';
|
||||
$this->storage->newFile($ff);
|
||||
$file = $this->storage->get($ff);
|
||||
$file->putContent($fec_temp);
|
||||
|
||||
$ff_txt = $_clean_folder.'FEC_'.$key_mois.'_'.$key_annee.'.txt';
|
||||
$this->storage->newFile($ff_txt);
|
||||
$file_txt = $this->storage->get($ff_txt);
|
||||
$file_txt->putContent($fec_temp_txt);
|
||||
// $file->putContent(implode(';', array('Jane Smith', 'janesmith@example.com', '555-5678')) . "\n");
|
||||
}
|
||||
}
|
||||
|
||||
} catch(\OCP\Files\NotFoundException $e) {
|
||||
}
|
||||
|
||||
} catch(\OCP\Files\NotPermittedException $e) {
|
||||
}
|
||||
}
|
||||
} catch(\OCP\Files\NotPermittedException $e) { }
|
||||
}
|
||||
|
||||
private function refreshFEC()
|
||||
{
|
||||
@ -2988,14 +2985,9 @@ class PageController extends Controller
|
||||
$pdf->Cell($pdf->GetPageWidth() - 30, 0, utf8_decode(html_entity_decode($defaultConfig[0]->nom).' '.html_entity_decode($defaultConfig[0]->prenom)), 0, 0, 'L');
|
||||
$pdf->setY($pdf->GetY() + 5);
|
||||
|
||||
$signatureExist = $this->signatureImageExists('sign.jpg');
|
||||
if($signatureExist) {
|
||||
$pdf->Image($this->defaultImagePath."sign.jpg", 13, $pdf->GetY() + 8, 55, 25);
|
||||
}
|
||||
|
||||
$signatureExist = $this->signatureImageExists('sign.png');
|
||||
if($signatureExist) {
|
||||
$pdf->Image($this->defaultImagePath."sign.png", 13, $pdf->GetY() + 40, 40, 15);
|
||||
$pdf->Image($this->defaultImagePath."sign.png", 13, $pdf->GetY(), 40, 15);
|
||||
}
|
||||
|
||||
$pdf->setY($pdf->GetY() - 5);
|
||||
@ -3201,14 +3193,9 @@ class PageController extends Controller
|
||||
$pdf->Cell($pdf->GetPageWidth() - 30, 0, utf8_decode(html_entity_decode($defaultConfig[0]->nom).' '.html_entity_decode($defaultConfig[0]->prenom)), 0, 0, 'L');
|
||||
$pdf->setY($pdf->GetY() + 5);
|
||||
|
||||
$signatureExist = $this->signatureImageExists('sign.jpg');
|
||||
if($signatureExist) {
|
||||
$pdf->Image($this->defaultImagePath."sign.jpg", 10, $pdf->GetY() + 5, 55, 25);
|
||||
}
|
||||
|
||||
$signatureExist = $this->signatureImageExists('sign.png');
|
||||
if ($signatureExist) {
|
||||
$pdf->Image($this->defaultImagePath."sign.png", 10, $pdf->GetY() + 35, 40, 15);
|
||||
$pdf->Image($this->defaultImagePath."sign.png", 10, $pdf->GetY(), 40, 15);
|
||||
}
|
||||
|
||||
$pdf->setY($pdf->GetY() - 5);
|
||||
@ -3662,29 +3649,6 @@ class PageController extends Controller
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* @NoAdminRequired
|
||||
* @NoCSRFRequired
|
||||
* @param int $defuntId
|
||||
*/
|
||||
|
||||
public function saveAttestationAbsentPacemaker($defuntId, $email = '')
|
||||
{
|
||||
|
||||
try {
|
||||
$careCertificateFilename = $this->certificateService->generatePacemakerAbsentCertificate($defuntId, $this->idNextcloud);
|
||||
if($careCertificateFilename != null && trim($email) != '') {
|
||||
//send email
|
||||
$this->sendAttachmentToClientByDefunt($defuntId, $careCertificateFilename, $email, "Retrait de pile", "Vous trouverez en pièce jointe l'attestation de retrait de pile ", true);
|
||||
|
||||
}
|
||||
return $careCertificateFilename;
|
||||
|
||||
} catch(\OCP\Files\NotFoundException $e) {
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* @NoAdminRequired
|
||||
* @NoCSRFRequired
|
||||
|
||||
@ -44,7 +44,7 @@ class Bdd
|
||||
"quantite", "date_paiement", "type_paiement", "id_devis", "reference", "description", "prix_unitaire", "legal_two", "path", "tva_default", "coefficient_ik",
|
||||
"mentions_default", "version", "mentions", "comment", "status_paiement", "devise", "auto_invoice_number", "changelog", "format", "comment", "user_id",
|
||||
"facture_prefixe", "arrivee", "depart", "latitude", "longitude", "id_lieu", "rang", "mois", "annee", "id_trajet", "commentaire","source",
|
||||
"date_habilitation", "sexe", "observations_generales", "ref_pacemaker", "id_defunt", "article_id", "corpulence", "lieu_deces",
|
||||
"date_habilitation", "sexe", "observations_generales", "ref_pacemaker", "id_defunt", "article_id", "corpulence",
|
||||
"date_naissance", "heure_debut", "heure_fin", "rigidite", "lividite", "observations_corps", "acces", "acces_recherche", "acces_etat",
|
||||
"injection", "injection_diffusion", "injection_qte", "preinjection", "preinjection_qte", "coinjection", "coinjection_qte",
|
||||
"drainage", "drainage_qte", "drainage_etat", "ponction", "ponction_qte", "cavite", "cavite_qte", "desinfection", "lavage",
|
||||
@ -740,7 +740,7 @@ class Bdd
|
||||
|
||||
public function getDefunts($idNextcloud, $isUserThanatoOnly = false)
|
||||
{
|
||||
$sql = "SELECT ".$this->tableprefix."defunt.id, ".$this->tableprefix."defunt.nom, ".$this->tableprefix."defunt.date_naissance, ".$this->tableprefix."defunt.ref_pacemaker, ".$this->tableprefix."defunt.sexe, ".$this->tableprefix."defunt.lieu_deces as lieu_deces, "
|
||||
$sql = "SELECT ".$this->tableprefix."defunt.id, ".$this->tableprefix."defunt.nom, ".$this->tableprefix."defunt.date_naissance, ".$this->tableprefix."defunt.ref_pacemaker, ".$this->tableprefix."defunt.sexe, "
|
||||
.$this->tableprefix."client.nom as nom_client, ".$this->tableprefix."client.id as id_client, "
|
||||
.$this->tableprefix."devis.num as numero_devis, ".$this->tableprefix."devis.id as id_devis, ".$this->tableprefix."devis.user_id as user_id, "
|
||||
.$this->tableprefix."devis.date as devis_date, "
|
||||
@ -783,7 +783,7 @@ class Bdd
|
||||
|
||||
public function getUnusedDefunts($idNextcloud)
|
||||
{
|
||||
$sql = "SELECT ".$this->tableprefix."defunt.id, ".$this->tableprefix."defunt.nom, ".$this->tableprefix."defunt.date_naissance, ".$this->tableprefix."defunt.ref_pacemaker, ".$this->tableprefix."defunt.sexe, ".$this->tableprefix."defunt.lieu_deces,"
|
||||
$sql = "SELECT ".$this->tableprefix."defunt.id, ".$this->tableprefix."defunt.nom, ".$this->tableprefix."defunt.date_naissance, ".$this->tableprefix."defunt.ref_pacemaker, ".$this->tableprefix."defunt.sexe,"
|
||||
.$this->tableprefix."devis.user_id as user_id
|
||||
FROM ".$this->tableprefix."defunt
|
||||
LEFT JOIN ".$this->tableprefix."devis ON ".$this->tableprefix."devis.id_defunt = ".$this->tableprefix."defunt.id
|
||||
@ -822,7 +822,6 @@ class Bdd
|
||||
.$this->tableprefix."defunt.heure_debut,"
|
||||
.$this->tableprefix."defunt.heure_fin,"
|
||||
.$this->tableprefix."defunt.corpulence,"
|
||||
.$this->tableprefix."defunt.lieu_deces,"
|
||||
.$this->tableprefix."defunt.rigidite,"
|
||||
.$this->tableprefix."defunt.lividite,"
|
||||
.$this->tableprefix."defunt.observations_corps,"
|
||||
@ -1144,39 +1143,19 @@ class Bdd
|
||||
/**
|
||||
* Insert Defunt
|
||||
*/
|
||||
public function insertDefuntByName($name, $lieuDeces = null, $dateNaissance = null)
|
||||
public function insertDefuntByName($name)
|
||||
{
|
||||
// Gérer la date de naissance par défaut si null ou vide
|
||||
if (empty($dateNaissance) || trim($dateNaissance) === '') {
|
||||
$dateNaissance = '1973-11-11';
|
||||
}
|
||||
|
||||
// Gérer le lieu de décès (peut être null)
|
||||
$lieuDecesValue = !empty($lieuDeces) ? trim($lieuDeces) : null;
|
||||
|
||||
$sql = "INSERT INTO `".$this->tableprefix."defunt` (
|
||||
`id_nextcloud`, `nom`, `sexe`, `date_naissance`, `ref_pacemaker`, `date`,
|
||||
`corpulence`, `observations_corps`, `observations_generales`, `lieu_deces`
|
||||
) VALUES (?,?,?,?,?,NOW(),?,?,?,?);";
|
||||
|
||||
$this->execSQLNoData($sql, array(
|
||||
'admin',
|
||||
$name,
|
||||
'm',
|
||||
$dateNaissance,
|
||||
'',
|
||||
'',
|
||||
'',
|
||||
'',
|
||||
$lieuDecesValue
|
||||
));
|
||||
|
||||
`id_nextcloud`, `nom`, `sexe`, `date_naissance`, `ref_pacemaker`, `date`,
|
||||
`corpulence`, `observations_corps`, `observations_generales`
|
||||
) VALUES (?,?,?,?,?,NOW(),?,?,?);";
|
||||
$this->execSQLNoData($sql, array('admin',$name, 'm', '1973-11-11', '', '', '', ''));
|
||||
return true;
|
||||
}
|
||||
|
||||
public function insertDefuntByNameAndReturnId($name, $lieuDeces = null, $dateNaissance = null)
|
||||
public function insertDefuntByNameAndReturnId($name)
|
||||
{
|
||||
$this->insertDefuntByName($name, $lieuDeces, $dateNaissance);
|
||||
$this->insertDefuntByName($name);
|
||||
return $this->getLastDefuntIdByName($name);
|
||||
}
|
||||
|
||||
@ -2615,7 +2594,7 @@ class Bdd
|
||||
return $data;
|
||||
}
|
||||
|
||||
private function getThanatoDevisListByDateSave($thanatoId, $date)
|
||||
private function getThanatoDevisListByDate($thanatoId, $date)
|
||||
{
|
||||
$dateFormatted = $date->format('Y-m-d');
|
||||
$sql = "SELECT
|
||||
@ -2656,42 +2635,6 @@ class Bdd
|
||||
return $devisList;
|
||||
}
|
||||
|
||||
private function getThanatoDevisListByDate($thanatoId, $date)
|
||||
{
|
||||
$dateFormatted = $date->format('Y-m-d');
|
||||
$sql = "SELECT
|
||||
devis.id,
|
||||
devis.date,
|
||||
devis.mentions,
|
||||
devis.num as calendar_uuid,
|
||||
devis.id_defunt as id_defunt,
|
||||
devis.id_lieu as id_lieu,
|
||||
devis.id_client as id_client,
|
||||
devis.id_thanato as id_thanato,
|
||||
thanato.nom as nom_thanato,
|
||||
thanato.prenom as prenom_thanato,
|
||||
defunt.nom as nom_defunt,
|
||||
lieu.nom as nom_lieu,
|
||||
lieu.latitude as lieu_latitude,
|
||||
lieu.longitude as lieu_longitude,
|
||||
client.nom as nom_client,
|
||||
client.entreprise as client_entreprise,
|
||||
client.adresse as client_adresse
|
||||
FROM ".$this->tableprefix."devis as devis
|
||||
LEFT JOIN ".$this->tableprefix."thanato as thanato on devis.id_thanato = thanato.id
|
||||
LEFT JOIN ".$this->tableprefix."lieu as lieu on devis.id_lieu = lieu.id
|
||||
LEFT JOIN ".$this->tableprefix."defunt as defunt on devis.id_defunt = defunt.id
|
||||
LEFT JOIN ".$this->tableprefix."client as client on devis.id_client = client.id
|
||||
WHERE devis.date = ? AND
|
||||
devis.id_thanato = ?
|
||||
ORDER BY devis.date ASC;";
|
||||
$devisList = $this->execSQLNoJsonReturn(
|
||||
$sql,
|
||||
[$dateFormatted,$thanatoId]
|
||||
);
|
||||
return $devisList;
|
||||
}
|
||||
|
||||
public function getThanatoById($thanatoId)
|
||||
{
|
||||
$sql = "SELECT id, nom, prenom,fk_user_uuid FROM ".$this->tableprefix."thanato WHERE id = ? LIMIT 1;";
|
||||
@ -3189,7 +3132,7 @@ class Bdd
|
||||
return 0;
|
||||
}
|
||||
|
||||
private function getClientFactureStatisticPerMonthSave($clientId, array $produitList)
|
||||
private function getClientFactureStatisticPerMonth($clientId, array $produitList)
|
||||
{
|
||||
$currentYear = date('Y');
|
||||
$monthLists = range(1, 12);
|
||||
@ -3210,11 +3153,12 @@ class Bdd
|
||||
LEFT JOIN ".$this->tableprefix."devis as devis on facture.id_devis = devis.id
|
||||
WHERE YEAR(facture.date_paiement) = ? AND
|
||||
MONTH(facture.date_paiement) = ? AND
|
||||
devis.id_client = ?
|
||||
devis.id_client = ? AND
|
||||
(devis.mentions = ? OR devis.mentions = ?)
|
||||
ORDER BY facture.date_paiement ASC;";
|
||||
$factureList = $this->execSQLNoJsonReturn(
|
||||
$sql,
|
||||
[$currentYear,$monthValue,$clientId]
|
||||
[$currentYear,$monthValue,$clientId,DevisMentionConstant::FACTURED,DevisMentionConstant::FACTURED_FORMATTED]
|
||||
);
|
||||
|
||||
$factureDevisIds = [];
|
||||
@ -3244,58 +3188,6 @@ class Bdd
|
||||
return $data;
|
||||
}
|
||||
|
||||
private function getClientFactureStatisticPerMonth($clientId, array $produitList, $clientGroupId = null)
|
||||
{
|
||||
$currentYear = date('Y');
|
||||
$monthLists = range(1, 12);
|
||||
$data = [] ;
|
||||
foreach($monthLists as $monthValue) {
|
||||
if(!isset($data[$monthValue])) {
|
||||
$data[$monthValue] = [];
|
||||
}
|
||||
$sql = "SELECT
|
||||
devis.id as devis_id,
|
||||
devis.id_client as devis_client_id,
|
||||
devis.date as devis_date,
|
||||
devis.mentions as devis_mention
|
||||
FROM ".$this->tableprefix."devis as devis
|
||||
WHERE YEAR(devis.date) = ? AND
|
||||
MONTH(devis.date) = ? AND
|
||||
devis.id_client = ?
|
||||
ORDER BY devis.date ASC;";
|
||||
$factureList = $this->execSQLNoJsonReturn(
|
||||
$sql,
|
||||
[$currentYear,$monthValue,$clientId]
|
||||
);
|
||||
|
||||
$factureDevisIds = [];
|
||||
foreach($factureList as $facture) {
|
||||
$factureDevisIds[] = $facture['devis_id'];
|
||||
}
|
||||
|
||||
$defuntCount = count($factureList);
|
||||
$produitsPrice = 0;
|
||||
$statisticForeachProductPerMonth = [];
|
||||
foreach($produitList as $produit) {
|
||||
if(!isset($statisticForeachProductPerMonth[$produit['id']])) {
|
||||
$statisticForeachProductPerMonth[$produit['id']] = 0;
|
||||
}
|
||||
$productTotalCount = $this->getDevisProductsQuantityByDevisListAndProductId($factureDevisIds, $produit['id']);
|
||||
$prixUnitaire = is_null($clientGroupId) ? $produit["prix_unitaire"] : $this->getProductPriceByClientGroupId($clientGroupId, $produit['id']);
|
||||
$totalWithoutVat = $productTotalCount * $prixUnitaire;
|
||||
$statisticForeachProductPerMonth[$produit['id']] += $productTotalCount;
|
||||
$produitsPrice += $totalWithoutVat;
|
||||
}
|
||||
$data[$monthValue] = [
|
||||
"defunt_count" => $defuntCount,
|
||||
"total_price" => $produitsPrice,
|
||||
"year" => $currentYear,
|
||||
"products" => $statisticForeachProductPerMonth
|
||||
];
|
||||
}
|
||||
return $data;
|
||||
}
|
||||
|
||||
public function getExportClientStatData(array $clientIds)
|
||||
{
|
||||
$data = [];
|
||||
@ -3309,10 +3201,9 @@ class Bdd
|
||||
$client = $this->getClientById($clientId);
|
||||
if($client != null) {
|
||||
$clientName = trim($client["client_nom"]) . '-' .trim($client['client_entreprise']);
|
||||
$clientGroupId = $client['fk_client_group_id'];
|
||||
}
|
||||
$data[$clientId]["client_name"] = $clientName;
|
||||
$data[$clientId]["client_data"] = $this->getClientFactureStatisticPerMonth($clientId, $produitList, $clientGroupId);
|
||||
$data[$clientId]["client_data"] = $this->getClientFactureStatisticPerMonth($clientId, $produitList);
|
||||
}
|
||||
return $data;
|
||||
}
|
||||
@ -3572,7 +3463,6 @@ class Bdd
|
||||
devis.comment as devis_comment,
|
||||
devis.id_client as devis_id_client,
|
||||
devis.devis_full_number,
|
||||
devis.mentions,
|
||||
client.nom as client_nom,
|
||||
client.entreprise as client_entreprise,
|
||||
client.adresse as client_adresse,
|
||||
@ -3627,7 +3517,6 @@ class Bdd
|
||||
devis.comment as devis_comment,
|
||||
devis.id_client as devis_id_client,
|
||||
devis.devis_full_number,
|
||||
devis.mentions,
|
||||
client.nom as client_nom,
|
||||
client.entreprise as client_entreprise,
|
||||
client.adresse as client_adresse,
|
||||
@ -4187,7 +4076,6 @@ class Bdd
|
||||
lieu.adresse as lieu_adresse,
|
||||
defunt.nom as defunt_nom,
|
||||
defunt.sexe as defunt_sexe,
|
||||
defunt.lieu_deces as lieu_deces,
|
||||
defunt.ref_pacemaker as defunt_reference_pacemaker,
|
||||
defunt.product_brand as defunt_product_brand,
|
||||
defunt.product_reference as defunt_product_reference,
|
||||
@ -4219,13 +4107,11 @@ class Bdd
|
||||
return null;
|
||||
}
|
||||
|
||||
public function getDefuntById($defuntId)
|
||||
private function getDefuntById($defuntId)
|
||||
{
|
||||
$sql = "SELECT
|
||||
defunt.id as id,
|
||||
defunt.nom as defunt_nom,
|
||||
defunt.lieu_deces as lieu_deces,
|
||||
defunt.date_naissance as date_naissance,
|
||||
devis.id as devis_id
|
||||
FROM ".$this->tableprefix."defunt as defunt
|
||||
LEFT JOIN ".$this->tableprefix."devis as devis on defunt.id = devis.id_defunt
|
||||
@ -4568,60 +4454,23 @@ COMMENTAIRES: ".$comment;
|
||||
$this->execSQLNoData($sql, [DevisMentionConstant::CANCELED,$devisId]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Met à jour un défunt avec tous ses détails
|
||||
*/
|
||||
public function updateDefuntByNameAndDetails($defuntId, $name, $lieuDeces = null, $dateNaissance = null)
|
||||
private function updateDefuntByName($defuntId, $requestedDefuntName)
|
||||
{
|
||||
// Gérer la date de naissance par défaut si null ou vide
|
||||
if (empty($dateNaissance) || trim($dateNaissance) === '') {
|
||||
$dateNaissance = '1973-11-11';
|
||||
}
|
||||
|
||||
// Gérer le lieu de décès (peut être null)
|
||||
$lieuDecesValue = !empty($lieuDeces) ? trim($lieuDeces) : null;
|
||||
|
||||
$sql = "UPDATE `".$this->tableprefix."defunt` SET
|
||||
`nom` = ?,
|
||||
`lieu_deces` = ?,
|
||||
`date_naissance` = ?
|
||||
WHERE `id` = ?";
|
||||
|
||||
$this->execSQLNoData($sql, array(
|
||||
$name,
|
||||
$lieuDecesValue,
|
||||
$dateNaissance,
|
||||
$defuntId
|
||||
));
|
||||
|
||||
return true;
|
||||
$sql = "UPDATE ".$this->tableprefix."defunt as defunt
|
||||
SET defunt.nom = ?
|
||||
WHERE defunt.id = ?";
|
||||
$this->execSQLNoData($sql, [$requestedDefuntName,$defuntId]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Version simplifiée pour rétrocompatibilité
|
||||
*/
|
||||
public function updateDefuntByName($defuntId, $name)
|
||||
public function createOrUpdateDefuntByNameAndReturnDefuntId($defuntId, $currentDefuntName, $requestedDefuntName)
|
||||
{
|
||||
return $this->updateDefuntByNameAndDetails($defuntId, $name);
|
||||
}
|
||||
|
||||
public function createOrUpdateDefuntByNameAndReturnDefuntId($defuntId, $currentDefuntName, $requestedDefuntName, $lieuDeces = null, $dateNaissance = null)
|
||||
{
|
||||
if ($defuntId != null) {
|
||||
// Récupérer les données actuelles du défunt pour comparaison
|
||||
$currentDefunt = $this->getDefuntById($defuntId);
|
||||
|
||||
if($defuntId != null) {
|
||||
$defuntNameIsUpdated = $currentDefuntName != $requestedDefuntName;
|
||||
$lieuDecesIsUpdated = ($currentDefunt['lieu_deces'] ?? null) != $lieuDeces;
|
||||
$dateNaissanceIsUpdated = ($currentDefunt['date_naissance'] ?? null) != $dateNaissance;
|
||||
|
||||
// Mettre à jour si au moins un champ a changé
|
||||
if ($defuntNameIsUpdated || $lieuDecesIsUpdated || $dateNaissanceIsUpdated) {
|
||||
$this->updateDefuntByNameAndDetails($defuntId, $requestedDefuntName, $lieuDeces, $dateNaissance);
|
||||
if($defuntNameIsUpdated) {
|
||||
$this->updateDefuntByName($defuntId, $requestedDefuntName);
|
||||
}
|
||||
} else {
|
||||
// Créer un nouveau défunt
|
||||
$this->insertDefuntByName($requestedDefuntName, $lieuDeces, $dateNaissance);
|
||||
$this->insertDefuntByName($requestedDefuntName);
|
||||
$defunt = $this->getLastDefuntIdByName($requestedDefuntName);
|
||||
$defuntId = $defunt['id'];
|
||||
}
|
||||
@ -5373,22 +5222,21 @@ COMMENTAIRES: ".$comment;
|
||||
return $devisList;
|
||||
}
|
||||
|
||||
public function getDevisIdsGroupByFactureId($factureId, $mentionFilters = [])
|
||||
{
|
||||
public function getDevisIdsGroupByFactureId($factureId,$mentionFilters = []){
|
||||
$sql = "SELECT devis.id
|
||||
FROM ".$this->tableprefix."devis as devis
|
||||
WHERE devis.fk_facture_id = ? ";
|
||||
|
||||
$conditions = [$factureId];
|
||||
if(!empty($mentionFilters)) {
|
||||
if(!empty($mentionFilters)){
|
||||
$mentionsFilterPlaceholders = implode(',', array_fill(0, count($mentionFilters), '?'));
|
||||
$sql .= " AND devis.mentions IN ($mentionsFilterPlaceholders)";
|
||||
$conditions = array_merge($conditions, $mentionFilters);
|
||||
}
|
||||
$sql .= ";";
|
||||
$devisList = $this->execSQLNoJsonReturn($sql, $conditions);
|
||||
$sql.= ";";
|
||||
$devisList = $this->execSQLNoJsonReturn($sql,$conditions);
|
||||
$devisIds = [];
|
||||
foreach($devisList as $devis) {
|
||||
foreach($devisList as $devis){
|
||||
$devisIds[] = $devis['id'];
|
||||
}
|
||||
return $devisIds;
|
||||
@ -5835,7 +5683,7 @@ COMMENTAIRES: ".$comment;
|
||||
private function getProductsTotalPrices($products)
|
||||
{
|
||||
$configs = json_decode($this->getConfiguration(BddConstant::DEFAULT_ADMIN_ID_NEXTCLOUD));
|
||||
$currentConfig = $configs[0];
|
||||
$currentConfig = $configs[0];
|
||||
$totalHt = 0;
|
||||
$totalTtc = 0;
|
||||
foreach ($products as $product) {
|
||||
@ -5851,12 +5699,11 @@ COMMENTAIRES: ".$comment;
|
||||
];
|
||||
}
|
||||
|
||||
private function getDevisIdsListByFactureId($factureId)
|
||||
{
|
||||
private function getDevisIdsListByFactureId($factureId){
|
||||
$factureData = $this->getFactureByFactureId(factureId: $factureId);
|
||||
$isFactureGroupOfDevis = $factureData["facture_type"] == FactureTypeConstant::TYPE_GROUP;
|
||||
$factureDevisIdsList = [];
|
||||
if($isFactureGroupOfDevis) {
|
||||
if($isFactureGroupOfDevis){
|
||||
$isFactureForSingleClient = $factureData['fk_client_id'] != null && $factureData['fk_client_id'] != 0;
|
||||
$devisMentionFilters = [
|
||||
DevisMentionConstant::FACTURED_FORMATTED,
|
||||
@ -5865,25 +5712,24 @@ COMMENTAIRES: ".$comment;
|
||||
$devis = $this->getDevisByFkFactureId($factureId);
|
||||
$factureGroupIsRelatedToAnyDevis = $devis != null;
|
||||
if (!$factureGroupIsRelatedToAnyDevis) {
|
||||
if($isFactureForSingleClient) {
|
||||
if($isFactureForSingleClient){
|
||||
$factureDevisIdsList = $this->getDevisIdsByClientIdAndMonthYear(
|
||||
$factureData['fk_client_id'],
|
||||
$factureData['month'],
|
||||
$factureData['year'],
|
||||
$devisMentionFilters
|
||||
$factureData['year'],$devisMentionFilters
|
||||
);
|
||||
} else {
|
||||
}else{
|
||||
$factureDevisIdsList = $this->getDevisIdsByClientGroupFacturationIdAndMonthYear(
|
||||
$factureData['fk_client_group_facturation_id'],
|
||||
$factureData['month'],
|
||||
$factureData['year'],
|
||||
$devisMentionFilters
|
||||
);
|
||||
$factureData['month'],
|
||||
$factureData['year'],$devisMentionFilters
|
||||
);
|
||||
}
|
||||
} else {
|
||||
$factureDevisIdsList = $this->getDevisIdsGroupByFactureId($factureId, $devisMentionFilters);
|
||||
}else{
|
||||
$factureDevisIdsList = $this->getDevisIdsGroupByFactureId($factureId, $devisMentionFilters );
|
||||
}
|
||||
} else {
|
||||
}
|
||||
else{
|
||||
$factureDevisIdsList = $factureData['id_devis'] ? [$factureData['id_devis']] : [];
|
||||
}
|
||||
return $factureDevisIdsList;
|
||||
@ -5895,7 +5741,7 @@ COMMENTAIRES: ".$comment;
|
||||
$totalHt = 0;
|
||||
$totalTtc = 0;
|
||||
$tva = 0;
|
||||
foreach($factureDevisIds as $devisId) {
|
||||
foreach($factureDevisIds as $devisId){
|
||||
$products = $this->getDevisProduits($devisId);
|
||||
$totalPrices = $this->getProductsTotalPrices($products);
|
||||
$totalHt += $totalPrices["total_ht"];
|
||||
|
||||
@ -34,33 +34,35 @@ use Psr\Log\LoggerInterface;
|
||||
|
||||
class CalendarObjectCreatedListener implements IEventListener
|
||||
{
|
||||
/** @var LoggerInterface */
|
||||
private $logger;
|
||||
|
||||
/** @var GestionService */
|
||||
private $gestionService;
|
||||
/** @var LoggerInterface */
|
||||
private $logger;
|
||||
|
||||
public function __construct(
|
||||
LoggerInterface $logger,
|
||||
GestionService $gestionService
|
||||
) {
|
||||
$this->logger = $logger;
|
||||
$this->gestionService = $gestionService;
|
||||
}
|
||||
/** @var GestionService */
|
||||
private $gestionService;
|
||||
|
||||
public function __construct(
|
||||
LoggerInterface $logger,
|
||||
GestionService $gestionService
|
||||
) {
|
||||
$this->logger = $logger;
|
||||
$this->gestionService = $gestionService;
|
||||
}
|
||||
|
||||
public function handle(Event $event): void
|
||||
{
|
||||
if (!($event instanceof CalendarObjectCreatedEvent)) {
|
||||
return;
|
||||
}
|
||||
$calendarData = $event->getObjectData();
|
||||
try {
|
||||
$vCalendarString = $calendarData["calendardata"];
|
||||
$this->gestionService->HandleCreatedCalendarObject($vCalendarString);
|
||||
} catch (\OC\OCS\Exception $e) {
|
||||
$this->logger->debug("Error while handling created calendar object: " . $e->getMessage());
|
||||
} catch (\Throwable $e) {
|
||||
$this->logger->debug("Error while handling created calendar object: " . $e->getMessage());
|
||||
}
|
||||
}
|
||||
|
||||
public function handle(Event $event): void
|
||||
{
|
||||
if (!($event instanceof CalendarObjectCreatedEvent)) {
|
||||
return;
|
||||
}
|
||||
$calendarData = $event->getObjectData();
|
||||
try {
|
||||
$vCalendarString = $calendarData["calendardata"];
|
||||
$this->gestionService->HandleCreatedCalendarObject($vCalendarString);
|
||||
} catch (\OC\OCS\Exception $e) {
|
||||
$this->logger->debug("Error while handling created calendar object: " . $e->getMessage());
|
||||
} catch (\Throwable $e) {
|
||||
$this->logger->debug("Error while handling created calendar object: " . $e->getMessage());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@ -35,34 +35,35 @@ use Psr\Log\LoggerInterface;
|
||||
|
||||
class CalendarObjectUpdatedListener implements IEventListener
|
||||
{
|
||||
/** @var LoggerInterface */
|
||||
private $logger;
|
||||
|
||||
/** @var GestionService */
|
||||
private $gestionService;
|
||||
/** @var LoggerInterface */
|
||||
private $logger;
|
||||
|
||||
public function __construct(
|
||||
LoggerInterface $logger,
|
||||
GestionService $gestionService
|
||||
) {
|
||||
$this->logger = $logger;
|
||||
$this->gestionService = $gestionService;
|
||||
}
|
||||
/** @var GestionService */
|
||||
private $gestionService;
|
||||
|
||||
public function handle(Event $event): void
|
||||
{
|
||||
if (!($event instanceof CalendarObjectUpdatedEvent)) {
|
||||
return;
|
||||
}
|
||||
$calendarData = $event->getObjectData();
|
||||
try {
|
||||
$vCalendarString = $calendarData["calendardata"];
|
||||
$this->gestionService->HandleUpdatedCalendarObject($vCalendarString);
|
||||
} catch (\OC\OCS\Exception $e) {
|
||||
$this->logger->debug("Error while handling updated calendar object: " . $e->getMessage());
|
||||
} catch (\Throwable $e) {
|
||||
$this->logger->debug("Error while handling updated calendar object: " . $e->getMessage());
|
||||
}
|
||||
}
|
||||
public function __construct(
|
||||
LoggerInterface $logger,
|
||||
GestionService $gestionService
|
||||
) {
|
||||
$this->logger = $logger;
|
||||
$this->gestionService = $gestionService;
|
||||
}
|
||||
|
||||
public function handle(Event $event): void
|
||||
{
|
||||
if (!($event instanceof CalendarObjectUpdatedEvent)) {
|
||||
return;
|
||||
}
|
||||
$calendarData = $event->getObjectData();
|
||||
try {
|
||||
$vCalendarString = $calendarData["calendardata"];
|
||||
$this->gestionService->HandleUpdatedCalendarObject($vCalendarString);
|
||||
} catch (\OC\OCS\Exception $e) {
|
||||
$this->logger->debug("Error while handling updated calendar object: " . $e->getMessage());
|
||||
} catch (\Throwable $e) {
|
||||
$this->logger->debug("Error while handling updated calendar object: " . $e->getMessage());
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@ -1,70 +0,0 @@
|
||||
<?php
|
||||
|
||||
declare(strict_types=1);
|
||||
|
||||
namespace OCA\Gestion\Migration;
|
||||
|
||||
use Closure;
|
||||
use OCP\IDBConnection;
|
||||
use OCP\DB\ISchemaWrapper;
|
||||
use OCP\Migration\IOutput;
|
||||
use OCP\Migration\SimpleMigrationStep;
|
||||
|
||||
/**
|
||||
* Auto-generated migration step: Ajout du champ lieu_deces à la table defunt
|
||||
*/
|
||||
class Version8Date20250904141530 extends SimpleMigrationStep
|
||||
{
|
||||
private IDbConnection $db;
|
||||
|
||||
public function __construct(IDbConnection $db)
|
||||
{
|
||||
$this->db = $db;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param IOutput $output
|
||||
* @param Closure $schemaClosure The `\Closure` returns a `ISchemaWrapper`
|
||||
* @param array $options
|
||||
*/
|
||||
public function preSchemaChange(IOutput $output, Closure $schemaClosure, array $options): void
|
||||
{
|
||||
}
|
||||
|
||||
/**
|
||||
* @param IOutput $output
|
||||
* @param Closure $schemaClosure The `\Closure` returns a `ISchemaWrapper`
|
||||
* @param array $options
|
||||
* @return null|ISchemaWrapper
|
||||
*/
|
||||
public function changeSchema(IOutput $output, Closure $schemaClosure, array $options)
|
||||
{
|
||||
/** @var ISchemaWrapper $schema */
|
||||
$schema = $schemaClosure();
|
||||
$tableprefix = "gestion_";
|
||||
|
||||
/** DEFUNT - Ajout du champ lieu_deces **/
|
||||
if ($schema->hasTable($tableprefix.'defunt')) {
|
||||
$table = $schema->getTable($tableprefix.'defunt');
|
||||
|
||||
if (!$table->hasColumn('lieu_deces')) {
|
||||
$table->addColumn('lieu_deces', 'string', [
|
||||
'length' => 255,
|
||||
'notnull' => false,
|
||||
'default' => null
|
||||
]);
|
||||
}
|
||||
}
|
||||
|
||||
return $schema;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param IOutput $output
|
||||
* @param Closure $schemaClosure The `\Closure` returns a `ISchemaWrapper`
|
||||
* @param array $options
|
||||
*/
|
||||
public function postSchemaChange(IOutput $output, Closure $schemaClosure, array $options): void
|
||||
{
|
||||
}
|
||||
}
|
||||
@ -29,124 +29,119 @@ namespace OCA\Gestion\Service\Certificate;
|
||||
use DateTime;
|
||||
use DateTimeImmutable;
|
||||
use OCA\Gestion\Db\Bdd;
|
||||
use OCP\Files\IRootFolder;
|
||||
use OCA\Gestion\Helpers\DateHelpers;
|
||||
use OCA\Gestion\Service\Certificate\PdfHandler\CareCertificatePdfHandler;
|
||||
use OCA\Gestion\Service\Certificate\PdfHandler\PacemakerCertificatePdfHandler;
|
||||
use OCA\Gestion\Service\Certificate\PdfHandler\PacemakerAbsentCertificatePdfHandler;
|
||||
use OCP\Files\IRootFolder;
|
||||
|
||||
class CertificateService
|
||||
{
|
||||
/** @var Bdd */
|
||||
private $gestionBdd;
|
||||
class CertificateService {
|
||||
/** @var Bdd */
|
||||
private $gestionBdd;
|
||||
|
||||
/** @var IRootFolder */
|
||||
private $rootFolder;
|
||||
private $rootFolder;
|
||||
|
||||
private const DEFAULT_NEXTCLOUD_ADMIN = "admin";
|
||||
public function __construct(
|
||||
Bdd $gestionBdd,
|
||||
IRootFolder $rootFolder
|
||||
) {
|
||||
public function __construct(
|
||||
Bdd $gestionBdd,
|
||||
IRootFolder $rootFolder) {
|
||||
$this->gestionBdd = $gestionBdd;
|
||||
$this->rootFolder = $rootFolder;
|
||||
}
|
||||
}
|
||||
|
||||
private function signatureImageExists()
|
||||
{
|
||||
private function signatureImageExists(){
|
||||
$storage = $this->rootFolder->getUserFolder(self::DEFAULT_NEXTCLOUD_ADMIN);
|
||||
try {
|
||||
if(isset($storage)) {
|
||||
$storage->get("/.gestion/sign.png");
|
||||
try{
|
||||
if(isset($storage)){
|
||||
$storage->get("/.gestion/sign.png");
|
||||
$signatureExist = true;
|
||||
} else {
|
||||
$signatureExist = false;
|
||||
}
|
||||
} catch(\OCP\Files\NotFoundException $e) {
|
||||
$signatureExist = false;
|
||||
}
|
||||
return $signatureExist;
|
||||
}
|
||||
private function tamponImageExist()
|
||||
{
|
||||
}else{
|
||||
$signatureExist = false;
|
||||
}
|
||||
}
|
||||
catch(\OCP\Files\NotFoundException $e) {
|
||||
$signatureExist = false;
|
||||
}
|
||||
return $signatureExist;
|
||||
}
|
||||
private function tamponImageExist(){
|
||||
$storage = $this->rootFolder->getUserFolder(self::DEFAULT_NEXTCLOUD_ADMIN);
|
||||
try {
|
||||
if(isset($storage)) {
|
||||
$storage->get("/.gestion/sign.jpg"); // tampon image
|
||||
try{
|
||||
if(isset($storage)){
|
||||
$storage->get("/.gestion/sign.jpg"); // tampon image
|
||||
$signatureExist = true;
|
||||
} else {
|
||||
$signatureExist = false;
|
||||
}
|
||||
} catch(\OCP\Files\NotFoundException $e) {
|
||||
$signatureExist = false;
|
||||
}
|
||||
return $signatureExist;
|
||||
}
|
||||
}else{
|
||||
$signatureExist = false;
|
||||
}
|
||||
}
|
||||
catch(\OCP\Files\NotFoundException $e) {
|
||||
$signatureExist = false;
|
||||
}
|
||||
return $signatureExist;
|
||||
}
|
||||
|
||||
private function getLogo()
|
||||
{
|
||||
private function getLogo(){
|
||||
$storage = $this->rootFolder->getUserFolder(self::DEFAULT_NEXTCLOUD_ADMIN);
|
||||
try {
|
||||
try {
|
||||
if(isset($storage)) {
|
||||
$file = $storage->get('/.gestion/logo.png');
|
||||
} else {
|
||||
return "nothing";
|
||||
}
|
||||
} catch(\OCP\Files\NotFoundException $e) {
|
||||
$file = $storage->get('/.gestion/logo.jpeg');
|
||||
}
|
||||
} catch(\OCP\Files\NotFoundException $e) {
|
||||
return "nothing";
|
||||
}
|
||||
return base64_encode($file->getContent());
|
||||
}
|
||||
try{
|
||||
try {
|
||||
if(isset($storage)){
|
||||
$file = $storage->get('/.gestion/logo.png');
|
||||
}else{
|
||||
return "nothing";
|
||||
}
|
||||
} catch(\OCP\Files\NotFoundException $e) {
|
||||
$file = $storage->get('/.gestion/logo.jpeg');
|
||||
}
|
||||
}
|
||||
catch(\OCP\Files\NotFoundException $e) {
|
||||
return "nothing";
|
||||
}
|
||||
return base64_encode($file->getContent());
|
||||
}
|
||||
|
||||
private function setDevisOfDefuntDefaultValue($devisOfDefunt)
|
||||
{
|
||||
private function setDevisOfDefuntDefaultValue($devisOfDefunt){
|
||||
$devisOfDefunt["devis_date"] = new DateTimeImmutable($devisOfDefunt["devis_date"]);
|
||||
$locationOfDevis = "";
|
||||
if($devisOfDefunt['lieu_nom'] != null) {
|
||||
if($devisOfDefunt['lieu_nom'] != null){
|
||||
$locationOfDevis .= $devisOfDefunt['lieu_nom'];
|
||||
}
|
||||
if($devisOfDefunt['lieu_adresse'] != null) {
|
||||
if($devisOfDefunt['lieu_adresse'] != null){
|
||||
$locationOfDevis .= " ". $devisOfDefunt['lieu_adresse'];
|
||||
}
|
||||
$devisOfDefunt['location_of_devis'] = $locationOfDevis;
|
||||
if($devisOfDefunt['thanato_nom'] == null) {
|
||||
if($devisOfDefunt['thanato_nom'] == null){
|
||||
$devisOfDefunt['thanato_nom'] = "";
|
||||
}
|
||||
if($devisOfDefunt['thanato_prenom'] == null) {
|
||||
if($devisOfDefunt['thanato_prenom'] == null){
|
||||
$devisOfDefunt['thanato_prenom'] = "";
|
||||
}
|
||||
if($devisOfDefunt['thanato_reference'] == null) {
|
||||
if($devisOfDefunt['thanato_reference'] == null){
|
||||
$devisOfDefunt['thanato_reference'] = "";
|
||||
}
|
||||
if($devisOfDefunt['client_nom'] == null) {
|
||||
if($devisOfDefunt['client_nom'] == null){
|
||||
$devisOfDefunt['client_nom'] = "";
|
||||
}
|
||||
if($devisOfDefunt['client_prenom'] == null) {
|
||||
if($devisOfDefunt['client_prenom'] == null){
|
||||
$devisOfDefunt['client_prenom'] = "";
|
||||
}
|
||||
if($devisOfDefunt['client_entreprise'] == null) {
|
||||
if($devisOfDefunt['client_entreprise'] == null){
|
||||
$devisOfDefunt['client_entreprise'] = "";
|
||||
}
|
||||
if($devisOfDefunt['client_adresse'] == null) {
|
||||
if($devisOfDefunt['client_adresse'] == null){
|
||||
$devisOfDefunt['client_adresse'] = "";
|
||||
}
|
||||
return $devisOfDefunt;
|
||||
}
|
||||
|
||||
public function generateCareCertificate($defuntId, $idNextCloud)
|
||||
{
|
||||
public function generateCareCertificate($defuntId,$idNextCloud){
|
||||
$storage = $this->rootFolder->getUserFolder($idNextCloud);
|
||||
$configs = json_decode($this->gestionBdd->getConfiguration(self::DEFAULT_NEXTCLOUD_ADMIN));
|
||||
$currentConfig = $configs[0];
|
||||
$logo = $this->getLogo();
|
||||
$devisOfDefunt = $this->gestionBdd->getDevisOfDefunt($defuntId);
|
||||
if($devisOfDefunt == null) {
|
||||
return null;
|
||||
}
|
||||
$currentConfig = $configs[0];
|
||||
$logo = $this->getLogo();
|
||||
$devisOfDefunt = $this->gestionBdd->getDevisOfDefunt($defuntId);
|
||||
if($devisOfDefunt == null){
|
||||
return null;
|
||||
}
|
||||
$devisOfDefunt["configuration"] = $currentConfig;
|
||||
$devisOfDefunt = $this->setDevisOfDefuntDefaultValue($devisOfDefunt);
|
||||
$clean_folder = html_entity_decode(string: $currentConfig->path).'/';
|
||||
@ -155,67 +150,63 @@ class CertificateService
|
||||
$pdfFilename = $this->GetCareCertificateFilename($devisOfDefunt);
|
||||
$filenamePath = $clean_folder.$careCertificateFolder.$pdfFilename.'.pdf';
|
||||
$pdf = new CareCertificatePdfHandler();
|
||||
$pdf->AddFont('ComicSans', '', 'Comic Sans MS.php');
|
||||
$pdf->AddFont('ComicSans', 'B', 'comic-sans-bold.php');
|
||||
$pdf->AddFont('ComicSans','','Comic Sans MS.php');
|
||||
$pdf->AddFont('ComicSans','B','comic-sans-bold.php');
|
||||
$signatureImageExist = $this->signatureImageExists();
|
||||
$tamponImageExist = $this->tamponImageExist();
|
||||
$pdf->SetCareCertificateData($devisOfDefunt, $logo, $signatureImageExist, $tamponImageExist);
|
||||
$pdf->SetCareCertificateData($devisOfDefunt,$logo,$signatureImageExist ,$tamponImageExist);
|
||||
$pdf->SetCareCertificate();
|
||||
try {
|
||||
$storage->newFolder($folderDestination);
|
||||
} catch(\OCP\Files\NotPermittedException $e) {
|
||||
}
|
||||
catch(\OCP\Files\NotPermittedException $e) {
|
||||
}
|
||||
$pdfContent = $pdf->Output('', 'S');
|
||||
$pdfContent = $pdf->Output('','S');
|
||||
$storage->newFile($filenamePath);
|
||||
$pdfFile = $storage->get($filenamePath);
|
||||
$pdfFile->putContent($pdfContent);
|
||||
return $filenamePath;
|
||||
}
|
||||
|
||||
private function getCareCertificateFolder($devisOfDefunt)
|
||||
{
|
||||
private function getCareCertificateFolder($devisOfDefunt){
|
||||
$careCertificateFolder = 'CLIENTS/'
|
||||
.mb_strtoupper($devisOfDefunt["client_nom"], 'UTF-8')
|
||||
.mb_strtoupper($devisOfDefunt["client_nom"],'UTF-8')
|
||||
.'/DEFUNTS/'
|
||||
.mb_strtoupper($devisOfDefunt["defunt_nom"], 'UTF-8').'/'
|
||||
.mb_strtoupper($devisOfDefunt["defunt_nom"],'UTF-8').'/'
|
||||
.'ATTESTATION/';
|
||||
|
||||
return $careCertificateFolder;
|
||||
}
|
||||
|
||||
private function GetCareCertificateFilename($devisOfDefunt)
|
||||
{
|
||||
$filename = 'ATTESTATION_SOIN_'.mb_strtoupper($devisOfDefunt['defunt_nom'], 'UTF-8');
|
||||
private function GetCareCertificateFilename($devisOfDefunt){
|
||||
$filename = 'ATTESTATION_SOIN_'.mb_strtoupper($devisOfDefunt['defunt_nom'],'UTF-8');
|
||||
return $filename;
|
||||
}
|
||||
|
||||
private function getPacemakerCertificateFolder($devisOfDefunt)
|
||||
{
|
||||
private function getPacemakerCertificateFolder($devisOfDefunt){
|
||||
$folder = 'CLIENTS/'
|
||||
.mb_strtoupper($devisOfDefunt["client_nom"], 'UTF-8')
|
||||
.mb_strtoupper($devisOfDefunt["client_nom"],'UTF-8')
|
||||
.'/DEFUNTS/'
|
||||
.mb_strtoupper($devisOfDefunt["defunt_nom"], 'UTF-8').'/'
|
||||
.mb_strtoupper($devisOfDefunt["defunt_nom"],'UTF-8').'/'
|
||||
.'ATTESTATION/';
|
||||
|
||||
return $folder;
|
||||
}
|
||||
|
||||
private function getPacemakerCertificateFilename($devisOfDefunt)
|
||||
{
|
||||
$filename = 'ATTESTATION_PACEMAKER_'.mb_strtoupper($devisOfDefunt['defunt_nom'], 'UTF-8');
|
||||
private function getPacemakerCertificateFilename($devisOfDefunt){
|
||||
$filename = 'ATTESTATION_PACEMAKER_'.mb_strtoupper($devisOfDefunt['defunt_nom'],'UTF-8');
|
||||
return $filename;
|
||||
}
|
||||
|
||||
public function generatePacemakerCertificate($defuntId, $idNextCloud)
|
||||
{
|
||||
public function generatePacemakerCertificate($defuntId,$idNextCloud){
|
||||
$storage = $this->rootFolder->getUserFolder($idNextCloud);
|
||||
$configs = json_decode($this->gestionBdd->getConfiguration(self::DEFAULT_NEXTCLOUD_ADMIN));
|
||||
$currentConfig = $configs[0];
|
||||
$logo = $this->getLogo();
|
||||
$devisOfDefunt = $this->gestionBdd->getDevisOfDefunt($defuntId);
|
||||
if($devisOfDefunt == null) {
|
||||
return null;
|
||||
}
|
||||
$currentConfig = $configs[0];
|
||||
$logo = $this->getLogo();
|
||||
$devisOfDefunt = $this->gestionBdd->getDevisOfDefunt($defuntId);
|
||||
if($devisOfDefunt == null){
|
||||
return null;
|
||||
}
|
||||
$devisOfDefunt["configuration"] = $currentConfig;
|
||||
$devisOfDefunt = $this->setDevisOfDefuntDefaultValue($devisOfDefunt);
|
||||
$clean_folder = html_entity_decode(string: $currentConfig->path).'/';
|
||||
@ -224,58 +215,18 @@ class CertificateService
|
||||
$pdfFilename = $this->getPacemakerCertificateFilename($devisOfDefunt);
|
||||
$filenamePath = $clean_folder.$pacemakerCertificateFolder.$pdfFilename.'.pdf';
|
||||
$pdf = new PacemakerCertificatePdfHandler();
|
||||
$pdf->AddFont('ComicSans', '', 'Comic Sans MS.php');
|
||||
$pdf->AddFont('ComicSans', 'B', 'comic-sans-bold.php');
|
||||
$pdf->AddFont('ComicSans','','Comic Sans MS.php');
|
||||
$pdf->AddFont('ComicSans','B','comic-sans-bold.php');
|
||||
$signatureImageExist = $this->signatureImageExists();
|
||||
$tamponImageExist = $this->tamponImageExist();
|
||||
$pdf->SetPacemakerCertificateData($devisOfDefunt, $logo, $signatureImageExist, $tamponImageExist);
|
||||
$pdf->SetPacemakerCertificateData($devisOfDefunt,$logo,$signatureImageExist ,$tamponImageExist);
|
||||
$pdf->SetPacemakerCertificate();
|
||||
try {
|
||||
$storage->newFolder($folderDestination);
|
||||
} catch(\OCP\Files\NotPermittedException $e) {
|
||||
}
|
||||
catch(\OCP\Files\NotPermittedException $e) {
|
||||
}
|
||||
$pdfContent = $pdf->Output('', 'S');
|
||||
$storage->newFile($filenamePath);
|
||||
$pdfFile = $storage->get($filenamePath);
|
||||
$pdfFile->putContent($pdfContent);
|
||||
return $filenamePath;
|
||||
}
|
||||
|
||||
private function getPacemakerAbsentCertificateFilename($devisOfDefunt)
|
||||
{
|
||||
$filename = 'ATTESTATION_ABSENCE_PACEMAKER_'.mb_strtoupper($devisOfDefunt['defunt_nom'], 'UTF-8');
|
||||
return $filename;
|
||||
}
|
||||
|
||||
public function generatePacemakerAbsentCertificate($defuntId, $idNextCloud)
|
||||
{
|
||||
$storage = $this->rootFolder->getUserFolder($idNextCloud);
|
||||
$configs = json_decode($this->gestionBdd->getConfiguration(self::DEFAULT_NEXTCLOUD_ADMIN));
|
||||
$currentConfig = $configs[0];
|
||||
$logo = $this->getLogo();
|
||||
$devisOfDefunt = $this->gestionBdd->getDevisOfDefunt($defuntId);
|
||||
if($devisOfDefunt == null) {
|
||||
return null;
|
||||
}
|
||||
$devisOfDefunt["configuration"] = $currentConfig;
|
||||
$devisOfDefunt = $this->setDevisOfDefuntDefaultValue($devisOfDefunt);
|
||||
$clean_folder = html_entity_decode(string: $currentConfig->path).'/';
|
||||
$pacemakerCertificateFolder = $this->getPacemakerCertificateFolder($devisOfDefunt);
|
||||
$folderDestination = $clean_folder.$pacemakerCertificateFolder;
|
||||
$pdfFilename = $this->getPacemakerAbsentCertificateFilename($devisOfDefunt);
|
||||
$filenamePath = $clean_folder.$pacemakerCertificateFolder.$pdfFilename.'.pdf';
|
||||
$pdf = new PacemakerAbsentCertificatePdfHandler();
|
||||
$pdf->AddFont('ComicSans', '', 'Comic Sans MS.php');
|
||||
$pdf->AddFont('ComicSans', 'B', 'comic-sans-bold.php');
|
||||
$signatureImageExist = $this->signatureImageExists();
|
||||
$tamponImageExist = $this->tamponImageExist();
|
||||
$pdf->SetPacemakerCertificateData($devisOfDefunt, $logo, $signatureImageExist, $tamponImageExist);
|
||||
$pdf->SetPacemakerCertificate();
|
||||
try {
|
||||
$storage->newFolder($folderDestination);
|
||||
} catch(\OCP\Files\NotPermittedException $e) {
|
||||
}
|
||||
$pdfContent = $pdf->Output('', 'S');
|
||||
$pdfContent = $pdf->Output('','S');
|
||||
$storage->newFile($filenamePath);
|
||||
$pdfFile = $storage->get($filenamePath);
|
||||
$pdfFile->putContent($pdfContent);
|
||||
|
||||
@ -27,142 +27,136 @@ declare(strict_types=1);
|
||||
namespace OCA\Gestion\Service\Certificate\PdfHandler;
|
||||
|
||||
use DateTime;
|
||||
use FPDF;
|
||||
use \FPDF;
|
||||
use OCA\Gestion\Helpers\DateHelpers;
|
||||
use OCA\Gestion\Helpers\FileExportHelpers;
|
||||
use OCA\Gestion\Helpers\PriceHelpers;
|
||||
|
||||
class CareCertificatePdfHandler extends FPDF
|
||||
{
|
||||
class CareCertificatePdfHandler extends FPDF {
|
||||
|
||||
private $devisOfDefunt = [];
|
||||
private $logo = null;
|
||||
private $signatureImageExist = false;
|
||||
private $tamponImageExist = false;
|
||||
private $imagePath = "/var/www/html/data/admin/files/.gestion/";
|
||||
|
||||
public function Header()
|
||||
function Header()
|
||||
{
|
||||
if($this->logo != "nothing") {
|
||||
if($this->logo != "nothing"){
|
||||
$this->Image($this->imagePath."logo.png", 4, 2, 40, 45);
|
||||
} else {
|
||||
$this->Cell(55, 30, '');
|
||||
}
|
||||
else{
|
||||
$this->Cell(55,30,'');
|
||||
}
|
||||
}
|
||||
public function Footer()
|
||||
function Footer()
|
||||
{
|
||||
$this->SetY(-18);
|
||||
$this->SetFont('Arial', '', 10);
|
||||
$this->MultiCell(0, 5, utf8_decode(html_entity_decode($this->devisOfDefunt['configuration']->legal_one)), 0, 'C');
|
||||
$this->MultiCell(0, 5, utf8_decode(html_entity_decode($this->devisOfDefunt['configuration']->adresse)), 0, 'C');
|
||||
$this->MultiCell(0, 5, utf8_decode(html_entity_decode($this->devisOfDefunt['configuration']->adresse)), 0,'C');
|
||||
}
|
||||
|
||||
public function SetCareCertificateData(array $devisOfDefunt, $logo = null, $signatureImageExist = false, $tamponImageExist = false)
|
||||
{
|
||||
public function SetCareCertificateData(array $devisOfDefunt,$logo = null,$signatureImageExist = false , $tamponImageExist = false){
|
||||
$this->devisOfDefunt = $devisOfDefunt;
|
||||
$this->logo = $logo;
|
||||
$this->signatureImageExist = $signatureImageExist;
|
||||
$this->tamponImageExist = $tamponImageExist;
|
||||
}
|
||||
|
||||
public function SetCareCertificate()
|
||||
{
|
||||
public function SetCareCertificate(){
|
||||
$this->AddPage();
|
||||
$this->SetMargins(left:20, top:0, right:20);
|
||||
$this->SetMargins(left:20,top:0,right:20);
|
||||
$this->SetCareCertificateTitle();
|
||||
$this->SetCareCertificateContent();
|
||||
$this->SetSigning();
|
||||
}
|
||||
|
||||
private function SetSigning()
|
||||
{
|
||||
$this->SetXY(140, $this->GetY() + 15);
|
||||
$this->Cell(0, 10, 'Cachet et signature');
|
||||
private function SetSigning(){
|
||||
$this->SetXY(140,$this->GetY() + 15);
|
||||
$this->Cell(0,10,'Cachet et signature');
|
||||
|
||||
if($this->tamponImageExist) {
|
||||
$this->Image($this->imagePath."sign.jpg", 120, $this->GetY() + 8, 80, 35);
|
||||
if($this->tamponImageExist){
|
||||
$this->Image($this->imagePath."sign.jpg", 120, $this->GetY() + 8, 80, 35);
|
||||
}
|
||||
|
||||
if($this->signatureImageExist) {
|
||||
if($this->signatureImageExist){
|
||||
$this->Image($this->imagePath."sign.png", 140, $this->GetY() + 40, 40, 16);
|
||||
}
|
||||
}
|
||||
|
||||
private function SetCareCertificateContent()
|
||||
{
|
||||
private function SetCareCertificateContent(){
|
||||
$this->SetFont('Arial', '', 14);
|
||||
$this->MultiCell(0, 7, FileExportHelpers::FormatTextForExport('La Société '. $this->devisOfDefunt['configuration']->entreprise. ' habilitée sous le numéro ' . $this->devisOfDefunt['thanato_reference'] . ', certifie par la présente que : '));
|
||||
$this->MultiCell(0,7,FileExportHelpers::FormatTextForExport('La Société '. $this->devisOfDefunt['configuration']->entreprise. ' habilitée sous le numéro ' . $this->devisOfDefunt['thanato_reference'] . ', certifie par la présente que : '));
|
||||
$this->SetFont('Arial', 'B', 14);
|
||||
$this->Cell(0, 12, FileExportHelpers::FormatTextForExport($this->devisOfDefunt['thanato_nom'] . ' ' . $this->devisOfDefunt['thanato_prenom']), 0, 1);
|
||||
$this->Cell(0,12, FileExportHelpers::FormatTextForExport($this->devisOfDefunt['thanato_nom'] . ' ' . $this->devisOfDefunt['thanato_prenom']),0,1);
|
||||
$this->SetFont('Arial', '', 14);
|
||||
$this->MultiCell(0, 7, FileExportHelpers::FormatTextForExport('Employé(e) au sein de notre société et titulaire du diplôme national de Thanatopracteur, a effectué des soins de conservation sur le corps du défunt :'));
|
||||
$this->MultiCell(0,7, FileExportHelpers::FormatTextForExport('Employé(e) au sein de notre société et titulaire du diplôme national de Thanatopracteur, a effectué des soins de conservation sur le corps du défunt :'));
|
||||
$this->SetFont('Arial', 'B', 14);
|
||||
$this->Cell(0, 12, FileExportHelpers::FormatTextForExport($this->devisOfDefunt['defunt_nom']), 0, 1);
|
||||
$this->Cell(0,12, FileExportHelpers::FormatTextForExport($this->devisOfDefunt['defunt_nom']),0,1);
|
||||
$this->SetFont('Arial', '', 14);
|
||||
$this->Cell(0, 12, FileExportHelpers::FormatTextForExport("Date du décès") . ' : ' . $this->devisOfDefunt['defunt_date'] , 0, 1);
|
||||
$this->SetFont('Arial', '', 14);
|
||||
$this->Cell(0, 12, FileExportHelpers::FormatTextForExport("Date du décès") . ' : ' . $this->devisOfDefunt['defunt_date'], 0, 1);
|
||||
$this->SetFont('Arial', '', 14);
|
||||
$this->Cell(0, 12, FileExportHelpers::FormatTextForExport("Lieu du décès") . ' : ' . $this->devisOfDefunt['lieu_deces'], 0, 1);
|
||||
$this->SetFont('Arial', '', 14);
|
||||
$this->Cell(0, 12, FileExportHelpers::FormatTextForExport("Qui reposait à l'adresse suivante") . ' : ', 0, 1);
|
||||
$this->Cell(0,12, FileExportHelpers::FormatTextForExport("Qui reposait à l'adresse suivante") . ' : ',0,1);
|
||||
$this->SetFont('Arial', 'B', 14);
|
||||
$this->MultiCell(0, 6, FileExportHelpers::FormatTextForExport($this->devisOfDefunt['location_of_devis']));
|
||||
|
||||
|
||||
$this->MultiCell(0,6, FileExportHelpers::FormatTextForExport($this->devisOfDefunt['location_of_devis']));
|
||||
|
||||
|
||||
|
||||
$this->SetFont('Arial', '', 14);
|
||||
$this->Cell(0, 12, FileExportHelpers::FormatTextForExport("La présente attestation est établie pour faire valoir ce que de droit."), 0, 5);
|
||||
$this->Cell(0,12, FileExportHelpers::FormatTextForExport("La présente attestation est établie pour faire valoir ce que de droit."),0,5);
|
||||
$this->Ln(5);
|
||||
// $this->MultiAlignCell(120,7,FileExportHelpers::FormatTextForExport('Fait à '). FileExportHelpers::FormatTextForExport($this->devisOfDefunt['location_of_devis']),0);
|
||||
// $this->SetX(140);
|
||||
$this->Cell(0, 7, 'Fait le '. $this->devisOfDefunt['devis_date']->format('d/m/Y'), 0);
|
||||
$this->MultiAlignCell(120,7,FileExportHelpers::FormatTextForExport('Fait à '). FileExportHelpers::FormatTextForExport($this->devisOfDefunt['location_of_devis']),0);
|
||||
$this->SetX(140);
|
||||
$this->Cell(0,7,'le '. $this->devisOfDefunt['devis_date']->format('d/m/Y'),0);
|
||||
}
|
||||
|
||||
private function SetCareCertificateTitle()
|
||||
{
|
||||
private function SetCareCertificateTitle(){
|
||||
$this->SetY(60);
|
||||
$this->SetFont('Arial', 'B', 20);
|
||||
$this->Cell(0, 10, 'ATTESTATION DE SOINS DE CONSERVATION', 0, 1, 'C');
|
||||
$this->Ln(20);
|
||||
$this->Cell(0, 10, 'ATTESTATION DE SOINS DE CONSERVATION', 0, 1,'C');
|
||||
$this->Ln(20);
|
||||
}
|
||||
|
||||
public function MultiAlignCell($w, $h, $text, $border = 0, $ln = 0, $align = 'L', $fill = false)
|
||||
{
|
||||
// Store reset values for (x,y) positions
|
||||
$x = $this->GetX() + $w;
|
||||
$y = $this->GetY();
|
||||
function MultiAlignCell($w,$h,$text,$border=0,$ln=0,$align='L',$fill=false)
|
||||
{
|
||||
// Store reset values for (x,y) positions
|
||||
$x = $this->GetX() + $w;
|
||||
$y = $this->GetY();
|
||||
|
||||
// Make a call to FPDF's MultiCell
|
||||
$this->MultiCell($w, $h, $text, $border, $align, $fill);
|
||||
// Make a call to FPDF's MultiCell
|
||||
$this->MultiCell($w,$h,$text,$border,$align,$fill);
|
||||
|
||||
// Reset the line position to the right, like in Cell
|
||||
if($ln == 0) {
|
||||
$this->SetXY($x, $y);
|
||||
}
|
||||
}
|
||||
// Reset the line position to the right, like in Cell
|
||||
if( $ln==0 )
|
||||
{
|
||||
$this->SetXY($x,$y);
|
||||
}
|
||||
}
|
||||
|
||||
public function NbLines($w, $txt)
|
||||
function NbLines($w, $txt)
|
||||
{
|
||||
// Compute the number of lines a MultiCell of width w will take
|
||||
if(!isset($this->CurrentFont)) {
|
||||
if(!isset($this->CurrentFont))
|
||||
$this->Error('No font has been set');
|
||||
}
|
||||
$cw = $this->CurrentFont['cw'];
|
||||
if($w == 0) {
|
||||
$w = $this->w - $this->rMargin - $this->x;
|
||||
}
|
||||
$wmax = ($w - 2 * $this->cMargin) * 1000 / $this->FontSize;
|
||||
$s = str_replace("\r", '', (string)$txt);
|
||||
if($w==0)
|
||||
$w = $this->w-$this->rMargin-$this->x;
|
||||
$wmax = ($w-2*$this->cMargin)*1000/$this->FontSize;
|
||||
$s = str_replace("\r",'',(string)$txt);
|
||||
$nb = strlen($s);
|
||||
if($nb > 0 && $s[$nb - 1] == "\n") {
|
||||
if($nb>0 && $s[$nb-1]=="\n")
|
||||
$nb--;
|
||||
}
|
||||
$sep = -1;
|
||||
$i = 0;
|
||||
$j = 0;
|
||||
$l = 0;
|
||||
$nl = 1;
|
||||
while($i < $nb) {
|
||||
while($i<$nb)
|
||||
{
|
||||
$c = $s[$i];
|
||||
if($c == "\n") {
|
||||
if($c=="\n")
|
||||
{
|
||||
$i++;
|
||||
$sep = -1;
|
||||
$j = $i;
|
||||
@ -170,25 +164,25 @@ class CareCertificatePdfHandler extends FPDF
|
||||
$nl++;
|
||||
continue;
|
||||
}
|
||||
if($c == ' ') {
|
||||
if($c==' ')
|
||||
$sep = $i;
|
||||
}
|
||||
$l += $cw[$c];
|
||||
if($l > $wmax) {
|
||||
if($sep == -1) {
|
||||
if($i == $j) {
|
||||
if($l>$wmax)
|
||||
{
|
||||
if($sep==-1)
|
||||
{
|
||||
if($i==$j)
|
||||
$i++;
|
||||
}
|
||||
} else {
|
||||
$i = $sep + 1;
|
||||
}
|
||||
else
|
||||
$i = $sep+1;
|
||||
$sep = -1;
|
||||
$j = $i;
|
||||
$l = 0;
|
||||
$nl++;
|
||||
} else {
|
||||
$i++;
|
||||
}
|
||||
else
|
||||
$i++;
|
||||
}
|
||||
return $nl;
|
||||
}
|
||||
|
||||
@ -1,239 +0,0 @@
|
||||
<?php
|
||||
|
||||
declare(strict_types=1);
|
||||
/**
|
||||
* Calendar App
|
||||
*
|
||||
* @copyright 2021 Anna Larch <anna.larch@gmx.net>
|
||||
*
|
||||
* @author Anna Larch <anna.larch@gmx.net>
|
||||
* @author Richard Steinmetz <richard@steinmetz.cloud>
|
||||
*
|
||||
* This library is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE
|
||||
* License as published by the Free Software Foundation; either
|
||||
* version 3 of the License, or any later version.
|
||||
*
|
||||
* This library is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU AFFERO GENERAL PUBLIC LICENSE for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Affero General Public
|
||||
* License along with this library. If not, see <http://www.gnu.org/licenses/>.
|
||||
*
|
||||
*/
|
||||
|
||||
namespace OCA\Gestion\Service\Certificate\PdfHandler;
|
||||
|
||||
use DateTime;
|
||||
use FPDF;
|
||||
use OCA\Gestion\Helpers\DateHelpers;
|
||||
use OCA\Gestion\Helpers\FileExportHelpers;
|
||||
use OCA\Gestion\Helpers\PriceHelpers;
|
||||
|
||||
class PacemakerAbsentCertificatePdfHandler extends FPDF
|
||||
{
|
||||
private $devisOfDefunt = [];
|
||||
private $logo = null;
|
||||
private $signatureImageExist = false;
|
||||
private $tamponImageExist = false;
|
||||
private $imagePath = "/var/www/html/data/admin/files/.gestion/";
|
||||
|
||||
public function Header()
|
||||
{
|
||||
if ($this->logo != "nothing") {
|
||||
$this->Image($this->imagePath . "logo.png", 10, 10, 50, 35);
|
||||
}
|
||||
|
||||
// En-tête avec les informations de l'entreprise - SOUS le logo
|
||||
$this->SetXY(10, 50); // Position sous le logo
|
||||
$this->SetFont('Arial', 'B', 12);
|
||||
$this->Cell(0, 5, FileExportHelpers::FormatTextForExport($this->devisOfDefunt['configuration']->entreprise), 0, 1);
|
||||
$this->SetFont('Arial', '', 10);
|
||||
$this->MultiCell(0, 4, FileExportHelpers::FormatTextForExport($this->devisOfDefunt['configuration']->adresse), 0, 'L');
|
||||
|
||||
if (isset($this->devisOfDefunt['configuration']->telephone)) {
|
||||
$this->Cell(0, 4, 'Tel : ' . FileExportHelpers::FormatTextForExport($this->devisOfDefunt['configuration']->telephone), 0, 1);
|
||||
}
|
||||
|
||||
if (isset($this->devisOfDefunt['thanato_reference'])) {
|
||||
$this->Cell(0, 4, 'Habilitation : ' . FileExportHelpers::FormatTextForExport($this->devisOfDefunt['thanato_reference']), 0, 1);
|
||||
}
|
||||
|
||||
if (isset($this->devisOfDefunt['configuration']->siret)) {
|
||||
$this->Cell(0, 4, 'Siret : ' . FileExportHelpers::FormatTextForExport($this->devisOfDefunt['configuration']->siret), 0, 1);
|
||||
}
|
||||
}
|
||||
|
||||
public function Footer()
|
||||
{
|
||||
$this->SetY(-15);
|
||||
$this->MultiCell(0, 5, utf8_decode(html_entity_decode($this->devisOfDefunt['configuration']->legal_one)), 0, 'C');
|
||||
$this->MultiCell(0, 5, utf8_decode(html_entity_decode($this->devisOfDefunt['configuration']->adresse)), 0, 'C');
|
||||
}
|
||||
|
||||
public function SetPacemakerCertificateData(array $devisOfDefunt, $logo = null, $signatureImageExist = false, $tamponImageExist = false)
|
||||
{
|
||||
$this->devisOfDefunt = $devisOfDefunt;
|
||||
$this->logo = $logo;
|
||||
$this->signatureImageExist = $signatureImageExist;
|
||||
$this->tamponImageExist = $tamponImageExist;
|
||||
}
|
||||
|
||||
public function SetPacemakerCertificate()
|
||||
{
|
||||
$this->AddPage();
|
||||
$this->SetMargins(left: 20, top: 0, right: 20);
|
||||
$this->SetPacemakerCertificateTitle();
|
||||
$this->SetPacemakerCertificateContent();
|
||||
}
|
||||
|
||||
private function SetPacemakerCertificateContent()
|
||||
{
|
||||
$this->SetY(100); // Position réduite après le titre
|
||||
|
||||
$this->SetFont('Arial', '', 12);
|
||||
|
||||
// Déterminer le genre selon la civilité
|
||||
$civilite = isset($this->devisOfDefunt['thanato_civilite']) ? $this->devisOfDefunt['thanato_civilite'] : 'Madame';
|
||||
$pronom = 'Je soussignée';
|
||||
$profession = 'thanatopractrice diplômée';
|
||||
|
||||
// Adaptation selon la civilité
|
||||
if (strtolower($civilite) === 'monsieur' || strtolower($civilite) === 'm.' || strtolower($civilite) === 'mr') {
|
||||
$pronom = 'Je soussigné';
|
||||
$profession = 'thanatopracteur diplômé';
|
||||
}
|
||||
|
||||
// Texte principal avec genre adapté
|
||||
$mainText = $pronom . ', ' . $civilite . ' ' .
|
||||
mb_convert_encoding(html_entity_decode($this->devisOfDefunt['thanato_prenom']), 'ISO-8859-1', 'UTF-8'). ' ' .mb_convert_encoding(html_entity_decode($this->devisOfDefunt['thanato_nom']), 'ISO-8859-1', 'UTF-8').
|
||||
', ' . $profession . ', certifie ne pas avoir constaté, à la palpation, la présence d\'un pacemaker pour :';
|
||||
|
||||
$this->MultiCell(0, 6, FileExportHelpers::FormatTextForExport($mainText));
|
||||
$this->Ln(8);
|
||||
|
||||
// Nom du défunt
|
||||
$this->SetFont('Arial', 'B', 12);
|
||||
$this->Cell(20, 8, 'Nom :', 0, 0);
|
||||
$this->SetFont('Arial', '', 12);
|
||||
$this->Cell(0, 8, FileExportHelpers::FormatTextForExport(mb_convert_encoding(html_entity_decode($this->devisOfDefunt['defunt_nom']), 'ISO-8859-1', 'UTF-8')), 0, 1);
|
||||
$this->Ln(3);
|
||||
|
||||
// Date
|
||||
$this->SetFont('Arial', 'B', 12);
|
||||
$this->Cell(20, 8, 'Date :', 0, 0);
|
||||
$this->SetFont('Arial', '', 12);
|
||||
if (isset($this->devisOfDefunt['devis_date'])) {
|
||||
$this->Cell(0, 8, $this->devisOfDefunt['devis_date']->format('d/m/Y'), 0, 1);
|
||||
} else {
|
||||
$this->Cell(0, 8, '', 0, 1);
|
||||
}
|
||||
$this->Ln(3);
|
||||
|
||||
// Lieu d'intervention
|
||||
$this->SetFont('Arial', 'B', 12);
|
||||
$this->Cell(40, 8, 'Lieu d\'intervention :', 0, 0);
|
||||
$this->SetFont('Arial', '', 12);
|
||||
$lieu = isset($this->devisOfDefunt['lieu_intervention']) ?
|
||||
$this->devisOfDefunt['lieu_intervention'] :
|
||||
$this->devisOfDefunt['location_of_devis'];
|
||||
|
||||
// Utiliser MultiCell pour permettre le retour à la ligne
|
||||
$this->SetX(20); // Retour au début de la ligne
|
||||
$this->SetFont('Arial', 'B', 12);
|
||||
$this->Cell(40, 8, 'Lieu d\'intervention :', 0, 1); // 1 pour aller à la ligne suivante
|
||||
$this->SetFont('Arial', '', 12);
|
||||
$this->MultiCell(0, 6, FileExportHelpers::FormatTextForExport($lieu), 0, 'L');
|
||||
|
||||
// Signatures et cachet - juste après le lieu d'intervention
|
||||
$this->Ln(15); // Petit espace après le lieu d'intervention
|
||||
|
||||
if ($this->signatureImageExist) {
|
||||
$this->Image($this->imagePath."sign.png", 140, $this->GetY(), 40, 16);
|
||||
}
|
||||
|
||||
if($this->tamponImageExist) {
|
||||
$this->SetXY(120, $this->GetY() + 20); // Augmenté de 5 à 20 pour plus d'espace
|
||||
$this->Image($this->imagePath."sign.jpg", 120, $this->GetY(), 80, 35);
|
||||
}
|
||||
}
|
||||
|
||||
private function SetPacemakerCertificateTitle()
|
||||
{
|
||||
$this->SetY(y: 85); // Titre plus bas pour éviter l'en-tête
|
||||
$this->SetFont('Arial', 'B', 16);
|
||||
$this->Cell(0, 10, FileExportHelpers::FormatTextForExport('ATTESTATION D\'ABSENCE DE PACEMAKER'), 0, 1, 'C');
|
||||
$this->Ln(5); // Espace réduit après le titre
|
||||
}
|
||||
|
||||
public function MultiAlignCell($w, $h, $text, $border = 0, $ln = 0, $align = 'L', $fill = false)
|
||||
{
|
||||
// Store reset values for (x,y) positions
|
||||
$x = $this->GetX() + $w;
|
||||
$y = $this->GetY();
|
||||
|
||||
// Make a call to FPDF's MultiCell
|
||||
$this->MultiCell($w, $h, $text, $border, $align, $fill);
|
||||
|
||||
// Reset the line position to the right, like in Cell
|
||||
if ($ln == 0) {
|
||||
$this->SetXY($x, $y);
|
||||
}
|
||||
}
|
||||
|
||||
public function NbLines($w, $txt)
|
||||
{
|
||||
// Compute the number of lines a MultiCell of width w will take
|
||||
if (!isset($this->CurrentFont)) {
|
||||
$this->Error('No font has been set');
|
||||
}
|
||||
$cw = $this->CurrentFont['cw'];
|
||||
if ($w == 0) {
|
||||
$w = $this->w - $this->rMargin - $this->x;
|
||||
}
|
||||
$wmax = ($w - 2 * $this->cMargin) * 1000 / $this->FontSize;
|
||||
$s = str_replace("\r", '', (string) $txt);
|
||||
$nb = strlen($s);
|
||||
if ($nb > 0 && $s[$nb - 1] == "\n") {
|
||||
$nb--;
|
||||
}
|
||||
$sep = -1;
|
||||
$i = 0;
|
||||
$j = 0;
|
||||
$l = 0;
|
||||
$nl = 1;
|
||||
while ($i < $nb) {
|
||||
$c = $s[$i];
|
||||
if ($c == "\n") {
|
||||
$i++;
|
||||
$sep = -1;
|
||||
$j = $i;
|
||||
$l = 0;
|
||||
$nl++;
|
||||
continue;
|
||||
}
|
||||
if ($c == ' ') {
|
||||
$sep = $i;
|
||||
}
|
||||
$l += $cw[$c];
|
||||
if ($l > $wmax) {
|
||||
if ($sep == -1) {
|
||||
if ($i == $j) {
|
||||
$i++;
|
||||
}
|
||||
} else {
|
||||
$i = $sep + 1;
|
||||
}
|
||||
$sep = -1;
|
||||
$j = $i;
|
||||
$l = 0;
|
||||
$nl++;
|
||||
} else {
|
||||
$i++;
|
||||
}
|
||||
}
|
||||
return $nl;
|
||||
}
|
||||
}
|
||||
@ -27,38 +27,36 @@ declare(strict_types=1);
|
||||
namespace OCA\Gestion\Service\Certificate\PdfHandler;
|
||||
|
||||
use DateTime;
|
||||
use FPDF;
|
||||
use \FPDF;
|
||||
use OCA\Gestion\Helpers\DateHelpers;
|
||||
use OCA\Gestion\Helpers\FileExportHelpers;
|
||||
use OCA\Gestion\Helpers\PriceHelpers;
|
||||
|
||||
class PacemakerCertificatePdfHandler extends FPDF
|
||||
{
|
||||
|
||||
private $devisOfDefunt = [];
|
||||
private $logo = null;
|
||||
private $signatureImageExist = false;
|
||||
private $imagePath = "/var/www/html/data/admin/files/.gestion/";
|
||||
private $tamponImageExist = false;
|
||||
|
||||
public function Header()
|
||||
function Header()
|
||||
{
|
||||
if ($this->logo != "nothing") {
|
||||
$this->Image($this->imagePath."logo.png", 4, 2, 40, 45);
|
||||
$this->Image($this->imagePath."logo.png", 4, 2, 40, 45);
|
||||
} else {
|
||||
$this->Cell(55, 30, '');
|
||||
}
|
||||
}
|
||||
|
||||
public function Footer()
|
||||
function Footer()
|
||||
{
|
||||
// Augmenter l'espace pour le footer pour éviter les chevauchements
|
||||
$this->SetY(-18);
|
||||
$this->SetFont('Arial', '', 10);
|
||||
$this->MultiCell(0, 5, utf8_decode(html_entity_decode($this->devisOfDefunt['configuration']->legal_one)), 0, 'C');
|
||||
$this->MultiCell(0, 5, utf8_decode(html_entity_decode($this->devisOfDefunt['configuration']->adresse)), 0, 'C');
|
||||
}
|
||||
|
||||
public function SetPacemakerCertificateData(array $devisOfDefunt, $logo = null, $signatureImageExist = false, $tamponImageExist = false)
|
||||
public function SetPacemakerCertificateData(array $devisOfDefunt, $logo = null, $signatureImageExist = false , $tamponImageExist = false)
|
||||
{
|
||||
$this->devisOfDefunt = $devisOfDefunt;
|
||||
$this->logo = $logo;
|
||||
@ -77,27 +75,17 @@ class PacemakerCertificatePdfHandler extends FPDF
|
||||
|
||||
private function SetSigning()
|
||||
{
|
||||
// Ajouter plus d'espace avant la signature et le tampon
|
||||
$this->Ln(5); // Ajouter de l'espace vertical
|
||||
$this->SetXY(140, $this->GetY() + 10);
|
||||
// $this->Cell(0, 10, 'Cachet et signatures');
|
||||
|
||||
// Calculer la position Y pour éviter le chevauchement avec le footer
|
||||
$maxY = $this->GetPageHeight() - 65;
|
||||
$currentY = $this->GetY();
|
||||
|
||||
// Si on est trop bas, ne pas dépasser la limite
|
||||
if ($currentY > $maxY) {
|
||||
$currentY = $maxY;
|
||||
if($this->tamponImageExist){
|
||||
$this->Image($this->imagePath."sign.jpg", 120, $this->GetY() + 8, 80, 30);
|
||||
}
|
||||
|
||||
// Positionner le tampon
|
||||
if($this->tamponImageExist) {
|
||||
$this->Image($this->imagePath."sign.jpg", 120, $currentY, 80, 25); // Réduire la hauteur de 30 à 25
|
||||
}
|
||||
|
||||
// Positionner la signature sous le tampon
|
||||
if ($this->signatureImageExist) {
|
||||
$this->Image($this->imagePath."sign.png", 140, $currentY + 28, 40, 16); // Ajuster la position Y
|
||||
$this->Image($this->imagePath."sign.png", 140, $this->GetY() + 38, 40, 16);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
private function SetPacemakerCertificateContent()
|
||||
@ -105,18 +93,16 @@ class PacemakerCertificatePdfHandler extends FPDF
|
||||
$this->SetFont('Arial', '', 14);
|
||||
$this->MultiCell(0, 7, FileExportHelpers::FormatTextForExport('La Société ' . $this->devisOfDefunt['configuration']->entreprise . ' habilitée sous le numéro ' . $this->devisOfDefunt['thanato_reference'] . ', certifie par la présente que : '));
|
||||
$this->SetFont('Arial', 'B', 14);
|
||||
$this->Cell(0, 12, FileExportHelpers::FormatTextForExport($this->devisOfDefunt['thanato_nom'] . ' ' . $this->devisOfDefunt['thanato_prenom']), 0, 1);
|
||||
$this->Cell(0, 12, FileExportHelpers::FormatTextForExport($this->devisOfDefunt['thanato_nom'] . ' ' . $this->devisOfDefunt['thanato_prenom']), 0, 1);
|
||||
$this->SetFont('Arial', '', 14);
|
||||
$this->MultiCell(0, 7, FileExportHelpers::FormatTextForExport('Employé(e) au sein de notre société et titulaire du diplôme national de Thanatopracteur, a retiré ce jour, la prothèse fonctionnant à pile implantée sur le corps du défunt :'));
|
||||
$this->SetFont('Arial', 'B', 14);
|
||||
$this->Cell(0, 12, FileExportHelpers::FormatTextForExport($this->devisOfDefunt['defunt_nom']), 0, 1);
|
||||
$this->SetFont('Arial', '', 14);
|
||||
$this->Cell(0, 12, FileExportHelpers::FormatTextForExport("Date du décès") . ' : ' . $this->devisOfDefunt['defunt_date'], 0, 1);
|
||||
$this->SetFont('Arial', '', 14);
|
||||
$this->Cell(0, 12, FileExportHelpers::FormatTextForExport("Lieu du décès") . ' : ' . $this->devisOfDefunt['lieu_deces'], 0, 1);
|
||||
$this->Cell(0, 12, FileExportHelpers::FormatTextForExport("Date du décès") . ' : ' . $this->devisOfDefunt['defunt_date'] , 0, 1);
|
||||
$this->SetFont('Arial', '', 14);
|
||||
$this->Cell(0, 12, FileExportHelpers::FormatTextForExport("Qui reposait à l'adresse suivante") . ' : ', 0, 1);
|
||||
|
||||
|
||||
$this->SetFont('Arial', 'B', 14);
|
||||
$this->MultiCell(0, 6, FileExportHelpers::FormatTextForExport($this->devisOfDefunt['location_of_devis']));
|
||||
$this->Ln(6);
|
||||
@ -137,26 +123,24 @@ class PacemakerCertificatePdfHandler extends FPDF
|
||||
0,
|
||||
1
|
||||
);
|
||||
$this->Cell(0, 12, FileExportHelpers::FormatTextForExport("La présente attestation est établie pour faire valoir ce que de droit."), 0, 1);
|
||||
$this->Cell(0, 12, FileExportHelpers::FormatTextForExport("La présente attestation est établie pour faire valoir ce que de droit."), 0, 5);
|
||||
$this->Ln(5);
|
||||
|
||||
// Positionner "Fait le" de manière relative plutôt qu'absolue
|
||||
$this->MultiAlignCell(120, 7, FileExportHelpers::FormatTextForExport('Fait à ') . FileExportHelpers::FormatTextForExport($this->devisOfDefunt['location_of_devis']), 0);
|
||||
$this->SetX(140);
|
||||
$this->Cell(0, 7, 'Fait le ' . $this->devisOfDefunt['devis_date']->format('d/m/Y'), 0);
|
||||
$this->Cell(0, 7, 'le ' . $this->devisOfDefunt['devis_date']->format('d/m/Y'), 0);
|
||||
}
|
||||
|
||||
private function SetPacemakerCertificateTitle()
|
||||
{
|
||||
$this->SetY(y: 50);
|
||||
$this->SetFont('Arial', 'B', 15);
|
||||
$this->Cell(0, 10, 'ATTESTATION DE RECUPERATION DE', 0, 1, 'C');
|
||||
$this->Cell(0, 10, 'PROTHESE FONCTIONNANT AU MOYEN D\'UNE PILE', 0, 1, 'C');
|
||||
$this->SetFont('Arial', 'B', 12);
|
||||
$this->Cell(0, 10, '(dernier alinea de l\'article R.2213-15 du code des collectivites territoriales)', 0, 1, 'C');
|
||||
$this->Ln(10);
|
||||
$this->SetFont('Arial', 'B', 20);
|
||||
$this->Cell(0, 10, 'ATTESTATION DE RETRAIT DE LA', 0, 1, 'C');
|
||||
$this->Cell(0, 10, 'PROTHESE FONCTIONNANT A PILE', 0, 1, 'C');
|
||||
$this->Ln(20);
|
||||
}
|
||||
|
||||
public function MultiAlignCell($w, $h, $text, $border = 0, $ln = 0, $align = 'L', $fill = false)
|
||||
function MultiAlignCell($w, $h, $text, $border = 0, $ln = 0, $align = 'L', $fill = false)
|
||||
{
|
||||
// Store reset values for (x,y) positions
|
||||
$x = $this->GetX() + $w;
|
||||
@ -171,22 +155,19 @@ class PacemakerCertificatePdfHandler extends FPDF
|
||||
}
|
||||
}
|
||||
|
||||
public function NbLines($w, $txt)
|
||||
function NbLines($w, $txt)
|
||||
{
|
||||
// Compute the number of lines a MultiCell of width w will take
|
||||
if (!isset($this->CurrentFont)) {
|
||||
if (!isset($this->CurrentFont))
|
||||
$this->Error('No font has been set');
|
||||
}
|
||||
$cw = $this->CurrentFont['cw'];
|
||||
if ($w == 0) {
|
||||
if ($w == 0)
|
||||
$w = $this->w - $this->rMargin - $this->x;
|
||||
}
|
||||
$wmax = ($w - 2 * $this->cMargin) * 1000 / $this->FontSize;
|
||||
$s = str_replace("\r", '', (string) $txt);
|
||||
$nb = strlen($s);
|
||||
if ($nb > 0 && $s[$nb - 1] == "\n") {
|
||||
if ($nb > 0 && $s[$nb - 1] == "\n")
|
||||
$nb--;
|
||||
}
|
||||
$sep = -1;
|
||||
$i = 0;
|
||||
$j = 0;
|
||||
@ -202,25 +183,21 @@ class PacemakerCertificatePdfHandler extends FPDF
|
||||
$nl++;
|
||||
continue;
|
||||
}
|
||||
if ($c == ' ') {
|
||||
if ($c == ' ')
|
||||
$sep = $i;
|
||||
}
|
||||
$l += $cw[$c];
|
||||
if ($l > $wmax) {
|
||||
if ($sep == -1) {
|
||||
if ($i == $j) {
|
||||
if ($i == $j)
|
||||
$i++;
|
||||
}
|
||||
} else {
|
||||
} else
|
||||
$i = $sep + 1;
|
||||
}
|
||||
$sep = -1;
|
||||
$j = $i;
|
||||
$l = 0;
|
||||
$nl++;
|
||||
} else {
|
||||
} else
|
||||
$i++;
|
||||
}
|
||||
}
|
||||
return $nl;
|
||||
}
|
||||
|
||||
@ -23,11 +23,6 @@ class DevisDataProcessor
|
||||
$data_devis = [];
|
||||
|
||||
foreach ($devisData as $devis) {
|
||||
// Exclure les devis annulés des récapitulatifs
|
||||
if (isset($devis['mentions']) && $devis['mentions'] === 'CANCELED') {
|
||||
continue;
|
||||
}
|
||||
|
||||
$devis_temp = $this->createDevisStructure($devis, $currentConfig);
|
||||
$devis_temp = $this->calculateDevisAmounts($devis_temp, $devis, $filter, $idNextCloud);
|
||||
$data_devis[] = $devis_temp;
|
||||
@ -46,8 +41,6 @@ class DevisDataProcessor
|
||||
'devis_date' => $devis['devis_date'],
|
||||
'lieu_nom' => $devis['lieu_nom'],
|
||||
'lieu_adresse' => $devis['lieu_adresse'],
|
||||
'thanato_nom' => $devis['thanato_nom'],
|
||||
'thanato_prenom' => $devis['thanato_prenom'],
|
||||
'defunt_nom' => $devis['defunt_nom'],
|
||||
'defunt_sexe' => $devis['defunt_sexe'],
|
||||
'client_nom' => $devis['client_nom'],
|
||||
@ -85,9 +78,9 @@ class DevisDataProcessor
|
||||
}
|
||||
|
||||
// Traitement identique aux factures
|
||||
// $produitsReferenceArray = array_unique($produitsReferenceArray);
|
||||
$produitsReferenceArray = array_unique($produitsReferenceArray);
|
||||
$produitsReferenceAsString = implode("-", $produitsReferenceArray);
|
||||
$devis_temp['article'] = !empty($produitsReferenceAsString) ? $produitsReferenceAsString : '';
|
||||
$devis_temp['article'] = !empty($produitsReferenceAsString) ? $produitsReferenceAsString : 'SOINS';
|
||||
|
||||
$devis_temp['montant_tva'] = ($devis_temp['montant_htc'] * $devis_temp['tva']) / 100;
|
||||
$devis_temp['montant_ttc'] = $devis_temp['montant_tva'] + $devis_temp['montant_htc'];
|
||||
|
||||
@ -81,31 +81,16 @@ class DevisPdfGenerator
|
||||
|
||||
private function calculatePagination($totalItems)
|
||||
{
|
||||
if ($totalItems <= 8) {
|
||||
// Tout sur 1 page
|
||||
return [
|
||||
'nb_pages' => 1,
|
||||
'items_per_page' => 15,
|
||||
'current_index' => 0
|
||||
];
|
||||
}
|
||||
|
||||
// Réserver 8 items pour dernière page
|
||||
$itemsAvantDernierePage = $totalItems - 8;
|
||||
$nbPagesNormales = ceil($itemsAvantDernierePage / 15);
|
||||
|
||||
return [
|
||||
'nb_pages' => $nbPagesNormales + 1,
|
||||
'items_per_page' => 15,
|
||||
'nb_pages' => ceil($totalItems / 12), // RÉDUIRE à 12 par page
|
||||
'items_per_page' => 12,
|
||||
'current_index' => 0
|
||||
];
|
||||
}
|
||||
|
||||
// VOICI LA FONCTION CORRIGÉE - 4 paramètres au lieu de 10
|
||||
private function generateSinglePage(PageContext $context, $num_page, &$pagination, &$totals)
|
||||
{
|
||||
$startIndex = $pagination['current_index'];
|
||||
$remainingItems = count($context->dataDevis) - $startIndex;
|
||||
|
||||
$context->pdf->AddPage();
|
||||
$context->pdf->SetAutoPagebreak(false);
|
||||
$context->pdf->SetMargins(0, 0, 10);
|
||||
@ -115,17 +100,7 @@ class DevisPdfGenerator
|
||||
$this->layoutManager->addClientInfoSection($context->pdf, $context->clientInfo, $context->dataDevis[0]);
|
||||
$this->layoutManager->addDocumentTitle($context->pdf, $context->dataDevis[0], $context->year);
|
||||
|
||||
// ✅ Calculer items
|
||||
$isLastPage = ($num_page == $pagination['nb_pages']);
|
||||
$hasAmounts = !$context->montant;
|
||||
|
||||
if ($isLastPage && $hasAmounts) {
|
||||
// Dernière page avec totaux : max 8 items
|
||||
$itemsToProcess = min(8, $remainingItems);
|
||||
} else {
|
||||
// Pages normales : 15 items
|
||||
$itemsToProcess = min(15, $remainingItems);
|
||||
}
|
||||
$itemsToProcess = min($pagination['items_per_page'], count($context->dataDevis) - $pagination['current_index']);
|
||||
|
||||
$config = [
|
||||
'pagination' => $pagination,
|
||||
@ -136,7 +111,7 @@ class DevisPdfGenerator
|
||||
'sansMontant' => $context->montant
|
||||
];
|
||||
|
||||
$finalY = $this->tableRenderer->createDevisTable(
|
||||
$this->tableRenderer->createDevisTable(
|
||||
$context->pdf,
|
||||
$context->dataDevis,
|
||||
$config
|
||||
|
||||
@ -63,18 +63,17 @@ class DevisPdfLayoutManager
|
||||
);
|
||||
}
|
||||
|
||||
public function addLegalFooter($pdf, $config, $tableEndY = 0)
|
||||
public function addLegalFooter($pdf, $config)
|
||||
{
|
||||
$y0 = 280;
|
||||
|
||||
$y0 = 260;
|
||||
$pageWidth = $pdf->GetPageWidth();
|
||||
|
||||
$pdf->SetFont('Arial', '', 6);
|
||||
$pdf->SetXY(1, $y0);
|
||||
$pdf->Cell($pageWidth, 5, mb_convert_encoding(html_entity_decode($config->legal_one), 'ISO-8859-1', 'UTF-8'), 0, 0, 'C');
|
||||
$pdf->SetXY(1, $y0 + 4);
|
||||
$pdf->Cell($pageWidth, 5, mb_convert_encoding(html_entity_decode($config->legal_two), 'ISO-8859-1', 'UTF-8'), 0, 0, 'C');
|
||||
$pdf->Cell($pageWidth, 5, mb_convert_encoding(html_entity_decode($config->legal_one), 'ISO-8859-1', 'UTF-8'), 0, 0, 'C');
|
||||
$pdf->SetXY(1, $y0 + 8);
|
||||
$pdf->Cell($pageWidth, 5, mb_convert_encoding(html_entity_decode($config->legal_two), 'ISO-8859-1', 'UTF-8'), 0, 0, 'C');
|
||||
$pdf->SetXY(1, $y0 + 12);
|
||||
$pdf->Cell($pageWidth, 5, mb_convert_encoding(html_entity_decode($config->telephone), 'ISO-8859-1', 'UTF-8'), 0, 0, 'C');
|
||||
}
|
||||
|
||||
@ -119,17 +118,17 @@ class DevisPdfLayoutManager
|
||||
$pdf->MultiCell(0, 7, trim(\OCA\Gestion\Helpers\FileExportHelpers::FormatTextForExport($clientInfo['address'])));
|
||||
$pdf->SetMargins(0, 0, 0);
|
||||
|
||||
$clientInfoYAxis += 7;
|
||||
$clientInfoYAxis += 14;
|
||||
$pdf->SetXY($clientInfoXAxis, $clientInfoYAxis);
|
||||
$pdf->Cell(0, 7, trim(mb_convert_encoding(html_entity_decode($clientInfo['city']), 'ISO-8859-1', 'UTF-8')));
|
||||
|
||||
if (isset($clientInfo['siret']) && trim($clientInfo['siret']) !== '' && $clientInfo['siret'] !== null) {
|
||||
if (!empty($clientInfo['siret'])) {
|
||||
$clientInfoYAxis += 7;
|
||||
$pdf->SetXY($clientInfoXAxis, $clientInfoYAxis);
|
||||
$pdf->Cell(0, 7, 'Siret: ' . \OCA\Gestion\Helpers\FileExportHelpers::FormatTextForExport($clientInfo['siret']));
|
||||
}
|
||||
|
||||
if (isset($clientInfo['email']) && trim($clientInfo['email']) !== '' && $clientInfo['email'] !== null) {
|
||||
if (!empty($clientInfo['email'])) {
|
||||
$clientInfoYAxis += 7;
|
||||
$pdf->SetXY($clientInfoXAxis, $clientInfoYAxis);
|
||||
$pdf->Cell(0, 7, 'Email: ' . mb_convert_encoding(html_entity_decode($clientInfo['email']), 'ISO-8859-1', 'UTF-8'));
|
||||
|
||||
@ -13,59 +13,41 @@ class DevisPdfTableRenderer
|
||||
$totals = &$config['totals'];
|
||||
$sansMontant = $config['sansMontant'] ?? false;
|
||||
|
||||
// Système de pagination comme les factures
|
||||
$maxItemsPerPage = 22; // Nombre maximum d'éléments par page
|
||||
$startIndex = $pagination['current_index'];
|
||||
$itemsThisPage = min($itemsToProcess, count($dataDevis) - $startIndex);
|
||||
|
||||
$tableEndY = $this->drawTableStructure($pdf, $numPage, $nbPage, $sansMontant, $itemsThisPage);
|
||||
$this->drawTableStructure($pdf, $numPage, $nbPage, $sansMontant);
|
||||
$this->addTableHeaders($pdf, $sansMontant);
|
||||
$this->populateTableData($pdf, $dataDevis, $startIndex, $itemsThisPage, $totals, $sansMontant);
|
||||
|
||||
// Totaux seulement sur la dernière page
|
||||
if ($numPage == $nbPage && !$sansMontant) {
|
||||
$finalY = $this->addTableTotals($pdf, $totals, $tableEndY);
|
||||
} else {
|
||||
$finalY = $tableEndY;
|
||||
$this->addTableTotals($pdf, $totals);
|
||||
}
|
||||
|
||||
return $finalY;
|
||||
}
|
||||
|
||||
private function drawTableStructure($pdf, $numPage, $nbPage, $sansMontant, $itemsOnPage)
|
||||
private function drawTableStructure($pdf, $numPage, $nbPage, $sansMontant)
|
||||
{
|
||||
$pdf->SetLineWidth(0.2);
|
||||
|
||||
$headerHeight = 10;
|
||||
$rowHeight = 10;
|
||||
|
||||
$tableHeight = $headerHeight + ($itemsOnPage * $rowHeight);
|
||||
$endY = 105 + $tableHeight;
|
||||
|
||||
$isLastPage = ($numPage == $nbPage);
|
||||
$hasAmounts = !$sansMontant;
|
||||
|
||||
if ($isLastPage && $hasAmounts) {
|
||||
// Dessiner 3 côtés seulement (haut, gauche, droite)
|
||||
$pdf->Line(5, 105, 205, 105); // Haut
|
||||
$pdf->Line(5, 105, 5, $endY); // Gauche
|
||||
$pdf->Line(205, 105, 205, $endY); // Droite
|
||||
// Pas de ligne du bas - elle sera tracée dans addTableTotals
|
||||
} else {
|
||||
// Dessiner rectangle complet
|
||||
$pdf->Rect(5, 105, 200, $tableHeight, "D");
|
||||
}
|
||||
|
||||
$pdf->Rect(5, 105, 200, 130, "D");
|
||||
$pdf->Line(5, 115, 205, 115);
|
||||
|
||||
$endY = ($numPage == $nbPage && !$sansMontant) ? 225 : 235;
|
||||
|
||||
if (!$sansMontant) {
|
||||
$verticalLines = [24, 41, 58, 77, 102, 127, 147, 167, 178, 189];
|
||||
// Ajustement final des positions des lignes verticales
|
||||
// Article et Défunt de même taille, TTC réduit
|
||||
$verticalLines = [22, 39, 56, 75, 105, 135, 155, 170, 185];
|
||||
} else {
|
||||
$verticalLines = [27, 47, 67, 85, 110, 135, 160];
|
||||
// Pour sans montant: Article et Défunt de même taille
|
||||
$verticalLines = [27, 47, 67, 85, 115, 145];
|
||||
}
|
||||
|
||||
foreach ($verticalLines as $x) {
|
||||
$pdf->Line($x, 105, $x, $endY);
|
||||
}
|
||||
|
||||
return $endY;
|
||||
}
|
||||
|
||||
private function addTableHeaders($pdf, $sansMontant)
|
||||
@ -74,17 +56,16 @@ class DevisPdfTableRenderer
|
||||
|
||||
if (!$sansMontant) {
|
||||
$headers = [
|
||||
[5, 19, "N° Devis"],
|
||||
[24, 17, "N° Dossier"],
|
||||
[41, 17, "N° Commande"],
|
||||
[58, 19, "Date"],
|
||||
[77, 25, "Article"],
|
||||
[102, 25, "Lieu du soin"],
|
||||
[127, 20, "Thanato"],
|
||||
[147, 20, "Défunt"],
|
||||
[167, 11, "H.T."],
|
||||
[178, 11, "TVA"],
|
||||
[189, 16, "T.T.C"]
|
||||
[5, 17, "N° Devis"],
|
||||
[22, 17, "N° Dossier"],
|
||||
[39, 17, "N° Commande"],
|
||||
[56, 19, "Date"],
|
||||
[75, 30, "Article"], // Taille augmentée
|
||||
[105, 30, "Lieu du soin"],
|
||||
[135, 20, "Défunt"], // Taille réduite pour équilibrer
|
||||
[155, 15, "H.T."],
|
||||
[170, 15, "TVA"],
|
||||
[185, 15, "T.T.C"] // Taille réduite
|
||||
];
|
||||
} else {
|
||||
$headers = [
|
||||
@ -92,10 +73,9 @@ class DevisPdfTableRenderer
|
||||
[27, 20, "N° Dossier"],
|
||||
[47, 20, "N° Commande"],
|
||||
[67, 18, "Date"],
|
||||
[85, 25, "Article"],
|
||||
[110, 25, "Lieu du soin"],
|
||||
[135, 25, "Thanato"],
|
||||
[160, 45, "Défunt"]
|
||||
[85, 30, "Article"], // Même taille que Défunt
|
||||
[115, 30, "Lieu du soin"],
|
||||
[145, 30, "Défunt"] // Même taille que Article
|
||||
];
|
||||
}
|
||||
|
||||
@ -146,34 +126,28 @@ class DevisPdfTableRenderer
|
||||
}
|
||||
};
|
||||
|
||||
// Préparer le nom complet du thanatopracteur
|
||||
$thanatoNom = trim(($devis['thanato_prenom'] ?? '') . ' ' . ($devis['thanato_nom'] ?? ''));
|
||||
$thanatoNom = \OCA\Gestion\Helpers\FileExportHelpers::FormatTextForExport($thanatoNom);
|
||||
|
||||
if (!$sansMontant) {
|
||||
$addSmartCell($pdf, 6, $yDevis, 18, $devis['devis_full_number']);
|
||||
$addSmartCell($pdf, 25, $yDevis, 16, $devis['case_number'] ?? '');
|
||||
$addSmartCell($pdf, 42, $yDevis, 16, $devis['order_number'] ?? '');
|
||||
// LARGEURS ÉQUILIBRÉES avec Article et Défunt de même taille
|
||||
$addSmartCell($pdf, 6, $yDevis, 16, $devis['devis_full_number']);
|
||||
$addSmartCell($pdf, 23, $yDevis, 16, $devis['case_number'] ?? '');
|
||||
$addSmartCell($pdf, 40, $yDevis, 16, $devis['order_number'] ?? '');
|
||||
|
||||
$addSmartCell($pdf, 59, $yDevis, 18, mb_convert_encoding($formatterDate->format($dateSoin), 'ISO-8859-1', 'UTF-8'));
|
||||
$addSmartCell($pdf, 57, $yDevis, 18, mb_convert_encoding($formatterDate->format($dateSoin), 'ISO-8859-1', 'UTF-8'));
|
||||
|
||||
$articleText = \OCA\Gestion\Helpers\FileExportHelpers::FormatTextForExport($devis['article'] ?? 'SOINS');
|
||||
$addSmartCell($pdf, 78, $yDevis, 24, $articleText);
|
||||
$addSmartCell($pdf, 76, $yDevis, 29, $articleText); // Article agrandi
|
||||
|
||||
$lieuText = \OCA\Gestion\Helpers\FileExportHelpers::FormatTextForExport($devis['lieu_nom'] ?? '');
|
||||
$addSmartCell($pdf, 103, $yDevis, 24, $lieuText);
|
||||
$addSmartCell($pdf, 106, $yDevis, 29, $lieuText);
|
||||
|
||||
// COLONNE Thanatopracteur (après Lieu du soin)
|
||||
$addSmartCell($pdf, 128, $yDevis, 19, $thanatoNom);
|
||||
|
||||
// COLONNE Défunt (après Thanato)
|
||||
$defuntText = \OCA\Gestion\Helpers\FileExportHelpers::FormatTextForExport($devis['defunt_nom'] ?? '');
|
||||
$addSmartCell($pdf, 148, $yDevis, 19, $defuntText);
|
||||
$addSmartCell($pdf, 136, $yDevis, 19, $defuntText); // Défunt réduit
|
||||
|
||||
$addSmartCell($pdf, 168, $yDevis, 10, number_format($devis['montant_htc'], 2, '.', '') . chr(128), 'R');
|
||||
$addSmartCell($pdf, 179, $yDevis, 10, number_format($devis['montant_tva'], 2, '.', '') . chr(128), 'R');
|
||||
$addSmartCell($pdf, 190, $yDevis, 15, number_format($devis['montant_ttc'], 2, '.', '') . chr(128), 'R');
|
||||
$addSmartCell($pdf, 156, $yDevis, 14, number_format($devis['montant_htc'], 2, '.', '') . chr(128), 'R');
|
||||
$addSmartCell($pdf, 171, $yDevis, 14, number_format($devis['montant_tva'], 2, '.', '') . chr(128), 'R');
|
||||
$addSmartCell($pdf, 186, $yDevis, 14, number_format($devis['montant_ttc'], 2, '.', '') . chr(128), 'R'); // TTC réduit
|
||||
} else {
|
||||
// Pour sans montant: Article et Défunt de même taille
|
||||
$addSmartCell($pdf, 6, $yDevis, 21, $devis['devis_full_number']);
|
||||
$addSmartCell($pdf, 28, $yDevis, 19, $devis['case_number'] ?? '');
|
||||
$addSmartCell($pdf, 48, $yDevis, 19, $devis['order_number'] ?? '');
|
||||
@ -181,58 +155,52 @@ class DevisPdfTableRenderer
|
||||
$addSmartCell($pdf, 68, $yDevis, 17, mb_convert_encoding($formatterDate->format($dateSoin), 'ISO-8859-1', 'UTF-8'));
|
||||
|
||||
$articleText = \OCA\Gestion\Helpers\FileExportHelpers::FormatTextForExport($devis['article'] ?? 'SOINS');
|
||||
$addSmartCell($pdf, 86, $yDevis, 24, $articleText);
|
||||
$addSmartCell($pdf, 86, $yDevis, 29, $articleText); // Article agrandi
|
||||
|
||||
$lieuText = \OCA\Gestion\Helpers\FileExportHelpers::FormatTextForExport($devis['lieu_nom'] ?? '');
|
||||
$addSmartCell($pdf, 111, $yDevis, 24, $lieuText);
|
||||
$addSmartCell($pdf, 116, $yDevis, 29, $lieuText);
|
||||
|
||||
// COLONNE Thanatopracteur (après Lieu du soin)
|
||||
$addSmartCell($pdf, 136, $yDevis, 24, $thanatoNom);
|
||||
|
||||
// COLONNE Défunt (après Thanato)
|
||||
$defuntText = \OCA\Gestion\Helpers\FileExportHelpers::FormatTextForExport($devis['defunt_nom'] ?? '');
|
||||
$addSmartCell($pdf, 161, $yDevis, 44, $defuntText);
|
||||
$addSmartCell($pdf, 146, $yDevis, 29, $defuntText); // Défunt réduit
|
||||
}
|
||||
}
|
||||
|
||||
private function addTableTotals($pdf, $totals, $tableEndY)
|
||||
private function addTableTotals($pdf, $totals)
|
||||
{
|
||||
$totalEndY = $tableEndY + 8;
|
||||
|
||||
$pdf->SetLineWidth(0.2);
|
||||
|
||||
// Juste les lignes horizontales haut et bas
|
||||
$pdf->Line(5, $tableEndY, 205, $tableEndY);
|
||||
$pdf->Line(5, $totalEndY, 205, $totalEndY);
|
||||
|
||||
$pdf->Line(5, $tableEndY, 5, $totalEndY);
|
||||
$pdf->Line(205, $tableEndY, 205, $totalEndY);
|
||||
|
||||
$pdf->Line(5, 225, 205, 225);
|
||||
$pdf->SetFont('Arial', 'B', 8);
|
||||
|
||||
$pdf->SetXY(5, $tableEndY);
|
||||
$pdf->Cell(162, 8, 'TOTAL', 0, 0, 'C');
|
||||
// Alignement des totaux avec les colonnes HT, TVA, TTC
|
||||
$pdf->SetXY(5, 225);
|
||||
$pdf->Cell(130, 8, 'TOTAL', 0, 0, 'C');
|
||||
|
||||
$pdf->SetXY(167, $tableEndY);
|
||||
$pdf->Cell(9, 8, number_format($totals['ht'], 2, '.', '') . chr(128), 0, 0, 'R');
|
||||
// POSITIONS alignées avec les colonnes du tableau
|
||||
$pdf->SetXY(155, 225);
|
||||
$pdf->Cell(15, 8, number_format($totals['ht'], 2, '.', '') . chr(128), 0, 0, 'R');
|
||||
$pdf->SetXY(170, 225);
|
||||
$pdf->Cell(15, 8, number_format($totals['tva'], 2, '.', '') . chr(128), 0, 0, 'R');
|
||||
$pdf->SetXY(185, 225);
|
||||
$pdf->Cell(15, 8, number_format($totals['ttc'], 2, '.', '') . chr(128), 0, 0, 'R');
|
||||
|
||||
$pdf->SetXY(181, $tableEndY);
|
||||
$pdf->Cell(9, 8, number_format($totals['tva'], 2, '.', '') . chr(128), 0, 0, 'R');
|
||||
// CADRE TOTAL TTC - Texte à l'intérieur du cadre aligné à droite
|
||||
$pdf->SetXY(155, 240);
|
||||
$pdf->Cell(30, 8, 'TOTAL TTC', 0, 0, 'C');
|
||||
|
||||
$pdf->SetXY(189, $tableEndY);
|
||||
$pdf->Cell(16, 8, number_format($totals['ttc'], 2, '.', '') . chr(128), 0, 0, 'R');
|
||||
// Valeur alignée avec la fin du tableau tout à droite
|
||||
$pdf->SetXY(185, 240);
|
||||
$pdf->Cell(15, 8, number_format($totals['ttc'], 2, '.', '') . chr(128), 0, 0, 'R');
|
||||
|
||||
$cadreY = $totalEndY + 3;
|
||||
// Cadre TOTAL TTC aligné avec la fin du tableau (205)
|
||||
$lines = [
|
||||
[155, 240, 155, 248], // Ligne verticale gauche
|
||||
[185, 240, 185, 248], // Ligne de séparation
|
||||
[205, 240, 205, 248], // Ligne verticale droite (alignée avec fin du tableau)
|
||||
[155, 240, 205, 240], // Ligne horizontale haute
|
||||
[155, 248, 205, 248] // Ligne horizontale basse
|
||||
];
|
||||
|
||||
$pdf->SetXY(170, $cadreY + 1);
|
||||
$pdf->Cell(19, 6, 'TOTAL TTC', 0, 0, 'C');
|
||||
|
||||
$pdf->SetXY(189, $cadreY + 1);
|
||||
$pdf->Cell(16, 6, number_format($totals['ttc'], 2, '.', '') . chr(128), 0, 0, 'C');
|
||||
|
||||
$pdf->Rect(170, $cadreY, 35, 8, 'D');
|
||||
$pdf->Line(189, $cadreY, 189, $cadreY + 8);
|
||||
|
||||
return $cadreY + 8;
|
||||
foreach ($lines as $line) {
|
||||
$pdf->Line($line[0], $line[1], $line[2], $line[3]);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@ -30,102 +30,94 @@ use OCA\Gestion\Db\Bdd;
|
||||
use OCA\Gestion\Helpers\FileExportHelpers;
|
||||
use Psr\Log\LoggerInterface;
|
||||
|
||||
class ExportClientStatisticService
|
||||
{
|
||||
/** @var Bdd */
|
||||
private $gestionBdd;
|
||||
class ExportClientStatisticService {
|
||||
/** @var Bdd */
|
||||
private $gestionBdd;
|
||||
|
||||
/** @var LoggerInterface */
|
||||
private $logger;
|
||||
/** @var LoggerInterface */
|
||||
private $logger;
|
||||
|
||||
public function __construct(
|
||||
Bdd $gestionBdd,
|
||||
LoggerInterface $logger
|
||||
) {
|
||||
$this->logger = $logger;
|
||||
$this->gestionBdd = $gestionBdd;
|
||||
}
|
||||
public function __construct(
|
||||
Bdd $gestionBdd,
|
||||
LoggerInterface $logger) {
|
||||
$this->logger = $logger;
|
||||
$this->gestionBdd = $gestionBdd;
|
||||
}
|
||||
|
||||
public function getFileName(array $clientIds)
|
||||
{
|
||||
public function getFileName(array $clientIds){
|
||||
$filename = "";
|
||||
$clients = $this->gestionBdd->getClientsByClientsID($clientIds);
|
||||
foreach($clients as $client) {
|
||||
foreach($clients as $client){
|
||||
$filename .= $client['client_nom'] . '-' . $client['client_entreprise'] . '--';
|
||||
}
|
||||
$filename = rtrim($filename, '-');
|
||||
$filename = str_replace(' ', '-', $filename);
|
||||
$filename = str_replace(' ', '-', $filename);
|
||||
$filename = str_replace(' ','-', $filename);
|
||||
$filename = str_replace(' ','-', $filename);
|
||||
return $filename;
|
||||
}
|
||||
|
||||
public function getExportClientFileHeader(): string
|
||||
{
|
||||
$fileHeader =
|
||||
'CLIENT'.';'.
|
||||
public function getExportClientFileHeader(): string{
|
||||
$fileHeader =
|
||||
'CLIENT'.';'.
|
||||
'MOIS'.';'.
|
||||
'ANNEE'.';'.
|
||||
'NB DE DEFUNTS'.';';
|
||||
'NB DE DEFUNTS'.';';
|
||||
|
||||
$produitList = $this->gestionBdd->getProduitsListAsArray();
|
||||
foreach($produitList as $produit) {
|
||||
$fileHeader .= FileExportHelpers::FormatTextForExport($produit['reference']).';';
|
||||
}
|
||||
$fileHeader .= 'TOTAL HT'.';'."\n";
|
||||
return $fileHeader;
|
||||
}
|
||||
$produitList = $this->gestionBdd->getProduitsListAsArray();
|
||||
foreach($produitList as $produit){
|
||||
$fileHeader .= FileExportHelpers::FormatTextForExport($produit['reference']).';';
|
||||
}
|
||||
$fileHeader .= 'TOTAL HT'.';'."\n";
|
||||
return $fileHeader;
|
||||
}
|
||||
|
||||
public function populateExportDataIntoFileContent(array $exportData, string $fileContent): string
|
||||
{
|
||||
foreach($exportData as $clientId => $clientData) {
|
||||
$clientName = $clientData["client_name"];
|
||||
$clientStatPerMonth = $clientData["client_data"];
|
||||
$totalPrice = 0;
|
||||
if(!empty($clientStatPerMonth)) {
|
||||
foreach($clientStatPerMonth as $month => $stat) {
|
||||
$stat["client_name"] = $clientName;
|
||||
$totalPrice += $stat["total_price"];
|
||||
$fileContent = $this->populateClientStatDataIntoFileContent($fileContent, $month, $stat);
|
||||
}
|
||||
$fileContent = $this->populateTotalPriceIntoFileContent($fileContent, $totalPrice, count($stat["products"]));
|
||||
}
|
||||
}
|
||||
return $fileContent;
|
||||
}
|
||||
public function populateExportDataIntoFileContent(array $exportData,string $fileContent): string{
|
||||
foreach($exportData as $clientId => $clientData){
|
||||
$clientName = $clientData["client_name"];
|
||||
$clientStatPerMonth = $clientData["client_data"];
|
||||
$totalPrice = 0;
|
||||
if(!empty($clientStatPerMonth)){
|
||||
foreach($clientStatPerMonth as $month => $stat){
|
||||
$stat["client_name"] = $clientName;
|
||||
$totalPrice+=$stat["total_price"];
|
||||
$fileContent = $this->populateClientStatDataIntoFileContent($fileContent,$month,$stat);
|
||||
}
|
||||
$fileContent = $this->populateTotalPriceIntoFileContent($fileContent,$totalPrice,count($stat["products"]));
|
||||
}
|
||||
}
|
||||
return $fileContent;
|
||||
}
|
||||
|
||||
private function populateTotalPriceIntoFileContent(string $fileContent, $totalPrice, $productsCount)
|
||||
{
|
||||
$fileContent = $fileContent.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';';
|
||||
while($productsCount > 0) {
|
||||
$fileContent .= ''.';';
|
||||
$productsCount--;
|
||||
}
|
||||
$fileContent .= "$totalPrice".";"."\n";
|
||||
return $fileContent;
|
||||
}
|
||||
private function populateTotalPriceIntoFileContent(string $fileContent,$totalPrice,$productsCount){
|
||||
$fileContent = $fileContent.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';';
|
||||
while($productsCount > 0){
|
||||
$fileContent .= ''.';';
|
||||
$productsCount--;
|
||||
}
|
||||
$fileContent .= "$totalPrice".";"."\n";
|
||||
return $fileContent;
|
||||
}
|
||||
|
||||
private function populateClientStatDataIntoFileContent(string $fileContent, $month, array $statPerMonth)
|
||||
{
|
||||
$yearValue = $statPerMonth["year"];
|
||||
$defuntCount = $statPerMonth["defunt_count"];
|
||||
$products = $statPerMonth["products"];
|
||||
$priceTotal = $statPerMonth["total_price"];
|
||||
private function populateClientStatDataIntoFileContent(string $fileContent,$month,array $statPerMonth){
|
||||
$yearValue = $statPerMonth["year"];
|
||||
$defuntCount = $statPerMonth["defunt_count"];
|
||||
$products = $statPerMonth["products"];
|
||||
|
||||
$fileContent = $fileContent.
|
||||
FileExportHelpers::FormatTextForExport($statPerMonth['client_name']).';'.
|
||||
"$month".';'.
|
||||
"$yearValue".';'.
|
||||
"$defuntCount".';';
|
||||
|
||||
$fileContent = $fileContent.
|
||||
FileExportHelpers::FormatTextForExport($statPerMonth['client_name']).';'.
|
||||
"$month".';'.
|
||||
"$yearValue".';'.
|
||||
"$defuntCount".';';
|
||||
foreach($products as $productCount){
|
||||
$fileContent .= "$productCount".";";
|
||||
}
|
||||
$fileContent .= "\n";
|
||||
return $fileContent;
|
||||
|
||||
foreach($products as $productCount) {
|
||||
$fileContent .= "$productCount".";";
|
||||
}
|
||||
$fileContent .= "$priceTotal".';'."\n";
|
||||
return $fileContent;
|
||||
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@ -34,158 +34,149 @@ use OCA\Gestion\Constants\BddConstant;
|
||||
use OCA\Gestion\Helpers\FileExportHelpers;
|
||||
use OCA\Gestion\Constants\AbsenceTypeConstant;
|
||||
|
||||
class ExportThanatoStatisticService
|
||||
{
|
||||
/** @var Bdd */
|
||||
private $gestionBdd;
|
||||
class ExportThanatoStatisticService {
|
||||
/** @var Bdd */
|
||||
private $gestionBdd;
|
||||
|
||||
/** @var LoggerInterface */
|
||||
private $logger;
|
||||
/** @var LoggerInterface */
|
||||
private $logger;
|
||||
|
||||
/** @var IRootFolder */
|
||||
private $rootFolder;
|
||||
/** @var IRootFolder */
|
||||
private $rootFolder;
|
||||
|
||||
private $geoService;
|
||||
private $geoService;
|
||||
|
||||
public function __construct(
|
||||
Bdd $gestionBdd,
|
||||
LoggerInterface $logger,
|
||||
IRootFolder $rootFolder,
|
||||
GeoService $geoService
|
||||
) {
|
||||
$this->geoService = $geoService;
|
||||
$this->rootFolder = $rootFolder;
|
||||
$this->logger = $logger;
|
||||
$this->gestionBdd = $gestionBdd;
|
||||
}
|
||||
public function __construct(
|
||||
Bdd $gestionBdd,
|
||||
LoggerInterface $logger,
|
||||
IRootFolder $rootFolder,
|
||||
GeoService $geoService) {
|
||||
$this->geoService = $geoService;
|
||||
$this->rootFolder = $rootFolder;
|
||||
$this->logger = $logger;
|
||||
$this->gestionBdd = $gestionBdd;
|
||||
}
|
||||
|
||||
private function getFilename($thanatoName, $thanatoLastName, $month, $year)
|
||||
{
|
||||
$filename = "$year-$month-";
|
||||
$filename .= $thanatoName . '-' . $thanatoLastName;
|
||||
$filename = str_replace(' ', '-', $filename);
|
||||
$filename = str_replace(' ', '-', $filename);
|
||||
private function getFilename($thanatoName,$thanatoLastName,$month,$year){
|
||||
$filename = "$year-$month-";
|
||||
$filename .= $thanatoName . '-' . $thanatoLastName;
|
||||
$filename = str_replace(' ','-', $filename);
|
||||
$filename = str_replace(' ','-', $filename);
|
||||
return $filename;
|
||||
}
|
||||
}
|
||||
|
||||
private function exportThanatoStatistic($thanatoId, $month, $year, $idNextcloud)
|
||||
{
|
||||
$thanato = $this->gestionBdd->getThanatoById($thanatoId);
|
||||
if($thanato == null) {
|
||||
return null;
|
||||
}
|
||||
$exportData = $this->gestionBdd->getExportThanatoStatisticData($thanatoId, $month, $year);
|
||||
if(empty($exportData)) {
|
||||
return null;
|
||||
}
|
||||
$defaultConfig = json_decode($this->gestionBdd->getConfiguration(BddConstant::DEFAULT_ADMIN_ID_NEXTCLOUD));
|
||||
$racineFolder = html_entity_decode($defaultConfig[0]->path).'/';
|
||||
$thanatoFolder = $racineFolder.'STATISTIQUES/THANATOS/';
|
||||
$fileHeader = $this->getExportThanatoFileHeader();
|
||||
$fileContent = $this->populateExportDataIntoFileContent($exportData, $fileHeader);
|
||||
$storage = $this->rootFolder->getUserFolder($idNextcloud);
|
||||
try {
|
||||
$storage->newFolder($thanatoFolder);
|
||||
} catch(\OCP\Files\NotPermittedException $e) {
|
||||
private function exportThanatoStatistic($thanatoId,$month,$year,$idNextcloud){
|
||||
$thanato = $this->gestionBdd->getThanatoById($thanatoId);
|
||||
if($thanato == null){
|
||||
return null;
|
||||
}
|
||||
$exportData = $this->gestionBdd->getExportThanatoStatisticData($thanatoId,$month,$year);
|
||||
if(empty($exportData)){
|
||||
return null;
|
||||
}
|
||||
$defaultConfig = json_decode($this->gestionBdd->getConfiguration(BddConstant::DEFAULT_ADMIN_ID_NEXTCLOUD));
|
||||
$racineFolder = html_entity_decode($defaultConfig[0]->path).'/';
|
||||
$thanatoFolder = $racineFolder.'STATISTIQUES/THANATOS/';
|
||||
$fileHeader = $this->getExportThanatoFileHeader();
|
||||
$fileContent = $this->populateExportDataIntoFileContent($exportData,$fileHeader);
|
||||
$storage = $this->rootFolder->getUserFolder($idNextcloud);
|
||||
try{
|
||||
$storage->newFolder($thanatoFolder);
|
||||
}
|
||||
catch(\OCP\Files\NotPermittedException $e) {
|
||||
|
||||
}
|
||||
$filename = $this->getFilename($thanato["nom"],$thanato["prenom"],$month,$year);
|
||||
$fileNamePath = $thanatoFolder."STAT-THANATO-" . $filename . '.csv';
|
||||
$storage->newFile($fileNamePath);
|
||||
$file = $storage->get($fileNamePath);
|
||||
$file->putContent($fileContent);
|
||||
return $fileNamePath;
|
||||
}
|
||||
|
||||
}
|
||||
$filename = $this->getFilename($thanato["nom"], $thanato["prenom"], $month, $year);
|
||||
$fileNamePath = $thanatoFolder."STAT-THANATO-" . $filename . '.csv';
|
||||
$storage->newFile($fileNamePath);
|
||||
$file = $storage->get($fileNamePath);
|
||||
$file->putContent($fileContent);
|
||||
return $fileNamePath;
|
||||
}
|
||||
public function exportThanatosListStatistic(array $thanatoIds,$month,$year,$idNextcloud){
|
||||
$filenames = [];
|
||||
foreach($thanatoIds as $thanatoId){
|
||||
$filename = $this->exportThanatoStatistic($thanatoId,$month,$year,$idNextcloud);
|
||||
if($filename != null){
|
||||
$filenames[] = $filename;
|
||||
}
|
||||
}
|
||||
return $filenames;
|
||||
}
|
||||
|
||||
public function exportThanatosListStatistic(array $thanatoIds, $month, $year, $idNextcloud)
|
||||
{
|
||||
$filenames = [];
|
||||
foreach($thanatoIds as $thanatoId) {
|
||||
$filename = $this->exportThanatoStatistic($thanatoId, $month, $year, $idNextcloud);
|
||||
if($filename != null) {
|
||||
$filenames[] = $filename;
|
||||
}
|
||||
}
|
||||
return $filenames;
|
||||
}
|
||||
public function getExportThanatoFileHeader(): string{
|
||||
$fileHeader =
|
||||
'FACTURE'.';'.
|
||||
'THANATOPRACTEUR'.';'.
|
||||
'DATE'.';'.
|
||||
'HEURE DE DEBUT'.';'.
|
||||
'HEURE DE FIN'.';'.
|
||||
'SOINS'.';'.
|
||||
'JOUR/FERIE'.';'.
|
||||
'CONGE'.';'.
|
||||
'REPOS'.';'.
|
||||
'MALADIE'.';'.
|
||||
'NOM ET PRENOM'.';'.
|
||||
'LIEU'.';'.
|
||||
'POMPES FUNEBRES'.';'.
|
||||
'ADRESSE'.';'.
|
||||
'DISTANCE TOTALE KM'.';'.
|
||||
'HEURES TOTAL DE SOIN'.';'.
|
||||
'HEURES TOTAL DE CONGE'.';'.
|
||||
'HEURES TOTAL DE REPOS'.';'.
|
||||
'HEURES TOTAL DE MALADIE'.';'.
|
||||
'HEURES TOTAL DE TRAVAIL'.';'.
|
||||
'HEURES TOTAL DE PARCOURS ENTRE DEVIS'.';'.
|
||||
'NOMBRE DE SOINS ET TOILETTES'.';'.
|
||||
"\n";
|
||||
return $fileHeader;
|
||||
}
|
||||
|
||||
public function getExportThanatoFileHeader(): string
|
||||
{
|
||||
$fileHeader =
|
||||
'DEVIS'.';'.
|
||||
'THANATOPRACTEUR'.';'.
|
||||
'DATE'.';'.
|
||||
'HEURE DE DEBUT'.';'.
|
||||
'HEURE DE FIN'.';'.
|
||||
'SOINS'.';'.
|
||||
'JOUR/FERIE'.';'.
|
||||
'CONGE'.';'.
|
||||
'REPOS'.';'.
|
||||
'MALADIE'.';'.
|
||||
'NOM ET PRENOM'.';'.
|
||||
'LIEU'.';'.
|
||||
'POMPES FUNEBRES'.';'.
|
||||
'ADRESSE'.';'.
|
||||
'DISTANCE TOTALE KM'.';'.
|
||||
'HEURES TOTAL DE SOIN'.';'.
|
||||
'HEURES TOTAL DE CONGE'.';'.
|
||||
'HEURES TOTAL DE REPOS'.';'.
|
||||
'HEURES TOTAL DE MALADIE'.';'.
|
||||
'HEURES TOTAL DE TRAVAIL'.';'.
|
||||
'HEURES TOTAL DE PARCOURS ENTRE DEVIS'.';'.
|
||||
'NOMBRE DE SOINS ET TOILETTES'.';'.
|
||||
"\n";
|
||||
return $fileHeader;
|
||||
}
|
||||
private function populateNoDevisDataInADay(string $fileContent,$leave){
|
||||
$startTimeValue = "";
|
||||
$endTimeValue = "";
|
||||
$leaveValue = "Non";
|
||||
if($leave["onLeave"]){
|
||||
$startTimeValue = $leave["startTime"];
|
||||
$endTimeValue = $leave["endTime"];
|
||||
if($leave["absenceTypeKey"] == AbsenceTypeConstant::LEAVE){
|
||||
$leaveValue = "Oui";
|
||||
}
|
||||
if($leave["absenceTypeKey"] == AbsenceTypeConstant::DISEASE){
|
||||
$diseaseValue = "Oui";
|
||||
}
|
||||
if($leave["absenceTypeKey"] == AbsenceTypeConstant::REST){
|
||||
$restValue = "Oui";
|
||||
}
|
||||
}
|
||||
$fileContent = $fileContent.
|
||||
''.';'.
|
||||
FileExportHelpers::FormatTextForExport($leave['thanatoName']).';'.
|
||||
$leave['date'].';'.
|
||||
$startTimeValue.';'.
|
||||
$endTimeValue.';'.
|
||||
''.';'.
|
||||
DateHelpers::getPublicHolidayText($leave['isPublicHoliday']).';'.
|
||||
$leaveValue.';'.
|
||||
$restValue.';'.
|
||||
$diseaseValue.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'."\n";
|
||||
return $fileContent;
|
||||
}
|
||||
|
||||
private function populateNoDevisDataInADay(string $fileContent, $leave)
|
||||
{
|
||||
$startTimeValue = "";
|
||||
$endTimeValue = "";
|
||||
$leaveValue = "Non";
|
||||
$restValue = "Non"; // AJOUTER CETTE LIGNE
|
||||
$diseaseValue = "Non"; // AJOUTER CETTE LIGNE
|
||||
if($leave["onLeave"]) {
|
||||
$startTimeValue = $leave["startTime"];
|
||||
$endTimeValue = $leave["endTime"];
|
||||
if($leave["absenceTypeKey"] == AbsenceTypeConstant::LEAVE) {
|
||||
$leaveValue = "Oui";
|
||||
}
|
||||
if($leave["absenceTypeKey"] == AbsenceTypeConstant::DISEASE) {
|
||||
$diseaseValue = "Oui";
|
||||
}
|
||||
if($leave["absenceTypeKey"] == AbsenceTypeConstant::REST) {
|
||||
$restValue = "Oui";
|
||||
}
|
||||
}
|
||||
$fileContent = $fileContent.
|
||||
''.';'.
|
||||
FileExportHelpers::FormatTextForExport($leave['thanatoName']).';'.
|
||||
$leave['date'].';'.
|
||||
$startTimeValue.';'.
|
||||
$endTimeValue.';'.
|
||||
''.';'.
|
||||
DateHelpers::getPublicHolidayText($leave['isPublicHoliday']).';'.
|
||||
$leaveValue.';'.
|
||||
$restValue.';'.
|
||||
$diseaseValue.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'."\n";
|
||||
return $fileContent;
|
||||
}
|
||||
|
||||
public function populateExportDataIntoFileContent(array $exportData, string $fileContent): string
|
||||
{
|
||||
public function populateExportDataIntoFileContent(array $exportData,string $fileContent): string{
|
||||
|
||||
$g_totalDistance = 0;
|
||||
$g_totalDevisHours = 0;
|
||||
@ -194,81 +185,81 @@ class ExportThanatoStatisticService
|
||||
$g_totalTravelingHoursBetweenDevisLocation = 0;
|
||||
$g_totalDiseaseHours = 0;
|
||||
$g_totalRestHours = 0;
|
||||
$g_totalDevisCount = 0;
|
||||
$g_totalDevisCount = 0;
|
||||
|
||||
foreach($exportData as $devisDate => $devisData) {
|
||||
$totalDevisHours = 0;
|
||||
$totalWorkedHours = 8;
|
||||
$totalLeaveHours = 0;
|
||||
$totalDiseaseHours = 0;
|
||||
$totalRestHours = 0;
|
||||
$totalDistance = 0;
|
||||
$totalDevisCount = 0;
|
||||
$totalTravelingHoursBetweenDevisLocation = 0;
|
||||
$hasDevisInTheCurrentDate = $devisData['hasDevis'];
|
||||
if($hasDevisInTheCurrentDate === false) {
|
||||
$leaves = $devisData["leaves"];
|
||||
foreach($leaves as $leave) {
|
||||
$fileContent = $this->populateNoDevisDataInADay($fileContent, $leave);
|
||||
if($leave["onLeave"]) {
|
||||
$totalLeaveHoursInsideWorkingHours = $leave["totalWorkedHours"];
|
||||
if($leave["absenceTypeKey"] == AbsenceTypeConstant::LEAVE) {
|
||||
$totalLeaveHours += $totalLeaveHoursInsideWorkingHours;
|
||||
}
|
||||
if($leave["absenceTypeKey"] == AbsenceTypeConstant::REST) {
|
||||
$totalRestHours += $totalLeaveHoursInsideWorkingHours;
|
||||
}
|
||||
if($leave["absenceTypeKey"] == AbsenceTypeConstant::DISEASE) {
|
||||
$totalDiseaseHours += $totalLeaveHoursInsideWorkingHours;
|
||||
}
|
||||
}
|
||||
}
|
||||
$totalAbsenceHours = $totalLeaveHours + $totalRestHours + $totalDiseaseHours;
|
||||
$totalWorkedHours -= $totalAbsenceHours;
|
||||
} else {
|
||||
$totalDevisCount += count($devisData["devisId"]);
|
||||
$routeLines = $this->gestionBdd->getRouteLinesByDevisIdList($devisData["devisId"]);
|
||||
$totalDistanceAndTotalTravelingHoursBetweenDevis = $this->geoService->getTotalDistanceAndTotalTravelingHoursBetweenDevisLocationByRouteLines($routeLines);
|
||||
$totalDistance = $totalDistanceAndTotalTravelingHoursBetweenDevis["totalDistance"];
|
||||
$totalTravelingHoursBetweenDevisLocation = $totalDistanceAndTotalTravelingHoursBetweenDevis["totalTravelingHours"];
|
||||
$devisList = $devisData["devis"];
|
||||
$leaves = $devisData["leaves"];
|
||||
if(!empty($devisList)) {
|
||||
foreach($devisList as $devis) {
|
||||
$fileContent = $this->populateDevisDataIntoThanatoExportFileContent($fileContent, $devis);
|
||||
$totalDevisHours += $devis["totalHours"];
|
||||
}
|
||||
}
|
||||
foreach($leaves as $leave) {
|
||||
$fileContent = $this->populateNoDevisDataInADay($fileContent, $leave);
|
||||
if($leave["onLeave"]) {
|
||||
$totalLeaveHoursInsideWorkingHours = $leave["totalWorkedHours"];
|
||||
if($leave["absenceTypeKey"] == AbsenceTypeConstant::LEAVE) {
|
||||
$totalLeaveHours += $totalLeaveHoursInsideWorkingHours;
|
||||
}
|
||||
if($leave["absenceTypeKey"] == AbsenceTypeConstant::REST) {
|
||||
$totalRestHours += $totalLeaveHoursInsideWorkingHours;
|
||||
}
|
||||
if($leave["absenceTypeKey"] == AbsenceTypeConstant::DISEASE) {
|
||||
$totalDiseaseHours += $totalLeaveHoursInsideWorkingHours;
|
||||
}
|
||||
}
|
||||
}
|
||||
$totalAbsenceHours = $totalLeaveHours + $totalRestHours + $totalDiseaseHours;
|
||||
$totalWorkedHours -= $totalAbsenceHours;
|
||||
}
|
||||
foreach($exportData as $devisDate => $devisData){
|
||||
$totalDevisHours = 0;
|
||||
$totalWorkedHours = 8;
|
||||
$totalLeaveHours = 0;
|
||||
$totalDiseaseHours = 0;
|
||||
$totalRestHours = 0;
|
||||
$totalDistance = 0;
|
||||
$totalDevisCount = 0;
|
||||
$totalTravelingHoursBetweenDevisLocation = 0;
|
||||
$hasDevisInTheCurrentDate = $devisData['hasDevis'];
|
||||
if($hasDevisInTheCurrentDate === false){
|
||||
$leaves = $devisData["leaves"];
|
||||
foreach($leaves as $leave){
|
||||
$fileContent = $this->populateNoDevisDataInADay($fileContent,$leave);
|
||||
if($leave["onLeave"]){
|
||||
$totalLeaveHoursInsideWorkingHours = $leave["totalWorkedHours"];
|
||||
if($leave["absenceTypeKey"] == AbsenceTypeConstant::LEAVE ){
|
||||
$totalLeaveHours += $totalLeaveHoursInsideWorkingHours;
|
||||
}
|
||||
if($leave["absenceTypeKey"] == AbsenceTypeConstant::REST){
|
||||
$totalRestHours += $totalLeaveHoursInsideWorkingHours;
|
||||
}
|
||||
if($leave["absenceTypeKey"] == AbsenceTypeConstant::DISEASE){
|
||||
$totalDiseaseHours += $totalLeaveHoursInsideWorkingHours;
|
||||
}
|
||||
}
|
||||
}
|
||||
$totalAbsenceHours = $totalLeaveHours + $totalRestHours + $totalDiseaseHours;
|
||||
$totalWorkedHours -= $totalAbsenceHours;
|
||||
}
|
||||
else{
|
||||
$totalDevisCount += count($devisData["devisId"]);
|
||||
$routeLines = $this->gestionBdd->getRouteLinesByDevisIdList($devisData["devisId"]);
|
||||
$totalDistanceAndTotalTravelingHoursBetweenDevis = $this->geoService->getTotalDistanceAndTotalTravelingHoursBetweenDevisLocationByRouteLines($routeLines);
|
||||
$totalDistance = $totalDistanceAndTotalTravelingHoursBetweenDevis["totalDistance"];
|
||||
$totalTravelingHoursBetweenDevisLocation = $totalDistanceAndTotalTravelingHoursBetweenDevis["totalTravelingHours"];
|
||||
$devisList = $devisData["devis"];
|
||||
$leaves = $devisData["leaves"];
|
||||
if(!empty($devisList)){
|
||||
foreach($devisList as $devis){
|
||||
$fileContent = $this->populateDevisDataIntoThanatoExportFileContent($fileContent,$devis);
|
||||
$totalDevisHours += $devis["totalHours"];
|
||||
}
|
||||
}
|
||||
foreach($leaves as $leave){
|
||||
$fileContent = $this->populateNoDevisDataInADay($fileContent,$leave);
|
||||
if($leave["onLeave"]){
|
||||
$totalLeaveHoursInsideWorkingHours = $leave["totalWorkedHours"];
|
||||
if($leave["absenceTypeKey"] == AbsenceTypeConstant::LEAVE){
|
||||
$totalLeaveHours += $totalLeaveHoursInsideWorkingHours;
|
||||
}
|
||||
if($leave["absenceTypeKey"] == AbsenceTypeConstant::REST){
|
||||
$totalRestHours += $totalLeaveHoursInsideWorkingHours;
|
||||
}
|
||||
if($leave["absenceTypeKey"] == AbsenceTypeConstant::DISEASE){
|
||||
$totalDiseaseHours += $totalLeaveHoursInsideWorkingHours;
|
||||
}
|
||||
}
|
||||
}
|
||||
$totalAbsenceHours = $totalLeaveHours + $totalRestHours + $totalDiseaseHours;
|
||||
$totalWorkedHours -= $totalAbsenceHours;
|
||||
}
|
||||
|
||||
$fileContent = $this->populateLastRecapForTheLine(
|
||||
$fileContent,
|
||||
$totalDistance,
|
||||
$totalDevisHours,
|
||||
$totalWorkedHours,
|
||||
$totalLeaveHours,
|
||||
$totalTravelingHoursBetweenDevisLocation,
|
||||
$totalDiseaseHours,
|
||||
$totalRestHours,
|
||||
$totalDevisCount
|
||||
);
|
||||
$fileContent = $this->populateLastRecapForTheLine(
|
||||
$fileContent,
|
||||
$totalDistance,
|
||||
$totalDevisHours,
|
||||
$totalWorkedHours,
|
||||
$totalLeaveHours,
|
||||
$totalTravelingHoursBetweenDevisLocation,
|
||||
$totalDiseaseHours,
|
||||
$totalRestHours,$totalDevisCount
|
||||
);
|
||||
|
||||
$g_totalDistance += $totalDistance;
|
||||
$g_totalDevisHours += $totalDevisHours;
|
||||
@ -277,8 +268,8 @@ class ExportThanatoStatisticService
|
||||
$g_totalTravelingHoursBetweenDevisLocation += $totalTravelingHoursBetweenDevisLocation;
|
||||
$g_totalDiseaseHours += $totalDiseaseHours;
|
||||
$g_totalRestHours += $totalRestHours;
|
||||
$g_totalDevisCount += $totalDevisCount;
|
||||
}
|
||||
$g_totalDevisCount += $totalDevisCount;
|
||||
}
|
||||
|
||||
$fileContent = $this->populateLastRecapForTheLine(
|
||||
$fileContent,
|
||||
@ -288,113 +279,77 @@ class ExportThanatoStatisticService
|
||||
$g_totalLeaveHours,
|
||||
$g_totalTravelingHoursBetweenDevisLocation,
|
||||
$g_totalDiseaseHours,
|
||||
$g_totalRestHours,
|
||||
$g_totalDevisCount
|
||||
$g_totalRestHours,$g_totalDevisCount
|
||||
);
|
||||
|
||||
return $fileContent;
|
||||
}
|
||||
return $fileContent;
|
||||
}
|
||||
|
||||
private function populateLastRecapForTheLine(string $fileContent, $distance, $totalDevisHours, $totalWorkedHours, $totalLeaveHours, $totalTravelingHours, $totalDiseaseHours = 0, $totalRestHours = 0, $totalDevisCount = 0)
|
||||
{
|
||||
$fileContent = $fileContent.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
"$distance".';'.
|
||||
"$totalDevisHours".';'.
|
||||
"$totalLeaveHours".';'.
|
||||
"$totalRestHours".';'.
|
||||
"$totalDiseaseHours".';'.
|
||||
"$totalWorkedHours".';'.
|
||||
"$totalTravelingHours".';'.
|
||||
"$totalDevisCount"."\n";
|
||||
return $fileContent;
|
||||
}
|
||||
private function populateLastRecapForTheLine(string $fileContent,$distance,$totalDevisHours,$totalWorkedHours,$totalLeaveHours,$totalTravelingHours ,$totalDiseaseHours = 0,$totalRestHours = 0,$totalDevisCount = 0){
|
||||
$fileContent = $fileContent.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
"$distance".';'.
|
||||
"$totalDevisHours".';'.
|
||||
"$totalLeaveHours".';'.
|
||||
"$totalRestHours".';'.
|
||||
"$totalDiseaseHours".';'.
|
||||
"$totalWorkedHours".';'.
|
||||
"$totalTravelingHours".';'.
|
||||
"$totalDevisCount"."\n";
|
||||
return $fileContent;
|
||||
}
|
||||
|
||||
private function getFormatDevisProduitsAsString($devisProduits)
|
||||
{
|
||||
$result = '';
|
||||
foreach ($devisProduits as $produit) {
|
||||
$result .= $produit['produit_reference'] . '-' . $produit['produit_description'] . '--';
|
||||
}
|
||||
// Remove the trailing "--" at the end
|
||||
$result = rtrim($result, '-');
|
||||
return $result;
|
||||
}
|
||||
private function getFormatDevisProduitsAsString($devisProduits){
|
||||
$result = '';
|
||||
foreach ($devisProduits as $produit) {
|
||||
$result .= $produit['produit_reference'] . '-' . $produit['produit_description'] . '--';
|
||||
}
|
||||
// Remove the trailing "--" at the end
|
||||
$result = rtrim($result, '-');
|
||||
return $result;
|
||||
}
|
||||
|
||||
private function populateDevisDataIntoThanatoExportFileContentSave(string $fileContent, array $devis)
|
||||
{
|
||||
$produitAsString = $this->getFormatDevisProduitsAsString($devis["produits"]);
|
||||
$factureNum = $devis["facture_num"] ?? $devis["facture_on_group_num"] ?? "";
|
||||
$fileContent = $fileContent.
|
||||
FileExportHelpers::FormatTextForExport($factureNum).';'.
|
||||
FileExportHelpers::FormatTextForExport($devis['nom_thanato'] . ' ' . $devis['prenom_thanatho']).';'.
|
||||
FileExportHelpers::FormatTextForExport($devis["date"]).';'.
|
||||
FileExportHelpers::FormatTextForExport($devis["startTime"]).';'.
|
||||
FileExportHelpers::FormatTextForExport($devis["endTime"]).';'.
|
||||
FileExportHelpers::FormatTextForExport($produitAsString).';'.
|
||||
FileExportHelpers::FormatTextForExport($devis["dayType"]).';'.
|
||||
FileExportHelpers::FormatTextForExport('Non').';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
FileExportHelpers::FormatTextForExport($devis["nom_defunt"]).';'.
|
||||
FileExportHelpers::FormatTextForExport($devis["nom_lieu"] ?? "").';'.
|
||||
FileExportHelpers::FormatTextForExport($devis["nom_client"] ?? "").';'.
|
||||
FileExportHelpers::FormatTextForExport($devis["client_adresse"] ?? "").
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'."\n";
|
||||
private function populateDevisDataIntoThanatoExportFileContent(string $fileContent,array $devis){
|
||||
$produitAsString = $this->getFormatDevisProduitsAsString($devis["produits"]);
|
||||
$factureNum = $devis["facture_num"] ?? $devis["facture_on_group_num"] ?? "";
|
||||
$fileContent = $fileContent.
|
||||
FileExportHelpers::FormatTextForExport($factureNum).';'.
|
||||
FileExportHelpers::FormatTextForExport($devis['nom_thanato'] . ' ' . $devis['prenom_thanatho']).';'.
|
||||
FileExportHelpers::FormatTextForExport($devis["date"]).';'.
|
||||
FileExportHelpers::FormatTextForExport($devis["startTime"]).';'.
|
||||
FileExportHelpers::FormatTextForExport($devis["endTime"]).';'.
|
||||
FileExportHelpers::FormatTextForExport($produitAsString).';'.
|
||||
FileExportHelpers::FormatTextForExport($devis["dayType"]).';'.
|
||||
FileExportHelpers::FormatTextForExport('Non').';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
FileExportHelpers::FormatTextForExport($devis["nom_defunt"]).';'.
|
||||
FileExportHelpers::FormatTextForExport($devis["nom_lieu"] ?? "").';'.
|
||||
FileExportHelpers::FormatTextForExport($devis["nom_client"] ?? "").';'.
|
||||
FileExportHelpers::FormatTextForExport($devis["client_adresse"] ?? "").
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'."\n";
|
||||
|
||||
return $fileContent;
|
||||
|
||||
return $fileContent;
|
||||
|
||||
}
|
||||
|
||||
private function populateDevisDataIntoThanatoExportFileContent(string $fileContent, array $devis)
|
||||
{
|
||||
$produitAsString = $this->getFormatDevisProduitsAsString($devis["produits"]);
|
||||
$devisNum = (string)($devis["calendar_uuid"] ?? "");
|
||||
|
||||
$fileContent = $fileContent.
|
||||
FileExportHelpers::FormatTextForExport($devisNum).';'.
|
||||
FileExportHelpers::FormatTextForExport(($devis['nom_thanato'] ?? '') . ' ' . ($devis['prenom_thanato'] ?? '')).';'.
|
||||
FileExportHelpers::FormatTextForExport($devis["date"] ?? "").';'.
|
||||
FileExportHelpers::FormatTextForExport($devis["startTime"] ?? "").';'.
|
||||
FileExportHelpers::FormatTextForExport($devis["endTime"] ?? "").';'.
|
||||
FileExportHelpers::FormatTextForExport($produitAsString).';'.
|
||||
FileExportHelpers::FormatTextForExport($devis["dayType"] ?? "").';'.
|
||||
'Non'.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
FileExportHelpers::FormatTextForExport($devis["nom_defunt"] ?? "").';'. // ICI
|
||||
FileExportHelpers::FormatTextForExport($devis["nom_lieu"] ?? "").';'.
|
||||
FileExportHelpers::FormatTextForExport($devis["nom_client"] ?? "").';'.
|
||||
FileExportHelpers::FormatTextForExport($devis["client_adresse"] ?? "").';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'.
|
||||
''.';'."\n";
|
||||
|
||||
return $fileContent;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@ -30,31 +30,28 @@ use Exception;
|
||||
use OCA\Gestion\Constants\GeoConstant;
|
||||
use OCA\Gestion\Helpers\GeoHelpers;
|
||||
|
||||
class GeoService
|
||||
{
|
||||
public function __construct()
|
||||
{
|
||||
}
|
||||
class GeoService {
|
||||
|
||||
public function __construct() {
|
||||
}
|
||||
|
||||
/**
|
||||
* Calcul la distance entre les deux points à vol d'oiseau
|
||||
*/
|
||||
private function getDistanceInKmBetweenTwoPoints($lat1, $lon1, $lat2, $lon2)
|
||||
{
|
||||
private function getDistanceInKmBetweenTwoPoints($lat1, $lon1, $lat2, $lon2) {
|
||||
$R = 6371; // Rayon moyen de la Terre en kilomètres
|
||||
$dLat = deg2rad($lat2 - $lat1);
|
||||
$dLon = deg2rad($lon2 - $lon1);
|
||||
$a = sin($dLat / 2) * sin($dLat / 2) + cos(deg2rad($lat1)) * cos(deg2rad($lat2)) * sin($dLon / 2) * sin($dLon / 2);
|
||||
$c = 2 * atan2(sqrt($a), sqrt(1 - $a));
|
||||
$a = sin($dLat/2) * sin($dLat/2) + cos(deg2rad($lat1)) * cos(deg2rad($lat2)) * sin($dLon/2) * sin($dLon/2);
|
||||
$c = 2 * atan2(sqrt($a), sqrt(1-$a));
|
||||
$d = $R * $c;
|
||||
return round($d, 2);
|
||||
}
|
||||
|
||||
private function getTravelingHourBetweenTwoPoints(array $origin, array $destination, $mode = "driving")
|
||||
{
|
||||
private function getTravelingHourBetweenTwoPoints(array $origin,array $destination,$mode = "driving"){
|
||||
$baseUrl = "https://api.geoapify.com/v1/routing";
|
||||
$originPoints = GeoHelpers::getPointsTextFromLatitudeAndLongitude($origin["latitude"], $origin["longitude"]);
|
||||
$destinationPoints = GeoHelpers::getPointsTextFromLatitudeAndLongitude($destination["latitude"], $destination["longitude"]);
|
||||
$originPoints = GeoHelpers::getPointsTextFromLatitudeAndLongitude($origin["latitude"],$origin["longitude"]);
|
||||
$destinationPoints = GeoHelpers::getPointsTextFromLatitudeAndLongitude($destination["latitude"],$destination["longitude"]);
|
||||
|
||||
$fullUrl = $baseUrl."?waypoints=$originPoints|$destinationPoints&mode=$mode&apiKey=9e23d93e7f454c988344f9171bf867aa";
|
||||
$curl = curl_init();
|
||||
@ -69,11 +66,11 @@ class GeoService
|
||||
CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
|
||||
CURLOPT_CUSTOMREQUEST => 'GET',
|
||||
));
|
||||
|
||||
|
||||
$response = curl_exec($curl);
|
||||
|
||||
|
||||
curl_close($curl);
|
||||
|
||||
|
||||
if ($response === false) {
|
||||
return 0;
|
||||
} else {
|
||||
@ -82,45 +79,45 @@ class GeoService
|
||||
$travelTimeHours = round($travelTimeHours, 2);
|
||||
return $travelTimeHours;
|
||||
}
|
||||
} catch(Exception $e) {
|
||||
}
|
||||
catch(Exception $e){
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
|
||||
public function getTotalDistanceAndTotalTravelingHoursBetweenDevisLocationByRouteLinesSave(array $routeLines)
|
||||
{
|
||||
public function getTotalDistanceAndTotalTravelingHoursBetweenDevisLocationByRouteLines(array $routeLines){
|
||||
$distanceCumul = 0;
|
||||
$totalTravelingHoursBetweenTwoDevisLocation = 0;
|
||||
$lastPoint = null;
|
||||
for ($i = 0; $i < sizeof($routeLines); $i++) {
|
||||
$lastPoint = NULL;
|
||||
for ($i=0; $i < sizeof($routeLines); $i++) {
|
||||
$currentDistance = 0;
|
||||
if($routeLines[$i]['lieu_id'] != null) {
|
||||
if($routeLines[$i]['lieu_id'] != NULL){
|
||||
$lastPoint = $routeLines[$i];
|
||||
}
|
||||
if($lastPoint['lieu_id'] != null && $routeLines[$i + 1]['lieu_id'] != null) {
|
||||
}
|
||||
if($lastPoint['lieu_id'] != NULL && $routeLines[$i+1]['lieu_id'] != NULL){
|
||||
$currentDistance = $this->getDistanceInKmBetweenTwoPoints(
|
||||
floatval(value: $lastPoint['latitude']),
|
||||
floatval($lastPoint['longitude']),
|
||||
floatval($routeLines[$i + 1]['latitude']),
|
||||
floatval($routeLines[$i + 1]['longitude'])
|
||||
floatval(value: $lastPoint['latitude']),
|
||||
floatval($lastPoint['longitude']),
|
||||
floatval($routeLines[$i+1]['latitude']),
|
||||
floatval($routeLines[$i+1]['longitude'])
|
||||
);
|
||||
$targetIsBetweenTwoDevisLocation = $lastPoint['source'] != "siege" && $routeLines[$i + 1]["source"] != "siege";
|
||||
if($targetIsBetweenTwoDevisLocation) {
|
||||
$targetIsBetweenTwoDevisLocation = $lastPoint['source'] != "siege" && $routeLines[$i+1]["source"] != "siege";
|
||||
if($targetIsBetweenTwoDevisLocation){
|
||||
$originPoints = [
|
||||
"latitude" => $lastPoint["latitude"],
|
||||
"longitude" => $lastPoint["longitude"]
|
||||
];
|
||||
$destinationPoints = [
|
||||
"latitude" => $routeLines[$i + 1]["latitude"],
|
||||
"longitude" => $routeLines[$i + 1]["longitude"]
|
||||
"latitude" => $routeLines[$i+1]["latitude"],
|
||||
"longitude" => $routeLines[$i+1]["longitude"]
|
||||
];
|
||||
$totalTravelingHoursBetweenTwoDevisLocation += $this->getTravelingHourBetweenTwoPoints(
|
||||
$totalTravelingHoursBetweenTwoDevisLocation+= $this->getTravelingHourBetweenTwoPoints(
|
||||
$originPoints,
|
||||
$destinationPoints,
|
||||
GeoConstant::DRIVING_MODE
|
||||
);
|
||||
}
|
||||
}
|
||||
}
|
||||
$distanceCumul += $currentDistance;
|
||||
}
|
||||
return [
|
||||
@ -128,65 +125,4 @@ class GeoService
|
||||
"totalTravelingHours" => $totalTravelingHoursBetweenTwoDevisLocation
|
||||
];
|
||||
}
|
||||
|
||||
public function getTotalDistanceAndTotalTravelingHoursBetweenDevisLocationByRouteLines(array $routeLines)
|
||||
{
|
||||
$distanceCumul = 0;
|
||||
$totalTravelingHoursBetweenTwoDevisLocation = 0;
|
||||
$lastPoint = null;
|
||||
|
||||
for ($i = 0; $i < sizeof($routeLines); $i++) {
|
||||
$currentDistance = 0;
|
||||
|
||||
// Vérifier que l'élément actuel existe
|
||||
if(!isset($routeLines[$i])) {
|
||||
continue;
|
||||
}
|
||||
|
||||
if($routeLines[$i]['lieu_id'] != null) {
|
||||
$lastPoint = $routeLines[$i];
|
||||
}
|
||||
|
||||
// Vérifier que $i+1 existe ET que $lastPoint n'est pas null
|
||||
if($lastPoint !== null &&
|
||||
isset($routeLines[$i + 1]) &&
|
||||
isset($lastPoint['lieu_id']) &&
|
||||
isset($routeLines[$i + 1]['lieu_id']) &&
|
||||
$lastPoint['lieu_id'] != null &&
|
||||
$routeLines[$i + 1]['lieu_id'] != null) {
|
||||
|
||||
$currentDistance = $this->getDistanceInKmBetweenTwoPoints(
|
||||
floatval($lastPoint['latitude']),
|
||||
floatval($lastPoint['longitude']),
|
||||
floatval($routeLines[$i + 1]['latitude']),
|
||||
floatval($routeLines[$i + 1]['longitude'])
|
||||
);
|
||||
|
||||
$targetIsBetweenTwoDevisLocation = $lastPoint['source'] != "siege" && $routeLines[$i + 1]["source"] != "siege";
|
||||
|
||||
if($targetIsBetweenTwoDevisLocation) {
|
||||
$originPoints = [
|
||||
"latitude" => $lastPoint["latitude"],
|
||||
"longitude" => $lastPoint["longitude"]
|
||||
];
|
||||
$destinationPoints = [
|
||||
"latitude" => $routeLines[$i + 1]["latitude"],
|
||||
"longitude" => $routeLines[$i + 1]["longitude"]
|
||||
];
|
||||
$totalTravelingHoursBetweenTwoDevisLocation += $this->getTravelingHourBetweenTwoPoints(
|
||||
$originPoints,
|
||||
$destinationPoints,
|
||||
GeoConstant::DRIVING_MODE
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
$distanceCumul += $currentDistance;
|
||||
}
|
||||
|
||||
return [
|
||||
"totalDistance" => round($distanceCumul, 2),
|
||||
"totalTravelingHours" => round($totalTravelingHoursBetweenTwoDevisLocation, 2)
|
||||
];
|
||||
}
|
||||
}
|
||||
|
||||
@ -50,7 +50,7 @@ class GestionService
|
||||
private $userConnectedUuid;
|
||||
|
||||
/** @var DevisPdfService */
|
||||
private $devisPdfService;
|
||||
private $devisPdfService;
|
||||
|
||||
public function __construct(
|
||||
Bdd $gestionBdd,
|
||||
@ -58,11 +58,12 @@ class GestionService
|
||||
TalkService $talkService,
|
||||
IUserSession $userSession,
|
||||
DevisPdfService $devisPdfService
|
||||
|
||||
) {
|
||||
$this->logger = $logger;
|
||||
$this->gestionBdd = $gestionBdd;
|
||||
$this->talkService = $talkService;
|
||||
$this->devisPdfService = $devisPdfService;
|
||||
$this->devisPdfService = $devisPdfService;
|
||||
|
||||
try {
|
||||
$this->userConnectedUuid = $userSession->getUser()->getUID();
|
||||
@ -162,10 +163,9 @@ class GestionService
|
||||
return $calendarStartDate;
|
||||
}
|
||||
|
||||
private function GetIsPivateFromVCalendarString(string $vCalendarString): bool
|
||||
{
|
||||
private function GetIsPivateFromVCalendarString(string $vCalendarString): bool{
|
||||
$isPrivateValue = VCalendarHelpers::GetValueFromKeyInVCalendarString(VCalendarPropertyConstant::PROPERTY_IS_PRIVATE, $vCalendarString);
|
||||
return $isPrivateValue === "1" ? true : false;
|
||||
return $isPrivateValue === "1" ? true : false;
|
||||
}
|
||||
|
||||
|
||||
@ -182,16 +182,7 @@ class GestionService
|
||||
private function UpdateDevisDataByVCalendarString($devis, $vCalendarString)
|
||||
{
|
||||
$requestedDefuntName = $this->GetCalendarSummaryFromVCalendarString($vCalendarString);
|
||||
|
||||
$lieuDeces = $this->getLieuDecesFromVCalendarString($vCalendarString);
|
||||
$dateNaissance = $this->getDateNaissanceFromVCalendarString($vCalendarString);
|
||||
|
||||
$defuntId = $this->gestionBdd->createOrUpdateDefuntByNameAndReturnDefuntId($devis['defunt_id'], $devis['defunt_nom'], $requestedDefuntName, $lieuDeces, $dateNaissance);
|
||||
file_put_contents(
|
||||
'/var/www/html/data/nextcloud_calendar_debug.log',
|
||||
date('Y-m-d H:i:s') . " - defuntId: " . $defuntId . "\n",
|
||||
FILE_APPEND
|
||||
);
|
||||
$defuntId = $this->gestionBdd->createOrUpdateDefuntByNameAndReturnDefuntId($devis['defunt_id'], $devis['defunt_nom'], $requestedDefuntName);
|
||||
$this->gestionBdd->updateDevisDefunt($devis['id'], $defuntId, $devis['defunt_id']);
|
||||
|
||||
$requestedClientId = $this->GetClientIdFromVCalendarString($vCalendarString);
|
||||
@ -215,11 +206,6 @@ class GestionService
|
||||
private function CheckIfDevisIsAlreadyUpdated($devis, $vCalendarString)
|
||||
{
|
||||
$requestedDefuntName = $this->GetCalendarSummaryFromVCalendarString($vCalendarString);
|
||||
|
||||
$requestedLieuDeces = $this->getLieuDecesFromVCalendarString($vCalendarString);
|
||||
$requestedDateNaissance = $this->getDateNaissanceFromVCalendarString($vCalendarString);
|
||||
$currentDefunt = $this->gestionBdd->getDefuntById($devis['defunt_id']);
|
||||
|
||||
$requestedClientId = $this->GetClientIdFromVCalendarString($vCalendarString);
|
||||
$requestLocationId = $this->GetLocationIdFromVCalendarString($vCalendarString);
|
||||
$requestedDevisComment = $this->GetDevisCommentFromVCalendarString($vCalendarString);
|
||||
@ -240,17 +226,15 @@ class GestionService
|
||||
$devis['lieu_id'] == $requestLocationId &&
|
||||
$devis['comment'] == $requestedDevisComment &&
|
||||
$requestedArticleIds == $articleDevisIds &&
|
||||
$devis['date'] == $requestedDevisDate &&
|
||||
($currentDefunt['lieu_deces'] ?? null) == $requestedLieuDeces &&
|
||||
($currentDefunt['date_naissance'] ?? null) == $requestedDateNaissance;
|
||||
$devis['date'] == $requestedDevisDate;
|
||||
}
|
||||
|
||||
public function HandleUpdatedCalendarObject(string $vCalendarString)
|
||||
{
|
||||
try {
|
||||
$isPrivate = $this->GetIsPivateFromVCalendarString($vCalendarString);
|
||||
$absenceType = VCalendarHelpers::GetValueFromKeyInVCalendarString('ABSENCETYPE', $vCalendarString);
|
||||
if ($isPrivate || $absenceType) {
|
||||
$absenceType = VCalendarHelpers::GetValueFromKeyInVCalendarString('ABSENCETYPE',$vCalendarString);
|
||||
if ($isPrivate || $absenceType ) {
|
||||
//from devis calendar to leave calendar
|
||||
$calendarUuid = $this->GetCalendarUuidFromVCalendarString($vCalendarString);
|
||||
$devis = $this->gestionBdd->getDevisByCalendarUuid($calendarUuid);
|
||||
@ -312,10 +296,10 @@ class GestionService
|
||||
$month,
|
||||
$year
|
||||
);
|
||||
if($oldThanatoTrajet != null) {
|
||||
$thereIsThanatoDevisRattachedToLigneTrajetForADate = $this->gestionBdd->thereIsThanatoDevisRattachedToLigneTrajetForADate($devis['date'], $oldThanatoTrajet['id']);
|
||||
if(!$thereIsThanatoDevisRattachedToLigneTrajetForADate) {
|
||||
$this->gestionBdd->deleteThanatoLigneTrajetForADateByIdTrajet($devis['date'], $oldThanatoTrajet['id']);
|
||||
if($oldThanatoTrajet != null){
|
||||
$thereIsThanatoDevisRattachedToLigneTrajetForADate = $this->gestionBdd->thereIsThanatoDevisRattachedToLigneTrajetForADate($devis['date'], $oldThanatoTrajet['id'] );
|
||||
if(!$thereIsThanatoDevisRattachedToLigneTrajetForADate){
|
||||
$this->gestionBdd->deleteThanatoLigneTrajetForADateByIdTrajet($devis['date'], $oldThanatoTrajet['id'] );
|
||||
}
|
||||
}
|
||||
$this->gestionBdd->updateDevisThanato($devis['id'], $thanato['id']);
|
||||
@ -335,10 +319,10 @@ class GestionService
|
||||
public function HandleCreatedCalendarObject(string $vCalendarString)
|
||||
{
|
||||
try {
|
||||
|
||||
$isPrivate = $this->GetIsPivateFromVCalendarString($vCalendarString);
|
||||
$absenceType = VCalendarHelpers::GetValueFromKeyInVCalendarString('ABSENCETYPE', $vCalendarString);
|
||||
if($isPrivate || $absenceType) {
|
||||
|
||||
$isPrivate = $this->GetIsPivateFromVCalendarString($vCalendarString);
|
||||
$absenceType = VCalendarHelpers::GetValueFromKeyInVCalendarString('ABSENCETYPE',$vCalendarString);
|
||||
if($isPrivate || $absenceType){
|
||||
//Nothing to do manage fo a private calendar
|
||||
return;
|
||||
}
|
||||
@ -352,15 +336,11 @@ class GestionService
|
||||
$thanatoId = $this->GetThanatoIdFromVCalendarString($vCalendarString);
|
||||
$calendarUuid = $this->GetCalendarUuidFromVCalendarString($vCalendarString);
|
||||
$userName = $this->GetThanatoNameFromVCalendarString($vCalendarString);
|
||||
|
||||
$lieuDeces = $this->getLieuDecesFromVCalendarString($vCalendarString);
|
||||
$dateNaissance = $this->getDateNaissanceFromVCalendarString($vCalendarString);
|
||||
|
||||
$devisAlreadyCreated = $this->IsDevisAlreadyCreated($clientId, $locationId, $thanatoId, $calendarSummary, $calendarUuid);
|
||||
if ($devisAlreadyCreated) {
|
||||
return;
|
||||
}
|
||||
$defuntId = $this->gestionBdd->insertDefuntByNameAndReturnId($calendarSummary, $lieuDeces, $dateNaissance);
|
||||
$defuntId = $this->gestionBdd->insertDefuntByNameAndReturnId($calendarSummary);
|
||||
$calendarStartDate = $this->GetCalendarDateFromVCalendarString($vCalendarString);
|
||||
$devisComment = $this->GetDevisCommentFromVCalendarString($vCalendarString);
|
||||
$devisId = $this->gestionBdd->insertDevisFromVCalendarAndReturnId($thanatoId, $clientId, $locationId, $defuntId, $calendarUuid, $calendarStartDate, $devisComment);
|
||||
@ -372,13 +352,14 @@ class GestionService
|
||||
$devisTalkMessage = $this->gestionBdd->getDevisTalkRoomMessage($devisId, $userName);
|
||||
$this->talkService->sendDevisTalkNotifications($devisTalkMessage, $userName, $this->userConnectedUuid);
|
||||
$this->gestionBdd->createDevisTrajetFromVCalendar($devisId, $userName);
|
||||
$this->devisPdfService->generateDevisPdfByDevisId($devisId, $this->userConnectedUuid);
|
||||
$this->devisPdfService->generateDevisPdfByDevisId($devisId , $this->userConnectedUuid);
|
||||
} catch (\OC\OCS\Exception $e) {
|
||||
$this->logger->debug("Error while handling created calendar object: " . $e->getMessage());
|
||||
} catch (\Throwable $e) {
|
||||
$this->logger->debug("Error while handling created calendar object: " . $e->getMessage());
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
private function GetThanatoNameFromVCalendarString($vCalendarString)
|
||||
{
|
||||
@ -412,16 +393,4 @@ class GestionService
|
||||
$mapped = array_map('trim', $articles);
|
||||
return $mapped;
|
||||
}
|
||||
|
||||
private function getLieuDecesFromVCalendarString(string $vCalendarString): ?string
|
||||
{
|
||||
$lieuDecesValue = VCalendarHelpers::GetValueFromKeyInVCalendarString("LIEUDECES", $vCalendarString);
|
||||
return !empty($lieuDecesValue) ? trim($lieuDecesValue) : null;
|
||||
}
|
||||
|
||||
private function getDateNaissanceFromVCalendarString(string $vCalendarString): ?string
|
||||
{
|
||||
$dateNaissanceValue = VCalendarHelpers::GetValueFromKeyInVCalendarString("DATENAISSANCE", $vCalendarString);
|
||||
return !empty($dateNaissanceValue) ? trim($dateNaissanceValue) : null;
|
||||
}
|
||||
}
|
||||
|
||||
@ -43,7 +43,7 @@ class MailerService {
|
||||
$cordialement = "<p> Cordialement,</p>";
|
||||
$userName = "<p> {$userName} </p>" ;
|
||||
$signatureImage = $this->getSignatureHtmlEmailContent();
|
||||
return $wish.$cordialement.$signatureImage ;
|
||||
return $wish . $cordialement .$userName . $signatureImage ;
|
||||
}
|
||||
|
||||
private function getSignatureHtmlEmailContent (){
|
||||
|
||||
@ -4,7 +4,7 @@ import "datatables.net-dt/css/jquery.dataTables.css";
|
||||
import "../css/mycss.css";
|
||||
|
||||
import "./listener/main_listener";
|
||||
import { getBibliotheques, exportCareCertificate,getBijouxById, getHypodermiquesyId, getObservationsById, getproduits, saveAttestationPacemaker, saveAttestationAbsentPacemaker, saveRapportBijoux, saveRapportSoin, setBijouxPhoto, setDefuntCover, setDefuntPacemakerPhoto, updateDB } from "./modules/ajaxRequest.mjs";
|
||||
import { getBibliotheques, exportCareCertificate,getBijouxById, getHypodermiquesyId, getObservationsById, getproduits, saveAttestationPacemaker, saveRapportBijoux, saveRapportSoin, setBijouxPhoto, setDefuntCover, setDefuntPacemakerPhoto, updateDB } from "./modules/ajaxRequest.mjs";
|
||||
import { globalConfiguration } from "./modules/mainFunction.mjs";
|
||||
|
||||
let bibliotheques = [];
|
||||
@ -77,7 +77,6 @@ window.addEventListener("DOMContentLoaded", function () {
|
||||
});
|
||||
|
||||
var pacemakerBtn = document.getElementById("pacemakerBtn");
|
||||
var pacemakerAbsentBtn = document.getElementById("pacemakerAbsentBtn");
|
||||
var rapportSoinBtn = document.getElementById("rapportSoinBtn");
|
||||
var exportCareCertificateButton = document.getElementById("exportCareCertificate");
|
||||
var setDefuntCoverButton = this.document.getElementById("coverProductsSetButton");
|
||||
@ -145,9 +144,6 @@ window.addEventListener("DOMContentLoaded", function () {
|
||||
case 'pacemaker':
|
||||
saveAttestationPacemaker({ defuntId: defuntid ,email: isSendEmail ? email: ''});
|
||||
break;
|
||||
case 'pacemakerAbsent':
|
||||
saveAttestationAbsentPacemaker({ defuntId: defuntid ,email: isSendEmail ? email: ''});
|
||||
break;
|
||||
case 'rapport-soin':
|
||||
saveRapportSoin({ numdefunt: defuntid ,email: isSendEmail ? email: ''});
|
||||
break;
|
||||
@ -186,12 +182,6 @@ window.addEventListener("DOMContentLoaded", function () {
|
||||
modalElement.modal('show')
|
||||
// saveAttestationPacemaker({ defuntId: defuntid });
|
||||
});
|
||||
pacemakerAbsentBtn.addEventListener("click", function(){
|
||||
modalTitle.text("Générer l'attestation d'absence pacemaker")
|
||||
modalElement.data('export-type', 'pacemakerAbsent')
|
||||
modalElement.modal('show')
|
||||
// saveAttestationPacemaker({ defuntId: defuntid });
|
||||
});
|
||||
|
||||
rapportSoinBtn.addEventListener("click", function(){
|
||||
modalElement.data('export-type', 'rapport-soin')
|
||||
|
||||
@ -678,31 +678,6 @@ export function saveAttestationPacemaker(myData) {
|
||||
});
|
||||
};
|
||||
|
||||
|
||||
/**
|
||||
* Save pdf in nextcloud
|
||||
* @param {*} myData
|
||||
*/
|
||||
export function saveAttestationAbsentPacemaker(myData) {
|
||||
showLoader();
|
||||
$.ajax({
|
||||
url: baseUrl + '/saveAttestationAbsentPacemaker',
|
||||
type: 'POST',
|
||||
contentType: 'application/json',
|
||||
data: JSON.stringify(myData)
|
||||
}).done(function (response) {
|
||||
if(!response) {
|
||||
showMessage('Ce defunt n\'appartient à aucun devis.');
|
||||
} else {
|
||||
showSuccess('Sauvegardé dans '+ response);
|
||||
}
|
||||
}).fail(function (response, code) {
|
||||
showMessage(t('gestion', 'Erreur dans la génération d\'attestation pacemaker'));
|
||||
}).always(function () {
|
||||
hideLoader();
|
||||
});
|
||||
};
|
||||
|
||||
/**
|
||||
* Save pdf in nextcloud
|
||||
* @param {*} myData
|
||||
|
||||
@ -21,7 +21,6 @@ export class Defunt {
|
||||
this.pompe = ((myresp.nom_client == null) ? '-' : myresp.nom_client);
|
||||
this.lieu = ((myresp.lieu == null) ? '-' : myresp.lieu);
|
||||
this.numero_devis = ((myresp.user_id == null) ? '-' : myresp.user_id);
|
||||
this.lieu_deces = ((myresp.lieu_deces == null) ? '-' : myresp.lieu_deces);
|
||||
this.baseUrl = generateUrl(`/apps/gestion/defunt/${this.id}/show`);
|
||||
this.productCoverDescription = Defunt.getDefuntProductCoverDescriptionFromApiResponse(myresp);
|
||||
}
|
||||
|
||||
@ -1,15 +1,11 @@
|
||||
<?php
|
||||
$quantiteOptions = [0];
|
||||
for ($i = 1; $i <= 10; $i++) {
|
||||
$quantiteOptions[] = $i / 10;
|
||||
$quantiteOptions[] = $i / 10;
|
||||
}
|
||||
for ($i = 1; $i <= 15; $i++) {
|
||||
if ($i > 1) {
|
||||
$quantiteOptions[] = $i;
|
||||
}
|
||||
if ($i < 15) {
|
||||
$quantiteOptions[] = $i + 0.5;
|
||||
}
|
||||
if ($i > 1) $quantiteOptions[] = $i;
|
||||
if ($i < 15) $quantiteOptions[] = $i + 0.5;
|
||||
}
|
||||
$coverProducts = $_['coverProducts'];
|
||||
?>
|
||||
@ -17,7 +13,7 @@ $coverProducts = $_['coverProducts'];
|
||||
<div id="defuntid" data-table="defunt" data-id="<?php echo $_['defunt'][0]->id; ?>"></div>
|
||||
<div class="breadcrumb" data-html2canvas-ignore>
|
||||
<div class="crumb svg crumbhome">
|
||||
<a href="<?php echo($_['url']['index']); ?>" class="icon-home"></a>
|
||||
<a href="<?php echo ($_['url']['index']); ?>" class="icon-home"></a>
|
||||
<span style="display: none;"></span>
|
||||
</div>
|
||||
<div class="crumb svg crumbhome">
|
||||
@ -30,7 +26,6 @@ $coverProducts = $_['coverProducts'];
|
||||
<div class="div">
|
||||
<button id="exportCareCertificate" class="btn btn-secondary" type="button">Générer l'attestation de soins</button>
|
||||
<button id="pacemakerBtn" class="btn btn-secondary" type="button">Générer l'attestation retrait de pile</button>
|
||||
<button id="pacemakerAbsentBtn" class="btn btn-secondary" type="button">Générer l'attestation d'Absence de Pacemacker</button>
|
||||
<button id="rapportSoinBtn" class="btn btn-secondary" type="button">Générer le rapport de soins</button>
|
||||
<button id="showRapportBijouxExportModal" class="btn btn-secondary" type="button" data-toggle="modal" data-target="#saveRapportBijouxModal">Générer le rapport des bijoux</button>
|
||||
</div>
|
||||
@ -76,24 +71,13 @@ $coverProducts = $_['coverProducts'];
|
||||
<input class="gestion-input w-100" type="date" value="<?php echo $_['defunt'][0]->date_naissance ?>" data-table="defunt" data-column="date_naissance" data-id="<?php echo $_['defunt'][0]->id ?>" />
|
||||
</div>
|
||||
</div>
|
||||
<!-- Lieu décès -->
|
||||
<div class="d-flex flex-row align-items-center col-12" style="margin-bottom: 8px">
|
||||
<div class="col-3">Lieu de décès</div>
|
||||
<div class="col-9">
|
||||
<input class="gestion-input w-100" type="text" value="<?php echo $_['defunt'][0]->lieu_deces ?>" data-table="defunt" data-column="lieu_deces" data-id="<?php echo $_['defunt'][0]->id ?>" />
|
||||
</div>
|
||||
</div>
|
||||
<!-- Sexe -->
|
||||
<!-- <div class="d-flex flex-row align-items-center col-12" style="margin-bottom: 8px">
|
||||
<div class="col-3">Sexe</div>
|
||||
<div class="col-9">
|
||||
<select class="gestion-select w-100" data-table="defunt" data-column="sexe" data-id="<?php echo $_['defunt'][0]->id ?>">
|
||||
<option value="m" <?php if (strcmp($_['defunt'][0]->sexe, 'm') == 0) {
|
||||
echo 'selected';
|
||||
} ?>>Masculin</option>
|
||||
<option value="f" <?php if (strcmp($_['defunt'][0]->sexe, 'f') == 0) {
|
||||
echo 'selected';
|
||||
} ?>>Féminin</option>
|
||||
<option value="m" <?php if (strcmp($_['defunt'][0]->sexe, 'm') == 0) echo 'selected' ?>>Masculin</option>
|
||||
<option value="f" <?php if (strcmp($_['defunt'][0]->sexe, 'f') == 0) echo 'selected' ?>>Féminin</option>
|
||||
</select>
|
||||
</div>
|
||||
</div> -->
|
||||
@ -125,11 +109,11 @@ $coverProducts = $_['coverProducts'];
|
||||
<input class="w-100 uploadDefuntPacemakerPhoto" accept="image/*" type="file" data-id="<?php echo $_['defunt'][0]->id ?>" />
|
||||
<?php
|
||||
if ($_['defunt'][0]->product_photo != null) {
|
||||
?>
|
||||
?>
|
||||
<label id="pacemakerPhotoLabel" for=""><?php echo ($_['defunt'][0]->product_photo_name ?? "") ?></label>
|
||||
<?php
|
||||
}
|
||||
?>
|
||||
?>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
@ -218,12 +202,8 @@ $coverProducts = $_['coverProducts'];
|
||||
<div class="col-9">
|
||||
<select class="gestion-select w-100" data-table="defunt" data-column="acces_etat" data-id="<?php echo $_['defunt'][0]->id ?>">
|
||||
<option>Selectionner un état</option>
|
||||
<option value="mauvais" <?php if (strcmp($_['defunt'][0]->acces_etat, 'mauvais') == 0) {
|
||||
echo 'selected';
|
||||
} ?>>Mauvais</option>
|
||||
<option value="bon" <?php if (strcmp($_['defunt'][0]->acces_etat, 'bon') == 0) {
|
||||
echo 'selected';
|
||||
} ?>>Bon</option>
|
||||
<option value="mauvais" <?php if (strcmp($_['defunt'][0]->acces_etat, 'mauvais') == 0) echo 'selected' ?>>Mauvais</option>
|
||||
<option value="bon" <?php if (strcmp($_['defunt'][0]->acces_etat, 'bon') == 0) echo 'selected' ?>>Bon</option>
|
||||
</select>
|
||||
</div>
|
||||
</div>
|
||||
@ -245,9 +225,7 @@ $coverProducts = $_['coverProducts'];
|
||||
<div class="col-9">
|
||||
<select class="gestion-select w-100" data-table="defunt" data-column="preinjection_qte" data-id="<?php echo $_['defunt'][0]->id ?>">
|
||||
<?php for ($i = 0; $i < sizeof($quantiteOptions); $i++) { ?>
|
||||
<option value="<?php echo $quantiteOptions[$i] ?>" <?php if ($_['defunt'][0]->preinjection_qte == $quantiteOptions[$i]) {
|
||||
echo 'selected';
|
||||
} ?>><?php echo $quantiteOptions[$i] ?></option>
|
||||
<option value="<?php echo $quantiteOptions[$i] ?>" <?php if ($_['defunt'][0]->preinjection_qte == $quantiteOptions[$i]) echo 'selected' ?>><?php echo $quantiteOptions[$i] ?></option>
|
||||
<?php } ?>
|
||||
</select>
|
||||
</div>
|
||||
@ -270,12 +248,8 @@ $coverProducts = $_['coverProducts'];
|
||||
<div class="col-9">
|
||||
<select class="gestion-select w-100" data-table="defunt" data-column="injection_diffusion" data-id="<?php echo $_['defunt'][0]->id ?>">
|
||||
<option>Selectionner un état</option>
|
||||
<option value="mauvaise" <?php if (strcmp($_['defunt'][0]->injection_diffusion, 'mauvaise') == 0) {
|
||||
echo 'selected';
|
||||
} ?>>Mauvaise</option>
|
||||
<option value="bonne" <?php if (strcmp($_['defunt'][0]->injection_diffusion, 'bonne') == 0) {
|
||||
echo 'selected';
|
||||
} ?>>Bonne</option>
|
||||
<option value="mauvaise" <?php if (strcmp($_['defunt'][0]->injection_diffusion, 'mauvaise') == 0) echo 'selected' ?>>Mauvaise</option>
|
||||
<option value="bonne" <?php if (strcmp($_['defunt'][0]->injection_diffusion, 'bonne') == 0) echo 'selected' ?>>Bonne</option>
|
||||
</select>
|
||||
</div>
|
||||
</div>
|
||||
@ -285,9 +259,7 @@ $coverProducts = $_['coverProducts'];
|
||||
<div class="col-9">
|
||||
<select class="gestion-select w-100" data-table="defunt" data-column="injection_qte" data-id="<?php echo $_['defunt'][0]->id ?>">
|
||||
<?php for ($i = 0; $i < sizeof($quantiteOptions); $i++) { ?>
|
||||
<option value="<?php echo $quantiteOptions[$i] ?>" <?php if ($_['defunt'][0]->injection_qte == $quantiteOptions[$i]) {
|
||||
echo 'selected';
|
||||
} ?>><?php echo $quantiteOptions[$i] ?></option>
|
||||
<option value="<?php echo $quantiteOptions[$i] ?>" <?php if ($_['defunt'][0]->injection_qte == $quantiteOptions[$i]) echo 'selected' ?>><?php echo $quantiteOptions[$i] ?></option>
|
||||
<?php } ?>
|
||||
</select>
|
||||
</div>
|
||||
@ -310,9 +282,7 @@ $coverProducts = $_['coverProducts'];
|
||||
<div class="col-9">
|
||||
<select class="gestion-select w-100" data-table="defunt" data-column="coinjection_qte" data-id="<?php echo $_['defunt'][0]->id ?>">
|
||||
<?php for ($i = 0; $i < sizeof($quantiteOptions); $i++) { ?>
|
||||
<option value="<?php echo $quantiteOptions[$i] ?>" <?php if ($_['defunt'][0]->coinjection_qte == $quantiteOptions[$i]) {
|
||||
echo 'selected';
|
||||
} ?>><?php echo $quantiteOptions[$i] ?></option>
|
||||
<option value="<?php echo $quantiteOptions[$i] ?>" <?php if ($_['defunt'][0]->coinjection_qte == $quantiteOptions[$i]) echo 'selected' ?>><?php echo $quantiteOptions[$i] ?></option>
|
||||
<?php } ?>
|
||||
</select>
|
||||
</div>
|
||||
@ -335,12 +305,8 @@ $coverProducts = $_['coverProducts'];
|
||||
<div class="col-9">
|
||||
<select class="gestion-select w-100" data-table="defunt" data-column="drainage_etat" data-id="<?php echo $_['defunt'][0]->id ?>">
|
||||
<option>Selectionner un état</option>
|
||||
<option value="mauvaise" <?php if (strcmp($_['defunt'][0]->drainage_etat, 'mauvaise') == 0) {
|
||||
echo 'selected';
|
||||
} ?>>Mauvaise</option>
|
||||
<option value="bonne" <?php if (strcmp($_['defunt'][0]->drainage_etat, 'bonne') == 0) {
|
||||
echo 'selected';
|
||||
} ?>>Bonne</option>
|
||||
<option value="mauvaise" <?php if (strcmp($_['defunt'][0]->drainage_etat, 'mauvaise') == 0) echo 'selected' ?>>Mauvaise</option>
|
||||
<option value="bonne" <?php if (strcmp($_['defunt'][0]->drainage_etat, 'bonne') == 0) echo 'selected' ?>>Bonne</option>
|
||||
</select>
|
||||
</div>
|
||||
</div>
|
||||
@ -350,9 +316,7 @@ $coverProducts = $_['coverProducts'];
|
||||
<div class="col-9">
|
||||
<select class="gestion-select w-100" data-table="defunt" data-column="drainage_qte" data-id="<?php echo $_['defunt'][0]->id ?>">
|
||||
<?php for ($i = 0; $i < sizeof($quantiteOptions); $i++) { ?>
|
||||
<option value="<?php echo $quantiteOptions[$i] ?>" <?php if ($_['defunt'][0]->drainage_qte == $quantiteOptions[$i]) {
|
||||
echo 'selected';
|
||||
} ?>><?php echo $quantiteOptions[$i] ?></option>
|
||||
<option value="<?php echo $quantiteOptions[$i] ?>" <?php if ($_['defunt'][0]->drainage_qte == $quantiteOptions[$i]) echo 'selected' ?>><?php echo $quantiteOptions[$i] ?></option>
|
||||
<?php } ?>
|
||||
</select>
|
||||
</div>
|
||||
@ -375,9 +339,7 @@ $coverProducts = $_['coverProducts'];
|
||||
<div class="col-9">
|
||||
<select class="gestion-select w-100" data-table="defunt" data-column="ponction_qte" data-id="<?php echo $_['defunt'][0]->id ?>">
|
||||
<?php for ($i = 0; $i < sizeof($quantiteOptions); $i++) { ?>
|
||||
<option value="<?php echo $quantiteOptions[$i] ?>" <?php if ($_['defunt'][0]->ponction_qte == $quantiteOptions[$i]) {
|
||||
echo 'selected';
|
||||
} ?>><?php echo $quantiteOptions[$i] ?></option>
|
||||
<option value="<?php echo $quantiteOptions[$i] ?>" <?php if ($_['defunt'][0]->ponction_qte == $quantiteOptions[$i]) echo 'selected' ?>><?php echo $quantiteOptions[$i] ?></option>
|
||||
<?php } ?>
|
||||
</select>
|
||||
</div>
|
||||
@ -400,9 +362,7 @@ $coverProducts = $_['coverProducts'];
|
||||
<div class="col-9">
|
||||
<select class="gestion-select w-100" data-table="defunt" data-column="cavite_qte" data-id="<?php echo $_['defunt'][0]->id ?>">
|
||||
<?php for ($i = 0; $i < sizeof($quantiteOptions); $i++) { ?>
|
||||
<option value="<?php echo $quantiteOptions[$i] ?>" <?php if ($_['defunt'][0]->cavite_qte == $quantiteOptions[$i]) {
|
||||
echo 'selected';
|
||||
} ?>><?php echo $quantiteOptions[$i] ?></option>
|
||||
<option value="<?php echo $quantiteOptions[$i] ?>" <?php if ($_['defunt'][0]->cavite_qte == $quantiteOptions[$i]) echo 'selected' ?>><?php echo $quantiteOptions[$i] ?></option>
|
||||
<?php } ?>
|
||||
</select>
|
||||
</div>
|
||||
@ -457,9 +417,7 @@ $coverProducts = $_['coverProducts'];
|
||||
<div class="d-flex flex-row col-12 align-items-center" style="margin-bottom: 8px">
|
||||
<div class="col-3">Rasage</div>
|
||||
<div class="d-flex col-9 justify-content-start align-items-start">
|
||||
<input class="gestion-checkbox" type="checkbox" <?php if ($_['defunt'][0]->rasage == 1) {
|
||||
echo 'checked';
|
||||
} ?> data-table="defunt" data-column="rasage" data-id="<?php echo $_['defunt'][0]->id ?>" />
|
||||
<input class="gestion-checkbox" type="checkbox" <?php if ($_['defunt'][0]->rasage == 1) echo 'checked' ?> data-table="defunt" data-column="rasage" data-id="<?php echo $_['defunt'][0]->id ?>" />
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user