Reviews.vue 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406
  1. <template>
  2. <LayoutContainer>
  3. <div class="container-1">
  4. <LayoutUISectionTitle>
  5. Avis Clients
  6. </LayoutUISectionTitle>
  7. <h4>
  8. C'est vous qui le dites
  9. </h4>
  10. </div>
  11. <!-- Ecrans larges -->
  12. <div v-if="lgAndUp" class="container-2">
  13. <!-- Partie 1 : Avis clients -->
  14. <v-row justify="center">
  15. <div class="col-review">
  16. <v-col cols="6">
  17. <v-card class="left mx-auto">
  18. <v-card-title>
  19. Patrice CATHELIN
  20. </v-card-title>
  21. <v-card-text>
  22. <p>
  23. C'est un logiciel très bien conçu et efficace avec une équipe
  24. ouverte, dynamique et à l'écoute. L’assistance est très
  25. réactive, j'ai toujours eu une réponse rapide à mes besoins,
  26. ce qui est fort appréciable.
  27. </p>
  28. </v-card-text>
  29. <div class="card-footer">
  30. <small class="status">
  31. Directeur administratif & pédagogique
  32. </small>
  33. <small class="structure">
  34. Conservatoire de Musique & de Danse de Sens (78)
  35. </small>
  36. </div>
  37. </v-card>
  38. </v-col>
  39. <v-col cols="6">
  40. <v-card class="right mx-auto">
  41. <v-card-title>
  42. Karine GIRAUD
  43. </v-card-title>
  44. <v-card-text>
  45. <p>
  46. Étant présente depuis presque le début, je suis fière d'avoir
  47. vu grandir ce logiciel et d'avoir évoluée avec lui. De plus,
  48. je me suis sentie écoutée lors de mes propositions
  49. d'amélioration, car beaucoup ont vu le jour. Enfin,
  50. l'accompagnement et la réactivité n'ont jamais faibli depuis
  51. toutes ces années
  52. </p>
  53. </v-card-text>
  54. <div class="card-footer">
  55. <small class="status">
  56. Secrétaire administrative
  57. </small>
  58. <small class="structure">
  59. Association Musicale Sainte Cécile de Lagord (17)
  60. </small>
  61. </div>
  62. </v-card>
  63. </v-col>
  64. </div>
  65. </v-row>
  66. <v-row justify="center">
  67. <div class="col-review">
  68. <v-col cols="6">
  69. <v-card class="left mx-auto">
  70. <v-card-title>
  71. Laurent BEL
  72. </v-card-title>
  73. <v-card-text>
  74. <p>
  75. Logiciel très complet qui permet de faire beaucoup de choses.
  76. J’apprécie particulièrement la réactivité, la bienveillance et
  77. le fait que l’équipe soit à l'écoute pour faire évoluer
  78. l'outil en fonction de nos besoins. Si besoin, la FAQ est
  79. vraiment utile. Elle permet de trouver rapidement une solution
  80. face à un problème rencontré..
  81. </p>
  82. </v-card-text>
  83. <div class="card-footer">
  84. <small class="status">
  85. Directeur administratif & pédagogique
  86. </small>
  87. <small class="structure">
  88. École de Musique EPIC Musique en 4 Rivières (74)
  89. </small>
  90. </div>
  91. </v-card>
  92. </v-col>
  93. <v-col cols="6">
  94. <v-card class="right mx-auto">
  95. <v-card-title>
  96. Philippe BORY
  97. </v-card-title>
  98. <v-card-text>
  99. <p>
  100. Opentalent est une entreprise avec de vraies valeurs humaines,
  101. à l'écoute de chaque structure et qui ne cesse de s'améliorer
  102. pour toujours coller aux besoins de ses clients. Plus qu'une
  103. relation commerciale, c'est pour nous un véritable partenaire
  104. au quotidien.
  105. </p>
  106. </v-card-text>
  107. <div class="card-footer">
  108. <small class="status">
  109. Personnel administratif
  110. </small>
  111. <small class="structure">
  112. École d'Arts de Saint-Michel-sur-Orge (91)
  113. </small>
  114. </div>
  115. </v-card>
  116. </v-col>
  117. </div>
  118. </v-row>
  119. <!-- Partie 2 : Carrousel logos clients -->
  120. <div class="carousel-clients-container">
  121. <CommonCarouselClients :items="items" />
  122. </div>
  123. </div>
  124. <!-- Petits écrans -->
  125. <div v-else class="container-sm">
  126. <v-row>
  127. <v-col cols="12">
  128. <Carousel
  129. :itemsToShow="1"
  130. :wrap-around="true"
  131. ref="reviewCarousel"
  132. >
  133. <Slide v-for="(card, index) in cards" :key="index">
  134. <v-card>
  135. <v-card-title>
  136. <span class="review-name">{{ card.name }}</span>
  137. </v-card-title>
  138. <v-card-text>
  139. <p class="description-review">
  140. {{ card.review }}
  141. </p>
  142. </v-card-text>
  143. <div class="card-footer">
  144. <small>{{ card.status }}</small>
  145. <small>{{ card.structure }}</small>
  146. </div>
  147. </v-card>
  148. </Slide>
  149. </Carousel>
  150. </v-col>
  151. </v-row>
  152. <v-row class="justify-center align-center mb-8">
  153. <v-col class="d-flex justify-space-around align-center">
  154. <v-btn
  155. icon="fas fa-arrow-left-long"
  156. @click="goToPrevious"
  157. />
  158. <div class="carousel-controls">
  159. <div
  160. v-for="(item, index) in cards"
  161. :key="index"
  162. :class="{ 'active-control': index === state.activeIndex }"
  163. class="ml-6"
  164. />
  165. </div>
  166. <v-btn
  167. icon="fas fa-arrow-right-long"
  168. @click="goToNext"
  169. />
  170. </v-col>
  171. </v-row>
  172. <CommonCarouselClients :items="items" class="alt-theme pt-12"/>
  173. </div>
  174. </LayoutContainer>
  175. </template>
  176. <script setup lang="ts">
  177. import { Carousel, Slide } from "vue3-carousel";
  178. import "vue3-carousel/dist/carousel.css";
  179. import { useDisplay } from "vuetify";
  180. import type { Review } from "~/types/interface";
  181. const { lgAndUp } = useDisplay();
  182. const reviewCarousel: Ref<typeof Carousel | null> = ref(null);
  183. const state = ref({
  184. activeIndex: 0,
  185. });
  186. const goToNext = () => {
  187. reviewCarousel.value!.next();
  188. state.value.activeIndex = (state.value.activeIndex + 1) % cards.length;
  189. }
  190. const goToPrevious = () => {
  191. reviewCarousel.value!.prev();
  192. state.value.activeIndex =
  193. state.value.activeIndex - 1 < 0
  194. ? cards.length - 1
  195. : state.value.activeIndex - 1;
  196. }
  197. const cards: Array<Review> = [
  198. {
  199. name: "Patrice CATHELIN",
  200. review:
  201. "C'est un logiciel très bien conçu et efficace avec une équipe ouverte, dynamique et à l'écoute. L’assistance est très réactive, j'ai toujours eu une réponse rapide à mes besoins, ce qui est fort appréciable.",
  202. status: "Directeur administratif & pédagogique",
  203. structure: "Conservatoire de Musique & de Danse de Sens (78)",
  204. },
  205. {
  206. name: "Karine GIRAUD",
  207. review:
  208. "Étant présente depuis presque le début, je suis fière d'avoir vu grandir ce logiciel et d'avoir évoluée avec lui. De plus, je me suis sentie écoutée lors de mes propositions d'amélioration, car beaucoup ont vu le jour. Enfin, l'accompagnement et la réactivité n'ont jamais faibli depuis toutes ces années",
  209. status: "Secrétaire administrative",
  210. structure: "Association Musicale Sainte Cécile de Lagord (17)",
  211. },
  212. {
  213. name: "Laurent BEL",
  214. review:
  215. "Logiciel très complet qui permet de faire beaucoup de choses. J’apprécie particulièrement la réactivité, la bienveillance et le fait que l’équipe soit à l'écoute pour faire évoluer l'outil en fonction de nos besoins. Si besoin, la FAQ est vraiment utile. Elle permet de trouver rapidement une solution face à un problème rencontré.",
  216. status: "Directeur administratif & pédagogique",
  217. structure: "École de Musique EPIC Musique en 4 Rivières (74)",
  218. },
  219. {
  220. name: "Philippe BORY",
  221. review:
  222. "Opentalent est une entreprise avec de vraies valeurs humaines, à l'écoute de chaque structure et qui ne cesse de s'améliorer pour toujours coller aux besoins de ses clients. Plus qu'une relation commerciale, c'est pour nous un véritable partenaire au quotidien.",
  223. status: "Personnel administratif",
  224. structure: "École d'Arts de Saint-Michel-sur-Orge (91)",
  225. },
  226. ];
  227. const items: Ref<Array<{ src: string, alt: string }>> = ref([
  228. { src: "/images/pages/home/reviews/Logo_Conservatoire_Les_Ateliers_des_Arts_Agglomeration_du_Puy-en-Velay.svg", alt: "Logo du Conservatoire « Les ateliers des arts" },
  229. { src: "/images/pages/home/reviews/Logo_Conservatoire-Senlis.png", alt: "Logo du Conservatoire de Senlis" },
  230. { src: "/images/pages/home/reviews/Logo_Ecole_de_Musique-Sausheim.png", alt: "Logo de l’École de musique Sausheim" },
  231. { src: "/images/pages/home/reviews/Logo_Conservatoire_Marly_le_Roi-Roger_Bourdin.jpeg", alt: "Logo du Conservatoire Marly le Roi Roger Bourdin" },
  232. { src: "/images/pages/home/reviews/Logo_Conservatoire_de_Musiques_et_de_Danses_du_Thouarsais.jpeg", alt: "Logo du Conservatoire de Musique et de Danse du Thouarsais" },
  233. { src: "/images/pages/home/reviews/Logo_Conservatoire_de_Musique_d_Annemasse.jpg", alt: "Logo du Conservatoire d’Annemasse" },
  234. ]);
  235. </script>
  236. <style scoped>
  237. .container-1 {
  238. background-color: var(--neutral-color);
  239. @media (min-width: 1240px) {
  240. height: 22rem;
  241. }
  242. h4 {
  243. font-size: 2rem;
  244. line-height: 42px;
  245. text-align: center;
  246. color: var(--primary-color);
  247. }
  248. @media (max-width: 600px) {
  249. margin-bottom: 24px;
  250. }
  251. }
  252. .container-2 {
  253. background-color: var(--primary-color);
  254. .col-review {
  255. display: flex;
  256. justify-content: center;
  257. align-items: center;
  258. .v-card {
  259. padding-top: 1rem;
  260. width: 21rem;
  261. min-height: 21rem;
  262. max-height: 21rem;
  263. margin-bottom: 0.9rem;
  264. .v-card-title {
  265. margin-left: 1rem;
  266. font-weight: 500;
  267. font-size: 1.4rem;
  268. color: var(--primary-color);
  269. }
  270. .v-card-text p {
  271. text-align: justify !important;
  272. height: 10rem;
  273. font-size: 1rem;
  274. color: var(--primary-color);
  275. margin: 0 1rem 1rem 1rem;
  276. line-height: 20px;
  277. }
  278. .card-footer {
  279. display: flex;
  280. flex-direction: column;
  281. margin-top: 1rem;
  282. small {
  283. position: absolute;
  284. display: flex;
  285. align-items: center;
  286. bottom: 0;
  287. right: 0;
  288. font-weight: 600;
  289. width: 90%;
  290. color: var(--primary-color);
  291. }
  292. .status {
  293. margin-top: 1rem;
  294. font-size: 0.7rem;
  295. line-height: 15px;
  296. letter-spacing: 0.18em;
  297. text-transform: uppercase;
  298. margin-bottom: 2rem;
  299. width: 300px;
  300. right: 18px;
  301. }
  302. .structure {
  303. font-size: 0.8rem;
  304. margin-bottom: 1rem;
  305. width: 300px;
  306. right: 18px;
  307. }
  308. }
  309. }
  310. .left {
  311. bottom: 12rem;
  312. position: relative;
  313. }
  314. .right {
  315. position: relative;
  316. bottom: 7rem;
  317. }
  318. }
  319. .carousel-clients-container {
  320. margin-top: -7rem;
  321. }
  322. }
  323. .container-sm {
  324. .v-card {
  325. width: 70%;
  326. display: flex;
  327. flex-direction: column;
  328. justify-content: center;
  329. align-items: center;
  330. padding: 16px;
  331. }
  332. .carousel-controls {
  333. display: flex;
  334. flex-direction: row;
  335. justify-content: center;
  336. align-items: center;
  337. div {
  338. width: 0.6rem;
  339. height: 0.6rem;
  340. border-radius: 50%;
  341. background-color: var(--neutral-color-alt);
  342. cursor: pointer;
  343. margin-bottom: 0.5rem;
  344. }
  345. .active-control {
  346. background-color: var(--on-neutral-color-alt);
  347. margin-right: 10px;
  348. }
  349. }
  350. }
  351. </style>