Fonctionnalites.vue 8.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381
  1. <template>
  2. <div id="Fonctionnalites">
  3. <LayoutContainer>
  4. <div class="container-green">
  5. <div class="title-container mt-6">
  6. <v-icon size="6" class="fa-solid fa-circle icon-title mt-6 ml-6" />
  7. <h4 class="subtitle mt-6">
  8. Découvrez TOUTES LES FONCTIONNALITÉS DE NOTRE solution
  9. </h4>
  10. </div>
  11. <div class="title-container">
  12. <h4 class="title ml-6 mt-6">
  13. Des fonctionnalités adaptées à vos besoins
  14. </h4>
  15. </div>
  16. <v-row>
  17. <v-col cols="12">
  18. <div class="d-flex justify-center align-center">
  19. <div class="carousel-button" @click="previousAction">
  20. <i class="fas fa-chevron-left" @click="previousAction"/>
  21. </div>
  22. <div class="carousel-button" @click="nextAction">
  23. <i class="fas fa-chevron-right" @click="nextAction"/>
  24. </div>
  25. </div>
  26. </v-col>
  27. </v-row>
  28. <v-row>
  29. <v-col cols="12">
  30. <Carousel
  31. ref="functionCarousel"
  32. :items-to-show="5"
  33. :items-to-scroll="1"
  34. class="carousel"
  35. >
  36. <Slide
  37. v-for="(card, index) in cards"
  38. :key="index"
  39. :class="{
  40. card: true,
  41. 'active-card': index === activeCardIndex,
  42. }"
  43. >
  44. <div class="card-container">
  45. <v-card>
  46. <v-card-title>
  47. <h1 class="card-title">{{ card.title }}</h1>
  48. </v-card-title>
  49. <v-card-item>
  50. <v-card-text class="review-description">
  51. <ul>
  52. <li class="list-detail" v-for="item in card.list">
  53. {{ item }}
  54. </li>
  55. </ul>
  56. </v-card-text>
  57. <div class="card-footer">
  58. <!-- <v-card-actions class="reviewer-name">
  59. {{ card.name }}
  60. </v-card-actions>
  61. <p class="reviewer-status">
  62. {{ card.status }}
  63. </p> -->
  64. <p class="reviewer-structure">
  65. {{ card.option }}
  66. </p>
  67. </div>
  68. </v-card-item>
  69. </v-card>
  70. </div>
  71. </Slide>
  72. </Carousel>
  73. </v-col>
  74. </v-row>
  75. </div>
  76. </LayoutContainer>
  77. </div>
  78. </template>
  79. <script setup>
  80. import { ref } from "vue";
  81. import { Carousel, Slide } from "vue3-carousel";
  82. import "vue3-carousel/dist/carousel.css";
  83. const functionCarousel = ref(null);
  84. const activeCardIndex = ref(2);
  85. const previousAction = () => {
  86. const newIndex = activeCardIndex.value - 1;
  87. if (newIndex >= 0) {
  88. activeCardIndex.value = newIndex;
  89. functionCarousel.value.prev();
  90. }
  91. };
  92. const nextAction = () => {
  93. const newIndex = activeCardIndex.value + 1;
  94. if (newIndex < cards.length) {
  95. activeCardIndex.value = newIndex;
  96. functionCarousel.value.next();
  97. }
  98. };
  99. const cards = [
  100. {
  101. title: "ESPACES DÉDIÉS",
  102. list: ["Administration", "Professeurs", "Élèves/Familles"],
  103. },
  104. {
  105. title: "RÉPERTOIRE",
  106. list: [
  107. "Élèves et responsable légaux",
  108. "Personnel administratif et professeurs",
  109. "Contacts extérieurs, partenaires & donateurs",
  110. ],
  111. },
  112. {
  113. title: "PRÉINSCRIPTION EN LIGNE",
  114. list: [
  115. "Parametrage personnalisé des formulaires & mails automatiques",
  116. "Gestion des réinscriptions et des nouvelles inscriptionse",
  117. "Gestion des quotas et du suivi des préinscription en ligne",
  118. ],
  119. },
  120. {
  121. title: "AGENDA",
  122. list: [
  123. "Création et gestion des cours, examens, événements et prestations pédagogiques",
  124. "Planning interactif avec un contrôle de cohérence",
  125. "Gestion des présences et absences",
  126. ],
  127. },
  128. {
  129. title: "PARC MATÉRIEL ",
  130. list: [
  131. "Gestion de votre parc matériel (instruments, costumes, accessoires..)",
  132. "Planning interactif avec un contrôle de cohérence",
  133. "Gestion des présences et absences",
  134. ],
  135. },
  136. {
  137. title: "SUIVI PÉDAGOGIQUE",
  138. list: [
  139. "Gestion du cursus pédagogique (critères personnalisables)",
  140. "Création des examens et envoi des convocations",
  141. "Édition des bulletins de notes",
  142. ],
  143. },
  144. {
  145. title: "FACTURATION",
  146. list: [
  147. "Facturation automatisée selon différents critères",
  148. "Suivi des règlements et gestion des relances",
  149. "n options : de nombreux moyens de paiement",
  150. ],
  151. },
  152. {
  153. title: "COMMUNICATION",
  154. list: [
  155. "Édition et envoi de courriers, de mails ou de SMS*",
  156. "Création de modèles de courriers, mails ou SMS",
  157. "Outil de publipostage intégré pour un envoi personnalisé",
  158. ],
  159. option: "* en option",
  160. },
  161. {
  162. title: "SITE INTERNET ",
  163. list: [
  164. "Gestion intégrée au logiciel",
  165. "Mise à jour automatique des membres et événements sur votre site",
  166. "Possibilité de personnalisé votre template",
  167. ],
  168. },
  169. {
  170. title: "STATISTIQUE",
  171. list: [
  172. "Rapport d'activité complet en fonction de vos activités",
  173. "Personnalisation du rapport d'activité grâce aux différents formats proposés lors du téléchargement",
  174. "Export des données du logiciel pour une analyse complète",
  175. ],
  176. },
  177. {
  178. title: "RÉSEAU CMF ",
  179. list: [
  180. "Accès au répertoire du réseau",
  181. "Renouvellement de votre adhésion fédérale",
  182. "Gestion de l'assurance CMF",
  183. ],
  184. },
  185. {
  186. title: "PROMOTION DE VOTRE STRUCTURE & VOS ÉVÉNEMENTS ",
  187. list: [
  188. "Sur votre site internet intégré",
  189. "Sur l'agenda de la CMF",
  190. "Sur l'Agenda culturel Opentalent ",
  191. ],
  192. },
  193. ];
  194. </script>
  195. <style scoped>
  196. .title {
  197. font-family: "Barlow";
  198. font-weight: 600;
  199. font-size: 3rem;
  200. line-height: 2.4rem;
  201. color: white;
  202. width: 35rem;
  203. }
  204. .list-detail {
  205. font-family: "Barlow";
  206. font-style: normal;
  207. font-weight: 300;
  208. font-size: 1.2rem;
  209. line-height: 1.2rem;
  210. margin-bottom: 1rem;
  211. color: #000000;
  212. width: 100%;
  213. }
  214. .card-title {
  215. white-space: pre-wrap;
  216. }
  217. .carousel {
  218. margin-left: 2rem;
  219. margin-right: 2rem;
  220. }
  221. .card.active-card {
  222. }
  223. .title-container{
  224. display: flex;
  225. align-items: center;
  226. }
  227. .subtitle-avantage {
  228. font-family: "Barlow";
  229. font-weight: 600;
  230. font-size: 3rem;
  231. line-height: 18px;
  232. color: white;
  233. }
  234. .subtitle {
  235. color: white;
  236. font-family: "Barlow";
  237. font-size: 1rem;
  238. font-style: normal;
  239. font-weight: 600;
  240. line-height: 15px;
  241. letter-spacing: 1.8px;
  242. text-transform: uppercase;
  243. }
  244. .icon-title {
  245. color: rgba(32, 147, 190, 0.6);
  246. margin-right: 0.5rem;
  247. }
  248. .card {
  249. font-family: "Barlow";
  250. font-style: normal;
  251. font-weight: 300;
  252. transition: transform 0.3s;
  253. min-width: 20%;
  254. max-width: 20%;
  255. }
  256. .card.active-card {
  257. transform: scale(1.05);
  258. }
  259. .carousel-button {
  260. display: flex;
  261. justify-content: center;
  262. align-items: center;
  263. width: 4rem;
  264. height: 4rem;
  265. background-color: transparent;
  266. border: 2px solid #fff;
  267. cursor: pointer;
  268. margin-right: 1rem;
  269. margin-top: 1rem;
  270. }
  271. .carousel-button i {
  272. color: #fff;
  273. cursor: pointer;
  274. }
  275. .reviewer-name {
  276. font-family: "Barlow";
  277. font-style: normal;
  278. font-weight: 500;
  279. font-size: 20px;
  280. line-height: 24px;
  281. color: rgba(32, 147, 190);
  282. }
  283. .reviewer-status {
  284. font-family: "Barlow";
  285. font-family: "Barlow";
  286. font-style: normal;
  287. font-weight: 600;
  288. font-size: 12px;
  289. line-height: 16px;
  290. display: flex;
  291. align-items: center;
  292. letter-spacing: 0.18em;
  293. text-transform: uppercase;
  294. }
  295. .reviewer-structure {
  296. font-family: "Barlow";
  297. font-style: normal;
  298. font-weight: 300;
  299. font-size: 0.8rem;
  300. line-height: 14px;
  301. display: flex;
  302. align-items: center;
  303. margin-bottom: 1rem;
  304. color: #071b1f;
  305. }
  306. .review-description {
  307. text-align: left;
  308. }
  309. .card-footer {
  310. /** coller à droite */
  311. position: absolute;
  312. right: 0;
  313. margin-right: 2rem;
  314. }
  315. .card-text {
  316. font-family: "Barlow";
  317. font-style: normal;
  318. font-weight: 300;
  319. font-size: 1rem;
  320. line-height: 1rem;
  321. height: 12rem;
  322. }
  323. .reviews-title {
  324. color: #fff;
  325. font-family: "Barlow";
  326. font-size: 1rem;
  327. font-style: normal;
  328. font-weight: 600;
  329. line-height: 15px;
  330. letter-spacing: 1.8px;
  331. text-transform: uppercase;
  332. margin-left: 1rem;
  333. width: 10rem;
  334. }
  335. .card {
  336. width: 80rem;
  337. min-height: 35rem;
  338. max-height: 35rem;
  339. border-radius: 1rem;
  340. }
  341. .v-card {
  342. border-radius: 1rem;
  343. min-height: 25rem;
  344. max-height: 25rem;
  345. }
  346. .card-container {
  347. display: flex;
  348. justify-content: center;
  349. align-items: center;
  350. margin-bottom: 3rem;
  351. margin-right: 2rem;
  352. }
  353. .container-green {
  354. background-color: #0e2d32;
  355. }
  356. </style>