Reviews.vue 12 KB

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