Logiciels.vue 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232
  1. <template>
  2. <AnchoredSection id="softwares">
  3. <LayoutContainer>
  4. <v-row class="mb-6 center-90">
  5. <LayoutUISubTitle> Nos logiciels </LayoutUISubTitle>
  6. <LayoutUITitle>
  7. Nos logiciels dédiés à chaque acteur culturel
  8. </LayoutUITitle>
  9. </v-row>
  10. <v-row class="mb-12 center-90">
  11. <v-col md="3">
  12. <p class="text-justify mr-4 ml-2 mb-6">
  13. Découvrez notre gamme de logiciels de gestion & de communication
  14. adapté au secteur culturel. <br />
  15. Des fonctionnalités complètes:
  16. </p>
  17. <ul class="ml-4">
  18. <li v-for="(feature, index) in features" :key="index">
  19. {{ feature }}
  20. </li>
  21. </ul>
  22. <p class="text-justify mr-4 mt-6">
  23. <b>À chaque logiciel sa spécificité !</b>
  24. </p>
  25. </v-col>
  26. <v-col
  27. v-for="(item, index) in items"
  28. :key="index"
  29. cols="12"
  30. md="3"
  31. :class="item.class"
  32. >
  33. <nuxt-link :to="item.link" class="software-link">
  34. <v-img :src="item.imageUrl" cover class="container-image">
  35. <footer>
  36. <v-img :src="item.logoUrl" :alt="item.logoAlt" class="logo" />
  37. <v-btn aria-label="Voir plus" class="plus-button">
  38. <v-icon>fas fa-plus</v-icon>
  39. </v-btn>
  40. </footer>
  41. </v-img>
  42. </nuxt-link>
  43. <div class="subtitle">
  44. {{ item.subtitle }}
  45. </div>
  46. </v-col>
  47. </v-row>
  48. </LayoutContainer>
  49. </AnchoredSection>
  50. </template>
  51. <script setup lang="ts">
  52. import AnchoredSection from '~/components/Layout/AnchoredSection.vue'
  53. const features: Array<string> = [
  54. 'Une gestion de vos contacts',
  55. 'Un agenda collaboratif et interactif',
  56. 'Une gestion du matériel et du stock',
  57. 'Une communication simplifiée',
  58. "Un rapport d'activité complet",
  59. 'Un site internet intégré',
  60. 'Et bien plus encore...',
  61. ]
  62. const items: Array<{
  63. imageUrl: string
  64. alt: string
  65. logoUrl: string
  66. logoAlt: string
  67. class: string
  68. link: string
  69. subtitle: string
  70. }> = [
  71. {
  72. imageUrl:
  73. '/images/pages/qui-sommes-nous/logiciels/Opentalent_Artist_pour_les_structures_culturelles.jpg',
  74. alt: 'Partition tenue par une femme dans une chorale',
  75. logoUrl: '/images/logos/opentalent/Logo_Opentalent_Artist-blanc.png',
  76. logoAlt:
  77. 'Logo Opentalent Artist - logiciel de gestion et de communication pour les orchestres, les chorales, les compagnies artistiques et troupes',
  78. class: 'artist',
  79. link: '/opentalent-artist',
  80. subtitle:
  81. 'Pour les orchestres, les chorales, les compagnies et les troupes artistiques',
  82. },
  83. {
  84. imageUrl:
  85. '/images/pages/qui-sommes-nous/logiciels/Opentalent_School_pour_les_etablissements_d_enseignement_artistique.JPG',
  86. alt: 'Deux jeunes filles jouant du violon',
  87. logoUrl: '/images/logos/opentalent/Logo_Opentalent_School-blanc.png',
  88. logoAlt:
  89. 'Logo Opentalent School - logiciel de gestion et de communication pour les établissements d’enseignement artistique',
  90. class: 'school',
  91. link: '/opentalent-school',
  92. subtitle: 'Pour tous les établissements d’enseignement artistique',
  93. },
  94. {
  95. imageUrl:
  96. '/images/pages/qui-sommes-nous/logiciels/Opentalent_Manager_pour_les_reseaux_culturels.png',
  97. alt: 'Carte de réseau des structures de la confédération musicale de France',
  98. logoUrl: '/images/logos/opentalent/Logo_Opentalent_Manager-blanc.png',
  99. logoAlt:
  100. 'Logo Opentalent Manager - logiciel de gestion et de communication pour les fédérations, les confédérations et les collectivités',
  101. class: 'manager',
  102. link: '/opentalent-manager',
  103. subtitle: 'Pour les fédérations, confédérations et institutions publiques',
  104. },
  105. ]
  106. </script>
  107. <style scoped lang="scss">
  108. .container {
  109. padding: 0 !important;
  110. margin-top: 1rem;
  111. background: var(--neutral-color);
  112. }
  113. ul {
  114. list-style: none;
  115. padding-left: 0;
  116. }
  117. li {
  118. margin-left: 0.8rem;
  119. position: relative;
  120. margin-bottom: 6px;
  121. }
  122. li:before {
  123. content: '';
  124. position: absolute;
  125. left: -10px;
  126. top: 50%;
  127. transform: translateY(-50%);
  128. width: 3px;
  129. height: 3px;
  130. background-color: var(--on-neutral-color);
  131. border-radius: 50%;
  132. }
  133. .software-link {
  134. > .container-image:hover {
  135. transform: scale(1.05);
  136. }
  137. }
  138. .container-image {
  139. position: relative;
  140. background-repeat: no-repeat;
  141. background-size: cover;
  142. background-position: center;
  143. width: 100%;
  144. height: 370px;
  145. z-index: 0;
  146. border-radius: 12px 12px 0 12px;
  147. footer {
  148. position: absolute;
  149. bottom: 0;
  150. left: 0;
  151. width: 100%;
  152. height: 100px;
  153. display: flex;
  154. align-items: center;
  155. justify-content: space-between;
  156. padding: 0 10px;
  157. }
  158. .logo {
  159. width: 100px;
  160. z-index: 2;
  161. margin-right: 10px;
  162. }
  163. .plus-button {
  164. width: 100px;
  165. height: 100px;
  166. border-radius: 50% 0 0 0;
  167. background: var(--primary-color);
  168. color: var(--on-primary-color);
  169. box-shadow: none !important;
  170. border-top-left-radius: 10% !important;
  171. margin-right: -10px;
  172. margin-bottom: -10px;
  173. z-index: 2;
  174. .v-icon {
  175. color: var(--on-primary-color);
  176. font-size: 2rem;
  177. }
  178. }
  179. }
  180. .plus-button:hover {
  181. filter: brightness(90%);
  182. }
  183. .container-image::after {
  184. content: '';
  185. position: absolute;
  186. top: 0;
  187. bottom: 0;
  188. left: 0;
  189. right: 0;
  190. background: rgba(0, 0, 0, 0.4);
  191. }
  192. .artist .plus-button {
  193. background: var(--artist-color);
  194. }
  195. .school .plus-button {
  196. background: var(--school-color);
  197. }
  198. .manager .plus-button {
  199. background: var(--manager-color);
  200. }
  201. .subtitle {
  202. margin-top: 12px;
  203. text-align: center;
  204. font-size: 1rem;
  205. }
  206. </style>