Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

CSS Handles y el poder de la personalización de bloques #6

Open
github-learning-lab bot opened this issue Aug 26, 2020 · 7 comments
Open

CSS Handles y el poder de la personalización de bloques #6

github-learning-lab bot opened this issue Aug 26, 2020 · 7 comments

Comments

@github-learning-lab
Copy link

CSS Handles y el poder de la personalización de bloques

Branch: csshandles

Introducción

Si echa un vistazo a su tienda actual, podrá ver que todos los componentes tienen estilos parecidos, incluso si usted no ha realizado ninguna personalización.

Todos estos, incluyendo el Info Card recién configurado, comparten valores preestablecidos para fuente, color de fondo, color principal, formato de los botones, etc.

Esto se debe al style.json, archivo responsable de declarar valores genéricos de personalización para toda tienda del Store Framework.

style

Para crear una identidad propia para los componentes de su tienda, puede sobrescribir estos valores a través de personalizaciones de CSS.

Analizando el recipe para personalizaciones de tienda por CSS, percibimos que serán necesarios algunos pasos para aplicar el estilo propio que usted desea, como:

  1. Cree un nuevo archivo dentro de la carpeta CSS con el nombre vtex.{AppName}.css.
  2. Utilice el CSS Handle del componente que se personalizará dentro de este archivo siguiendo el formato a continuación:
.{CSSHandle} {
    {PropriedadeDeCSS}: {ValorDesejado};
    {PropriedadeDeCSS}: {ValorDesejado};
}
  1. En ausencia de CSS Handles, aplicar CSS Selectors permitidos, como es el caso de :global(vtex-{componentName}).
  2. Para aplicar CSS en un bloque específico y no a todos los bloques de aquel tipo, se utiliza el recurso de blockClass, que aparece junto a los handles de css al inspeccionar el código. Los blockClass deben ser declarados como una prop en el bloque en cuestión, y luego hacer referencia en el archivo de estilo como se muestra a continuación:
.{CSSHandle}--{blockClass} {
    {PropriedadeDeCSS}: {ValorDesejado};
    {PropriedadeDeCSS}: {ValorDesejado};
}

Personalizando el Info Card

Para descubrir los CSS Handles de un componente, como el Info Card, basta con acceder a la sección Customization de su documentación.

De acuerdo con la descripción de CSS Handles y con el recipe de personalizaciones de tienda por CSS, pudimos implementar un ejemplo de Info Card personalizado, cambiando su título y la configuración del botón call to action al agregar el siguiente código al archivo vtex.store-components.css dentro de /styles/css:

.infoCardHeadline {
    font-family: serif;
    font-size: 2.25rem;
    font-weight: normal;
    color: gray;
    border: 2px solid black;
    padding: 24px;
}

.infoCardCallActionContainer :global(.vtex-button) {
    color: white;
    background-color: gray;
    border: transparent;
}

.infoCardCallActionContainer :global(.vtex-button):hover {
    color: gray;
    background-color: blue;
    border: transparent;
}

Puedes comprobar el efecto de los cambios realizados ejecutando el comando vtex link.

image

En seguida, añadiremos un estilo específico al info card Vintage. Para empezar, agregue la prop blockClass en el info-card#button-right como se muestra a continuación:

"info-card#button-right": {
  "props": {
    "isFullModeStyle": false,
    "textPosition": "right",
    "imageUrl": "https://appliancetheme.vteximg.com.br/arquivos/cozinha-rosa-min.png",
    "headline": "Vintage Pink",
    "subhead": "Give your kitchen a boho style adding vintage apparels.<br>Available until January 2020.",
    "callToActionMode": "button",
    "callToActionText": "Explore",
    "callToActionUrl": "/sale/d",
    "textAlignment": "center",
    "blockClass": "vintage"     //  <------------
  }
}

Y entonces declare un background-color para este info card específico en su archivo de css:

.infoCardContainer--vintage {
  background-color: #EDCFD1
}

Observe el efecto alcanzado al enlazar su app.

image

Actividad

  1. En el archivo vtex.store-components.css, copie el código anterior para usarlo en el archivo CSS de su tema, siguiendo el recipe sobre personalizaciones de tienda por CSS.
  2. Basado en los Handles del Info Card, defina el ancho máximo (max-width) de todos los info cards en 1260px, el margin en 0 auto y el padding en 0.
  3. Cambie el color del título del componente a black .
  4. Coloque el título en negrita (bold) .
  5. Cambie el color de fondo del botón durante el hover a white .
  6. Paralelamente al blockClass vintage, aplique un nuevo block class llamado metal en el info card info-card#button-left y aplique el color de fondo de #e1e1e1 en este.

image


🚫 ¿Perdido?

¿Hay algún problema con este paso? ¿Qué tal si nos envía un feedback? 🙏

Crear feedback


Si aún tiene alguna duda sobre cómo enviar su respuesta, puede revisar aquí.

@vtex-course-hub
Copy link

Oopsie, something went wrong 😿

Results

✅✅✅✅✅✅✅✅✅✅✅✅✅❌✅✅✅✅

Tests

✅ Getting the file
✅ First test - Code compilation
✅ Check Css Classes - Image
✅ Check Css Attributes - Image
✅ Check Css Attributes values - Image
✅ Check Css Classes - Text
✅ Check Css Attributes - Text
✅ Check Css Attributes values - Text
✅ Check Css Classes - Button
✅ Check Css Attributes - Button
✅ Check Css Classes and Metal blockClass
✅ Check Css Attribute Values - Metal blockclass
✅ Check Css Classes and Vintage blockClass
❌ You haven't declared the correct css attributes for the Vintage Infocard - .infoCardContainer--vintage
✅ Check Css Attributes values - Button
✅ Check Css Classes - Button Hover
✅ Check Css Attributes - Button Hover
✅ Check Css Attributes values - Button Hover

Try again 😁

4 similar comments
@vtex-course-hub
Copy link

Oopsie, something went wrong 😿

Results

✅✅✅✅✅✅✅✅✅✅✅✅✅❌✅✅✅✅

Tests

✅ Getting the file
✅ First test - Code compilation
✅ Check Css Classes - Image
✅ Check Css Attributes - Image
✅ Check Css Attributes values - Image
✅ Check Css Classes - Text
✅ Check Css Attributes - Text
✅ Check Css Attributes values - Text
✅ Check Css Classes - Button
✅ Check Css Attributes - Button
✅ Check Css Classes and Metal blockClass
✅ Check Css Attribute Values - Metal blockclass
✅ Check Css Classes and Vintage blockClass
❌ You haven't declared the correct css attributes for the Vintage Infocard - .infoCardContainer--vintage
✅ Check Css Attributes values - Button
✅ Check Css Classes - Button Hover
✅ Check Css Attributes - Button Hover
✅ Check Css Attributes values - Button Hover

Try again 😁

@vtex-course-hub
Copy link

Oopsie, something went wrong 😿

Results

✅✅✅✅✅✅✅✅✅✅✅✅✅❌✅✅✅✅

Tests

✅ Getting the file
✅ First test - Code compilation
✅ Check Css Classes - Image
✅ Check Css Attributes - Image
✅ Check Css Attributes values - Image
✅ Check Css Classes - Text
✅ Check Css Attributes - Text
✅ Check Css Attributes values - Text
✅ Check Css Classes - Button
✅ Check Css Attributes - Button
✅ Check Css Classes and Metal blockClass
✅ Check Css Attribute Values - Metal blockclass
✅ Check Css Classes and Vintage blockClass
❌ You haven't declared the correct css attributes for the Vintage Infocard - .infoCardContainer--vintage
✅ Check Css Attributes values - Button
✅ Check Css Classes - Button Hover
✅ Check Css Attributes - Button Hover
✅ Check Css Attributes values - Button Hover

Try again 😁

@vtex-course-hub
Copy link

Oopsie, something went wrong 😿

Results

✅✅✅✅✅✅✅✅✅✅✅✅✅❌✅✅✅✅

Tests

✅ Getting the file
✅ First test - Code compilation
✅ Check Css Classes - Image
✅ Check Css Attributes - Image
✅ Check Css Attributes values - Image
✅ Check Css Classes - Text
✅ Check Css Attributes - Text
✅ Check Css Attributes values - Text
✅ Check Css Classes - Button
✅ Check Css Attributes - Button
✅ Check Css Classes and Metal blockClass
✅ Check Css Attribute Values - Metal blockclass
✅ Check Css Classes and Vintage blockClass
❌ You haven't declared the correct css attributes for the Vintage Infocard - .infoCardContainer--vintage
✅ Check Css Attributes values - Button
✅ Check Css Classes - Button Hover
✅ Check Css Attributes - Button Hover
✅ Check Css Attributes values - Button Hover

Try again 😁

@vtex-course-hub
Copy link

Oopsie, something went wrong 😿

Results

✅✅✅✅✅✅✅✅✅✅✅✅✅❌✅✅✅✅

Tests

✅ Getting the file
✅ First test - Code compilation
✅ Check Css Classes - Image
✅ Check Css Attributes - Image
✅ Check Css Attributes values - Image
✅ Check Css Classes - Text
✅ Check Css Attributes - Text
✅ Check Css Attributes values - Text
✅ Check Css Classes - Button
✅ Check Css Attributes - Button
✅ Check Css Classes and Metal blockClass
✅ Check Css Attribute Values - Metal blockclass
✅ Check Css Classes and Vintage blockClass
❌ You haven't declared the correct css attributes for the Vintage Infocard - .infoCardContainer--vintage
✅ Check Css Attributes values - Button
✅ Check Css Classes - Button Hover
✅ Check Css Attributes - Button Hover
✅ Check Css Attributes values - Button Hover

Try again 😁

@vtex-course-hub
Copy link

You did great! 😁

Results

✅✅✅✅✅✅✅✅✅✅✅✅✅✅✅✅✅✅

Tests

✅ Getting the file
✅ First test - Code compilation
✅ Check Css Classes - Image
✅ Check Css Attributes - Image
✅ Check Css Attributes values - Image
✅ Check Css Classes - Text
✅ Check Css Attributes - Text
✅ Check Css Attributes values - Text
✅ Check Css Classes - Button
✅ Check Css Attributes - Button
✅ Check Css Classes and Metal blockClass
✅ Check Css Attribute Values - Metal blockclass
✅ Check Css Classes and Vintage blockClass
✅ Check Css Attribute Values - Vintage
✅ Check Css Attributes values - Button
✅ Check Css Classes - Button Hover
✅ Check Css Attributes - Button Hover
✅ Check Css Attributes values - Button Hover

@github-learning-lab
Copy link
Author

¡Ha completado este paso con éxito!

Vaya al siguiente paso:

Flex Layout: cree layouts utilizando el poder de Flexbox

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

0 participants