section with transparent cards

This commit is contained in:
María
2025-07-31 13:14:13 +02:00
committed by María
parent 86d77c3e48
commit 41d2d8a47b
12 changed files with 117 additions and 26 deletions

View File

@@ -49,8 +49,10 @@
--spacing-32: 2rem; /* 32px */ --spacing-32: 2rem; /* 32px */
--spacing-10.2: 10.25rem; /* 164px */ --spacing-10.2: 10.25rem; /* 164px */
--spacing-20.1: 20.168rem; /* 322px */ --spacing-20.1: 20.168rem; /* 322px */
--spacing-20.3: 20.313rem; /* 326px */
--spacing-20.9: 20.938rem; /* 335px */ --spacing-20.9: 20.938rem; /* 335px */
--spacing-21.8: 21.875rem; /* 350px */ --spacing-21.8: 21.875rem; /* 350px */
--spacing-22.3: 22.313rem; /* 393px */
--spacing-25.6: 25.688rem; /* 411px */ --spacing-25.6: 25.688rem; /* 411px */
--spacing-124.2: 31.063rem; /* 497px */ --spacing-124.2: 31.063rem; /* 497px */
--spacing-44.8: 44.813rem; /* 717px */ --spacing-44.8: 44.813rem; /* 717px */

View File

@@ -1,17 +1,19 @@
<template> <template>
<NuxtLink :to="`/${langcode}/${link}`"> <div
<div class="flex flex-col gap-4 rounded-3xl"
class="flex flex-col min-h-21.8 min-w-80 max-w-80 gap-4 p-8 rounded-3xl shadow-tool-card hover:border-4 border-white transition-all duration-300 ease-in-out" :class="{
:class="{ 'border-2 border-white min-h-20.3': color === 'transparent',
'bg-consumo-base hover:bg-linear-to-t hover:from-consumo-base hover:to-consumo-extra-light': color === 'consumo', 'shadow-tool-card hover:border-4 border-white transition-all duration-300 ease-in-out min-h-21.8 min-w-80 max-w-80': color !== 'transparent',
'bg-iguales-base hover:bg-linear-to-t hover:from-iguales-base hover:to-iguales-extra-light': color === 'iguales', 'bg-consumo-base hover:bg-linear-to-t hover:from-consumo-base hover:to-consumo-extra-light': color === 'consumo',
'bg-aula-base hover:bg-linear-to-t hover:from-aula-base hover:to-aula-extra-light': color === 'aula', 'bg-iguales-base hover:bg-linear-to-t hover:from-iguales-base hover:to-iguales-extra-light': color === 'iguales',
'bg-certifica-base hover:bg-linear-to-t hover:from-certifica-base hover:to-certifica-extra-light': color === 'certifica', 'bg-aula-base hover:bg-linear-to-t hover:from-aula-base hover:to-aula-extra-light': color === 'aula',
'bg-foro-base hover:bg-linear-to-t hover:from-foro-base hover:to-foro-extra-light': color === 'foro', 'bg-certifica-base hover:bg-linear-to-t hover:from-certifica-base hover:to-certifica-extra-light': color === 'certifica',
'bg-ods-base hover:bg-linear-to-t hover:from-ods-base hover:to-ods-extra-light': color === 'ods', 'bg-foro-base hover:bg-linear-to-t hover:from-foro-base hover:to-foro-extra-light': color === 'foro',
}" 'bg-ods-base hover:bg-linear-to-t hover:from-ods-base hover:to-ods-extra-light': color === 'ods',
> }"
<div class="col-span-4 h-10.2 w-full"> >
<NuxtLink v-if="link" :to="`/${langcode}/${link}`" class="p-8">
<div class="h-10.2 w-full">
<img <img
v-if="image" v-if="image"
:src="`/img/${image.src}`" :src="`/img/${image.src}`"
@@ -23,10 +25,26 @@
</div> </div>
<div class="flex flex-col gap-4 items-center"> <div class="flex flex-col gap-4 items-center">
<p class="text-5.5 font-semibold uppercase">{{ title }}</p> <p class="text-5.5 font-semibold uppercase">{{ title }}</p>
<p class="text-center text-base">{{ description }}</p> <p class="text-center text-base" v-html="description"></p>
</div>
</NuxtLink>
<div v-if="!link" class="flex flex-col gap-4 p-8 items-center">
<div class="h-25 w-25">
<img
v-if="image"
:src="`/img/${image.src}`"
:alt="image.alt"
class="w-full h-full object-cover"
/>
<!-- <img v-else src="" alt="imagen-error"> -->
<!-- TODO: Add a fallback image -->
</div>
<div class="flex flex-col gap-4 items-center">
<p class="text-5.5 font-semibold uppercase">{{ title }}</p>
<p class="text-center text-base" v-html="description"></p>
</div> </div>
</div> </div>
</NuxtLink> </div>
</template> </template>
<script> <script>

View File

@@ -1,7 +1,7 @@
<template> <template>
<section <section
:id="id" :id="id"
class="relative flex flex-col p-4 md:p-12 mb-8 items-center justify-center gap-4 md:gap-8 text-center rounded-3xl" class="relative flex flex-col p-8 md:p-12 mb-8 items-center justify-center gap-4 md:gap-8 text-center rounded-3xl"
:class="{ :class="{
'bg-consumo-base bg-linear-to-t from-consumo-base to-consumo-extra-light': bgColor === 'consumo', 'bg-consumo-base bg-linear-to-t from-consumo-base to-consumo-extra-light': bgColor === 'consumo',
'bg-iguales-base bg-linear-to-t from-iguales-base to-iguales-extra-light': bgColor === 'iguales', 'bg-iguales-base bg-linear-to-t from-iguales-base to-iguales-extra-light': bgColor === 'iguales',

View File

@@ -99,6 +99,12 @@ export default {
menuIsOpen: false, menuIsOpen: false,
}; };
}, },
watch: {
'$route': function() {
this.dropdownOpen = false; // Close dropdown on language change
this.menuIsOpen = false; // Close mobile menu on language change
}
},
computed: { computed: {
langcode() { langcode() {
return this.$store.getters.langcode; return this.$store.getters.langcode;

View File

@@ -1,14 +1,29 @@
<template> <template>
<section <section
:id="id" :id="id"
class="flex flex-col gap-8 lg:gap-21 rounded-3xl mb-8 px-4 pt-12 pb-16 md:p-16 md:pb-24 bg-gradient-conic-cards "> class="flex flex-col gap-8 rounded-3xl mb-8 px-4 pt-12 pb-16 md:p-16 md:pb-24"
:class="{
'bg-gradient-conic-cards': bgColor === 'gradient-conic',
'bg-linear-to-t from-consumo-extra-light to-background-light': bgColor === 'consumo',
'bg-linear-to-t from-iguales-extra-light to-background-light': bgColor === 'iguales',
'bg-linear-to-t from-aula-extra-light to-background-light': bgColor === 'aula',
'bg-linear-to-t from-certifica-extra-light to-background-light': bgColor === 'certifica',
'bg-linear-to-t from-foro-extra-light to-background-light': bgColor === 'foro',
'bg-linear-to-t from-ods-extra-light to-background-light': bgColor === 'ods',
}">
<div class="flex flex-col justify-center items-center w-full"> <div class="flex flex-col justify-center items-center w-full">
<h2 class="text-4xl font-bold mb-6">{{ title }}</h2> <h2 class="font-bold mb-6">{{ title }}</h2>
<p class="mb-8 text-lg">{{ description }}</p> <p class="text-lg text-center" v-html="description"></p>
</div> </div>
<ul class="grid grid-cols-12 gap-8 mx-auto"> <ul class="grid grid-cols-12 gap-8 mx-auto">
<li v-for="(item, index) in cards" :key="`cards-${id}-${index}`" class="col-span-12 md:col-span-6 lg:col-span-4"> <li
v-for="(item, index) in cards" :key="`cards-${id}-${index}`"
:class="{
'col-span-12 md:col-span-6 lg:col-span-4': display === 'col-3',
'col-span-12 lg:col-span-4': display === 'col-3-transparent',
'col-span-12 md:col-span-6 lg:col-span-3': display === 'col-4',
}">
<CardTool <CardTool
:color="item.color" :color="item.color"
:title="item.title" :title="item.title"
@@ -37,7 +52,15 @@ export default {
type: String, type: String,
default: "", default: "",
}, },
cards: { display: {
type: String,
default: "col-3",
},
bgColor: {
type: String,
default: "",
},
cards: {
type: Array, type: Array,
default: () => [], default: () => [],
}, },

View File

@@ -11,15 +11,15 @@
'lg:flex-row': position === 'left', 'lg:flex-row': position === 'left',
'lg:flex-row-reverse': position === 'right', 'lg:flex-row-reverse': position === 'right',
'items-center gap-12': image.display === 'circle', 'items-center gap-12': image.display === 'circle',
'items-start': image.display === 'normal' && position === 'left', 'items-center lg:items-start gap-8': image.display === 'normal' && position === 'left',
'items-start justify-between': image.display === 'normal' && position === 'right' 'items-center lg:items-start justify-between gap-8': image.display === 'normal' && position === 'right'
}"> }">
<div <div
v-if="image" v-if="image"
:class="{ :class="{
'h-20.1 w-20.1 rounded-full overflow-hidden border-4 border-white': image.display === 'circle', 'h-20.1 w-20.1 rounded-full overflow-hidden border-4 border-white': image.display === 'circle',
'h-20.9 w-fit': image.display === 'normal' 'h-fit lg:h-20.9 w-full lg:w-fit': image.display === 'normal'
}"> }">
<img <img
:src="`/img/${image.src}`" :src="`/img/${image.src}`"

View File

@@ -35,5 +35,44 @@
"display": "normal" "display": "normal"
} }
} }
},
{
"component": "SectionWithCards",
"props": {
"id": "herramientas",
"title": "¿Cómo funciona?",
"description": "Consumo Cuidado no es una tienda online tradicional.</br>Es una plataforma tipo escaparate digital descentralizado.",
"display": "col-3-transparent",
"bgColor": "consumo",
"cards": [
{
"color": "transparent",
"title": "sin intermediación",
"description": "Cada entidad gestiona sus propios pedidos.</br>No hay plataformas externas que actúen como intermediarias ni controlen el proceso de venta.",
"image": {
"src": "handshake.png",
"alt": "Manos dándose la mano"
}
},
{
"color": "transparent",
"title": "descentralizado",
"description": "La plataforma visibiliza los productos y servicios, pero no gestiona ventas ni entregas: cada entidad mantiene el control de su proceso.",
"image": {
"src": "waypoints.png",
"alt": "Waypoint"
}
},
{
"color": "transparent",
"title": "RELACIÓN CERCANA",
"description": "Puedes contactar directamente con las entidades productoras.</br>Conoces quién está detrás de lo que compras.",
"image": {
"src": "messages-square.png",
"alt": "Mensaje"
}
}
]
}
} }
] ]

View File

@@ -62,6 +62,7 @@
"title": "Explora las herramientas del kit-ECO.SOCIAL", "title": "Explora las herramientas del kit-ECO.SOCIAL",
"description": "Elige la herramienta que mejor se adapte a tu entidad. Todas son gratuitas, prácticas y pensadas para organizaciones de economía social.", "description": "Elige la herramienta que mejor se adapte a tu entidad. Todas son gratuitas, prácticas y pensadas para organizaciones de economía social.",
"display": "col-3", "display": "col-3",
"bgColor": "gradient-conic",
"cards": [ "cards": [
{ {
"color": "consumo", "color": "consumo",

View File

@@ -12,11 +12,13 @@
<script> <script>
import HeroPages from '~/components/HeroPages.vue'; import HeroPages from '~/components/HeroPages.vue';
import TextWithImage from '../../components/TextWithImage.vue'; import TextWithImage from '../../components/TextWithImage.vue';
import SectionWithCards from '../../components/SectionWithCards.vue';
export default { export default {
components: { components: {
HeroPages, HeroPages,
TextWithImage TextWithImage,
SectionWithCards
}, },
data() { data() {
return { return {

BIN
public/img/handshake.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.4 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1022 B

BIN
public/img/waypoints.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.4 KiB