Event.vue 9.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322
  1. <template>
  2. <LayoutCommonSection>
  3. <v-row>
  4. <v-col cols="12" sm="12">
  5. <h4 class="mb-8">{{ $t('general_informations') }}</h4>
  6. <UiInputText
  7. v-model="entity.name"
  8. field="name"
  9. :rules="getAsserts('name')"
  10. />
  11. <span class="label">{{$t('datetimeStart')}}</span>
  12. <UiInputDateTimePicker
  13. v-model="entity.datetimeStart"
  14. field="datetimeStart"
  15. label="datetimeStart"
  16. :withTimePicker="true"
  17. class="my-2"
  18. :rules="getAsserts('datetimeStart')"
  19. validate-on-blur
  20. @update:model-value="onUpdateDateTimeStart(entity, $event)"
  21. />
  22. <span class="label">{{$t('datetimeEnd')}}</span>
  23. <UiInputDateTimePicker
  24. v-model="entity.datetimeEnd"
  25. field="datetimeEnd"
  26. label="datetimeEnd"
  27. :withTimePicker="true"
  28. class="my-2"
  29. :rules="getAsserts('datetimeEnd')"
  30. @update:model-value="onUpdateDateTimeEnd(entity, $event)"
  31. />
  32. <span class="label">{{$t('description')}}</span>
  33. <UiInputTextArea
  34. class="mt-3"
  35. v-model="entity.description"
  36. />
  37. <UiInputTreeSelectEventCategories
  38. v-model="entity.categories"
  39. label="event_categories_choices"
  40. />
  41. <UiInputImage
  42. v-model="entity.image"
  43. field="image"
  44. :width="240"
  45. :cropping-enabled="true"
  46. />
  47. </v-col>
  48. </v-row>
  49. </LayoutCommonSection>
  50. <LayoutCommonSection>
  51. <v-row>
  52. <v-col cols="12">
  53. <h4 class="mb-8">{{ $t('place_event') }}</h4>
  54. <UiInputAutocompleteApiResources
  55. v-model="entity.place"
  56. field="place"
  57. :model="PlaceSearchItem"
  58. listValue="id"
  59. listLabel="name"
  60. v-if="!newPlace"
  61. @update:model-value="getPlace(entity)"
  62. />
  63. <v-row v-if="!newPlace" class="mb-6 justify-center">
  64. <v-col
  65. v-if="entity.place && !editPlace"
  66. cols="12"
  67. sm="6"
  68. class="d-flex justify-center mb-2"
  69. >
  70. <v-btn
  71. prepend-icon="fa-solid fa-pencil"
  72. @click="onEditPlaceClick(entity)"
  73. >
  74. {{ $t('edit_place') }}
  75. </v-btn>
  76. </v-col>
  77. <v-col
  78. cols="12"
  79. sm="6"
  80. class="d-flex justify-center mb-2"
  81. >
  82. <v-btn
  83. prepend-icon="fa-solid fa-plus"
  84. @click="onAddPlaceClick(entity)"
  85. >
  86. {{ $t('add_place') }}
  87. </v-btn>
  88. </v-col>
  89. </v-row>
  90. <UiInputText :readonly="!newPlace && !editPlace" v-model="entity.placeName" field="placeName" />
  91. <UiInputText :readonly="!newPlace && !editPlace" v-model="entity.streetAddress" field="streetAddress" />
  92. <UiInputText :readonly="!newPlace && !editPlace" v-model="entity.streetAddressSecond" field="streetAddressSecond" />
  93. <UiInputText :readonly="!newPlace && !editPlace" v-model="entity.streetAddressThird" field="streetAddressThird" />
  94. <UiInputText :readonly="!newPlace && !editPlace" v-model="entity.postalCode" field="postalCode" />
  95. <UiInputText :readonly="!newPlace && !editPlace" v-model="entity.addressCity" field="addressCity" />
  96. <UiInputAutocompleteApiResources
  97. :readonly="!newPlace && !editPlace"
  98. v-model="entity.addressCountry"
  99. field="addressCountry"
  100. :model="Country"
  101. listValue="id"
  102. listLabel="name"
  103. />
  104. <client-only>
  105. <UiMapLeaflet
  106. :readonly="!newPlace && !editPlace"
  107. v-model:latitude="entity.latitude"
  108. v-model:longitude="entity.longitude"
  109. :streetAddress="entity.streetAddress"
  110. :streetAddressSecond="entity.streetAddressSecond"
  111. :streetAddressThird="entity.streetAddressThird"
  112. :postalCode="entity.postalCode"
  113. :addressCity="entity.addressCity"
  114. :addressCountryId="entity.addressCountry"
  115. :searchButton="true"
  116. ></UiMapLeaflet>
  117. </client-only>
  118. </v-col>
  119. </v-row>
  120. </LayoutCommonSection>
  121. <LayoutCommonSection>
  122. <v-row>
  123. <v-col cols="12">
  124. <h4 class="mb-8">{{ $t('communication_params') }}</h4>
  125. <UiInputText v-model="entity.url" field="url" />
  126. <UiInputAutocompleteEnum
  127. v-model="entity.pricing"
  128. enum-name="pricing_event"
  129. field="pricing"
  130. />
  131. <UiInputText v-if="entity.pricing==='PAID'" v-model="entity.urlTicket" field="urlTicket" />
  132. <UiInputNumber v-if="entity.pricing==='PAID'" v-model="entity.priceMini" field="priceMini" />
  133. <UiInputNumber v-if="entity.pricing==='PAID'" v-model="entity.priceMaxi" field="priceMaxi" />
  134. </v-col>
  135. </v-row>
  136. </LayoutCommonSection>
  137. <LazyLayoutDialog :show="showAlert" theme="warning">
  138. <template #dialogType>{{ $t('important') }}</template>
  139. <template #dialogTitle>{{ $t('place_change_everywhere') }}</template>
  140. <template #dialogText>
  141. <v-card-text class="text">
  142. <p>
  143. Si vous modifiez les informations de ce lieu et que ce lieu est lié à d'autre événements,
  144. alors les changements seront répercutés dans tous vos événements liés.
  145. </p>
  146. </v-card-text>
  147. </template>
  148. <template #dialogBtn>
  149. <v-btn class="mr-4 submitBtn theme-neutral-strong" @click="closeDialog">
  150. {{ $t('cancel') }}
  151. </v-btn>
  152. <v-btn class="mr-4 submitBtn theme-warning" @click="onEditPlaceConfirm">
  153. {{ $t('i_understand') }}
  154. </v-btn>
  155. </template>
  156. </LazyLayoutDialog>
  157. </template>
  158. <script setup lang="ts">
  159. import Event from "~/models/Freemium/Event";
  160. import Place from "~/models/Freemium/Place";
  161. import {getAssertUtils} from "~/services/asserts/getAssertUtils";
  162. import DateUtils from "~/services/utils/dateUtils";
  163. import Country from "~/models/Core/Country";
  164. import PlaceSearchItem from "~/models/Custom/Search/PlaceSearchItem";
  165. import {useEntityManager} from "~/composables/data/useEntityManager";
  166. const props = defineProps<{
  167. entity: Event
  168. }>()
  169. const {em} = useEntityManager()
  170. const getAsserts = (key) => getAssertUtils(Event.getAsserts(), key)
  171. /**
  172. * Si la date de début est mise à jour, on s'assure que la date de fin est
  173. * après elle, sinon elle devient égale
  174. * @param entity
  175. * @param dateTime
  176. */
  177. const onUpdateDateTimeStart = (entity, dateTime) =>{
  178. if(DateUtils.isBefore(props.entity.datetimeEnd, dateTime, false)){
  179. entity.datetimeEnd = dateTime
  180. }
  181. }
  182. /**
  183. * Si la date de fin est mise à jour, on s'assure que la date de début est
  184. * avant elle, sinon elle devient égale
  185. * @param entity
  186. * @param dateTime
  187. */
  188. const onUpdateDateTimeEnd = (entity, dateTime) =>{
  189. if(DateUtils.isBefore(dateTime, props.entity.datetimeStart, false)){
  190. entity.datetimeStart = dateTime
  191. }
  192. }
  193. const showAlert: Ref<boolean> = ref(false)
  194. const newPlace: Ref<boolean> = ref(false)
  195. const editPlace: Ref<boolean> = ref(false)
  196. /**
  197. * Si on clic sur le bouton "Ajouter un lieu", le choix dans la liste déroulante
  198. * est mise à nulle, et les champs input de l'adresse sont vidées
  199. * @param entity
  200. */
  201. const onAddPlaceClick = function(entity: Event){
  202. newPlace.value = true
  203. entity.place = null
  204. resetPlace(entity)
  205. }
  206. /**
  207. * Quand on clic sur le bouton "Editer le lieu", une alerte s'affiche
  208. */
  209. const onEditPlaceClick = function(){
  210. showAlert.value = true
  211. }
  212. /**
  213. * Quand on ferme la boite de dialogue
  214. */
  215. const closeDialog = function(){
  216. showAlert.value = false
  217. }
  218. /**
  219. * Si on décide d'éditer le lieu
  220. */
  221. const onEditPlaceConfirm = function(){
  222. showAlert.value = false
  223. editPlace.value = true
  224. }
  225. /**
  226. * Lorsque l'on choisit un lieu dans la liste déroulante, on mets a jour les champs
  227. * input de l'adresse
  228. * @param entity
  229. */
  230. const getPlace = async (entity: Event)=>{
  231. if(entity.place){
  232. const placeInstance = await em.fetch(Place, entity.place as number)
  233. entity.placeName = placeInstance.name
  234. entity.streetAddress = placeInstance.streetAddress
  235. entity.streetAddressSecond = placeInstance.streetAddressSecond
  236. entity.streetAddressThird = placeInstance.streetAddressThird
  237. entity.addressCity = placeInstance.addressCity
  238. entity.postalCode = placeInstance.postalCode
  239. entity.addressCountry = placeInstance.addressCountry
  240. entity.latitude = placeInstance.latitude
  241. entity.longitude = placeInstance.longitude
  242. editPlace.value = false
  243. }else{
  244. //Dans le cas où l'on ne récupère aucune place on remet a null le formulaire de l'adresse
  245. resetPlace(entity)
  246. }
  247. }
  248. /**
  249. * fonction permettant de remettre à vide tous les champs input de l'adresse
  250. * @param entity
  251. */
  252. const resetPlace = (entity: Event)=>{
  253. entity.placeName = null
  254. entity.streetAddress = null
  255. entity.streetAddressSecond = null
  256. entity.streetAddressThird = null
  257. entity.addressCity = null
  258. entity.postalCode = null
  259. entity.addressCountry = null
  260. entity.latitude = null
  261. entity.longitude = null
  262. }
  263. // Nettoyer les données lors du démontage du composant
  264. onBeforeUnmount(() => {
  265. // Nettoyer les références du store si nécessaire
  266. if (process.client) {
  267. clearNuxtData('/^' + Place.entity + '_/')
  268. useRepo(Place).flush()
  269. }
  270. })
  271. </script>
  272. <style scoped lang="scss">
  273. .label{
  274. font-size: 16px;
  275. color: rgb(var(--v-theme-on-primary-alt));
  276. }
  277. </style>