Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

This document provides resort guidance for developing brand footers for their Aspenware eCommerce web application. Documentation on implementing the Simple Footer option can be found here.

Table of Contents

1. Responsiveness and Breakpoints

...

Current Breakpoints

If you are targeting the current eCommerce platform breakpoints, please use:

...

If you are targeting future support as we update our platform, our breakpoints will be changing to better target modern devices. Aspenware will be updating our breakpoints to the following over the next 18 monthsas we evolve the platform. For this reason, we recommend you target the updated values. While there will be some inconsistency in your footer and the platform breakpoints while Aspenware makes this conversion, it will prevent you from having to update your CSS again down the road.

info
Code Block
sm: 37.5rem,
md: 60rem,
lg: 79rem,
xl: 119rem,

Mobile First

The Aspenware Commerce Platform is built mobile first, so when creating your CSS breakpoints for your brand footer we recommend targeting min-width instead of max-width.

ExampleFor example:

Code Block
@media only screen and (min-width: 60rem) {
  // YOUR CSS
}

2. Scoping CSS

Preventing Footer CSS leaks into your eCommerce site

...

To prevent this, we strongly recommend scoping all footer CSS by encapsulating it in a unique ID.

Info

Replace

...

your-

...

resort with your resorts name, lowercase, dash separated.

For exampleexample…

In your CSS:

Code Block
#YOUR#your-RESORTresort-brandfooter p { font-size: 1rem };
#YOUR#your-RESORTresort-brandfooter h1 { color: #000 };

And in your HTML:

Code Block
<div id="your-resort-brandfooter">
   <h1>YOUR RESORT NAME</h1> 
   <p>Welcome to MY RESORT<p>
   <ul>
      <li><a href="home">Home</li>
      ...
   </ul>
   ...
</div>

If you are using SASS to write the CSS and precompiling, you can simply wrap all your CSS in the unique ID:

Code Block
#YOUR#your-RESORTresort-brandfooter {
   p { font-size: 1rem };
   h1 { color: #000 };
}

...

Aspenware does its best to scope CSS but some CSS libraries we use may leak into your footer styles. If this happens, feel free to use !important on your scoped rules to ensure your styles are applied to your footer.

For example:

#YOUR#your-RESORTresort-brandfooter p { color: red !important }

3. Using Libraries and Frameworks in your Brand Footer

CSS Libraries

CSS libraries such as Bootstrap getting inserted into the page via the footer may cause conflicts with your eCommerce page design. If you must use a CSS library, please check the CSS library documentation to see if it is possible to scope the library to the context of your footer.

Javascript Frameworks

Do to conflicts with Javascript on page, using JavaScript in the footer is unsupported and we will not be able to help you if there are issues.

We utilize Vue.js on our front end and resorts have had difficulty inserting a second Vue instance into their headers and footers as the two Vue instances tend to conflict with each other. If you are going to attempt to use Vue for your footer, make sure that the instance is attaching to the ID of your footer container eg. #YOUR#your-RESORTresort-brandfooter (vs. using the default #app) and does not insert any components into the global page scope (window). It is also advised to enable scoped CSS in any Vue component files.

You may have more success using a different framework, such as React or Svelte.

In general, using frameworks for the footer is untested and unsupported at this time, so please be aware of the risk that you may run into issues.

4. Aspenware Theme Support for Resort Footers

Aspenware has internal tooling that we utilize to update the theme properties of your eCommerce site if your resort updates its branding. We have the ability to utilize the same tool to update the colors and logo in your footer on your behalf. To do this, you simply utilize special CSS Custom Properties when developing your brand footer.

The table below lists the Custom CSS Property names available to use and which elements they should be used on to enable us to manage update your eCommerce footer theme for youalong with the rest of the eCommerce application if your resort undertakes a brand update.

If you prefer to manage the theming of your footer on your own, you are welcome to do that by not including any of these properties in your footer CSS. The CSS custom property names must be used exactly as written. Please do not alter the --ads-* property names.

Info

Be sure to include CSS Property fallback values. These values will get applied to your footer styles in the event that Aspenware has not yet configured your footer theme or if the page has a problem loading the Aspenware custom properties.

CSS Custom Property

Use Cases

How to Use

--ads-plugins-brandfooter-backgroundcolor

The main background color for the footer

Code Block
#YOUR
#your-
RESORT
resort-brandfooter { background-color: var(--ads-plugins-brandfooter-backgroundcolor, FALLBACK COLOR);}

Replace FALLBACK COLOR with the default color that should be applied (eg. #334455)

if

. If the page had a problem loading the --ads-plugins-brandfooter-backgroundcolor property

(

or it was not configured yet by AW

)

this default value will load in its place.

--ads-plugins-brandfooter-header-

font-color

textcolor

The color for any headers in your brand footer

Code Block
#YOUR
#your-
RESORT
resort-brandfooter h1, 
#YOUR
#your-
RESORT
resort-brandfooter h2{
   var(--ads-plugins-brandfooter-header-
font-color
textcolor, FALLBACK COLOR);
}

Replace FALLBACK COLOR with the default color that should be applied

if

. If the page had a problem loading the --ads-plugins-brandfooter-header-

backgroundcolor

textcolor property

(

or it was not configured yet by AW

)

this default value will load in its place.

--ads-plugins-brandfooter-body-textcolor

The color for the body copy in your brand footer

Code Block
#YOUR
#your-
RESORT
resort-brandfooter p{
   color: var(--ads-plugins-brandfooter-body-textcolor, FALLBACK COLOR);
}

Replace FALLBACK COLOR with the default brand color that should be applied

if

(in hex format). If the page had a problem loading the --ads-plugins-brandfooter-body-textcolor property

(

or it was not configured yet by AW

)

this default value will load in its place.

--ads-plugins-brandfooter-link-textcolor

The color for the links in your brand footer

Code Block
#YOUR
#your-
RESORT
resort-brandfooter a {
  color: var(--ads-plugins-brandfooter-link-textcolor, FALLBACK COLOR);
}

Replace FALLBACK COLOR with the default brand color that should be applied

if

(in hex format). If the page had a problem loading the --ads-plugins-brandfooter-link-textcolor property

(

or it was not configured yet by AW

)

this default value will load in its place.

--ads-plugins-brandfooter-link-hover-textcolor

The color for the link interactive states in your brand footer

Code Block
#YOUR
#your-
RESORT
resort-brandfooter a:hover, 
#YOUR
#your-
RESORT
resort-brandfooter a:active, 
#YOUR
#your-
RESORT
resort-brandfooter a:visited {
  color: var(--ads-plugins-brandfooter-link-hover-textcolor, FALLBACK COLOR);
}

Replace FALLBACK COLOR with the default brand color that should be applied

if

(in hex format). If the page had a problem loading the --ads-plugins-brandfooter-link-hover-textcolor property

(

or it was not configured yet by AW

)

this default value will load in its place.

--ads-plugins-brandfooter-logo-image

The path to the logo image. For this to work, you must set your logo as a background image on

either

a div

or a span



Code Block
#YOUR
#your-
RESORT
resort-brandfooter .logo-image {
  height:80px; //adjust as needed for your logo dimensions
  width: 100px; //adjust as needed for your logo dimensions
  background-position: center;
  background-size: contain; //logo image will auto scale to fit the size of the container
  background-repeat: no-repeat;
  background: var(--ads-plugins-brandfooter-logo-image, url('URL TO FALLBACK IMAGE'));
}

Replace URL TO FALLBACK IMAGE with the path to

your

a default logo image that should be applied (eg url('https://brandsite.com/assets/logo.png'))

if

. If the page had a problem loading the --ads-plugins-brandfooter-logo-image property

(

or it was not configured yet by AW

)

, this path will load instead.

You can also omit the fallback URL if you are not hosting a version on your brand site. Our Customer Service team will address this with our internal tools during setup.

For accessibility, place include this role and aria-label on the div or span.

<div id="

#YOUR

#your-

RESORT

resort-brandfooter-logo" role="img" aria-label="logo"></div>

Info

If you use this prop as described, Aspenware will be able to host your logo for you on our file servers. Otherwise you will need to host the logo file for your footer and link to it in your footer markup, either inline or as a background image.

5. Deliverables

Aspenware is going to insert your custom brand footer HTML and CSS into the Commerce site using standard WYSIWYG tooling. To accomplish this, we require the following deliverables.

  1. A single HTML file that contains your Footer HTML. You can inline the CSS if you wish, but for maintainability reasons it is recommended to put all your CSS in a separate CSS file.

  2. If not inlining your CSS: A single CSS file with your footer CSS. If you are using SCSS or SASS, please export it to CSS. If you want your footer to be easily updated by our Customer Success team with our internal theming tools to account for future branding updates (avoids long deploy cycle turn around times), please use the CSS Custom properties defined in section 4 within your CSS when defining certain property values.

6. More Information on These Topics