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 and the power of customizing blocks #6

Open
github-learning-lab bot opened this issue Aug 11, 2020 · 4 comments
Open

CSS Handles and the power of customizing blocks #6

github-learning-lab bot opened this issue Aug 11, 2020 · 4 comments

Comments

@github-learning-lab
Copy link

CSS Handles and the power of customizing blocks

Branch: csshandles

Introduction

Taking a quick look at your online store, you'll notice that components have similar styles, even without applying any customization.

All of them, including the recently configured Info Card, share pre-established values for font, background color, main color, button format, etc.

This is due to the style.json, the file responsible for declaring generic customization values for every Store Framework store.

style

To create a unique identity for your store's components, you can overwrite these values using CSS customizations.

Analyzing the recipe employed to customize stores using CSS, we can notice that several steps will be needed in order to apply your own style, such as:

  1. Create a new file in the CSS folder, naming it vtex.{AppName}.css

  2. Use the CSS Handle of the component that will be customized in this file in the following format:

    .{CSSHandle} {
        {PropriedadeDeCSS}: {ValorDesejado};
        {PropriedadeDeCSS}: {ValorDesejado};
    }
  3. Lacking CSS Handles, apply permitted CSS Selectors, such as :global(vtex-{componentName}).

  4. To apply CSS to a specific block and not to every block of that type, use the blockClass resource, which appears next to the CSS Handles when inspecting your code. The blockClass must be declared as a prop in the block in question, and thus be referenced in the style file as shown below:

    .{CSSHandle}--{blockClass} {
        {CSSProperty}: {desiredValue};
        {CSSProperty}: {desiredValue};
    }

Customizing the Info Card

To uncover a component's CSS Handles, such as the Info Card, simply access your documentation's Customization section.

According to the description of CSS Handles and to the store customization recipe using CSS, we can implement a customized Info Card example, editing its title and call-to-action button configurations by adding the following code to the vtex.store-components.css file, found in /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;
}

You can check the effect of these changes by running the vtex link command.

image

Next, we'll add a specific style to the vintage info card. To begin, add the blockClassprop to info-card#button-right, as shown below:

"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"     //  <------------
  }
}

Thereafter, declare a background-color for this specific info card in your CSS file:

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

Check out the result by linking your app.

image

Activity

  1. In the vtex.store-components.css file, copy the above-mentioned code and use it in your theme's CSS file, according to the recipe on store customizations using CSS;
  2. Based on the Info Card Handles, define a maximum width (max-width) of 1260px for all info cards, a margin of 0 auto and a padding of 0.
  3. Change the component's title color to black;
  4. Put the title in bold;
  5. Change the call-to-action buttons background color during hover to white;
  6. In parallel to the vintage blockClass, apply a new block class called metal to the info card info-card#button-left and apply the #e1e1e1 background color to it.

image


🚫 Are you lost?

Is there any problem with this step? What about sending us a feedback? 🙏

Submit feedback


If you're still unsure as to how to send your answers, click here.

@vtex-course-hub
Copy link

Oopsie, something went wrong 😿

Results

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

Tests

✅ Getting the file
✅ First test - Code compilation
❌ You haven't declared .infoCardContainer classes for the image
❌ You haven't declared the attributes correctly for the image - .infoCardContainer
❌ You haven't declared the attributes values correctly for the image - .infoCardContainer
✅ 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
❌ You haven't declared the attributes values correctly for the button hover - .infoCardCallActionContainer :global(.vtex-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
✅ Check Css Attribute Values - Vintage
✅ Check Css Attributes values - Button
✅ Check Css Classes - Button Hover
✅ Check Css Attributes - Button Hover
❌ You haven't declared the attributes values correctly for the button hover - .infoCardCallActionContainer :global(.vtex-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

You have successfully completed this step!

Go to the next step!

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